# Matrox Graphics Inc. **Matrox** MGA-G400 Specification Document Number 10617-MS-0101 June 2, 1999 ## **Trademark Acknowledgements** MGA, $T^{\text{TM}}$ MGA-G400, $T^{\text{M}}$ MGA-1164SG, $T^{\text{M}}$ MGA-2064W, $T^{\text{M}}$ MGA-2164W, $T^{\text{M}}$ MGA-VC064SFB, $T^{\text{M}}$ MGA Marvel, $T^{\text{M}}$ MGA Millennium, $T^{\text{M}}$ MGA Mystique, $T^{\text{M}}$ MGA Rainbow Runner, $T^{\text{M}}$ MGA DynaView, $T^{\text{M}}$ PixelTOUCH, $T^{\text{M}}$ MGA Control Panel, $T^{\text{M}}$ $T^{\text{M$ Matrox® is a registered trademark of Matrox Electronic Systems Ltd. VGA, <sup>®</sup> is a registered trademark of International Business Machines Corporation; Micro Channel<sup>TM</sup> is a trademark of International Business Machines Corporation. Intel® is a registered trademark, and 386,<sup>TM</sup> 486,<sup>TM</sup> Pentium,<sup>TM</sup> and 80387<sup>TM</sup> are trademarks of Intel Corporation. Windows<sup>TM</sup> is a trademark of Microsoft Corporation; Microsoft, $^{\textcircled{\$}}$ and MS-DOS $^{\textcircled{\$}}$ are registered trademarks of Microsoft Corporation. AutoCAD® is a registered trademark of Autodesk Inc. $Unix^{TM}$ is a trademark of AT&T Bell Laboratories. X-Windows<sup>TM</sup> is a trademark of the Massachusetts Institute of Technology. AMD<sup>TM</sup> is a trademark of Advanced Micro Devices. Atmel<sup>®</sup> is a registered trademark of Atmel Corporation. Catalyst<sup>TM</sup> is a trademark of Catalyst Semiconductor Inc. SGS<sup>TM</sup> is a trademark of SGS-Thompson. Toshiba<sup>TM</sup> is a trademark of Toshiba Corporation. Texas Instruments<sup>TM</sup> is a trademark of Texas Instruments. National<sup>TM</sup> is a trademark of National Semiconductor Corporation. Microchip<sup>TM</sup> is a trademark of Microchip Technology Inc. All other nationally and internationally recognized trademarks and tradenames are hereby acknowledged. # This document contains confidential proprietary information that may not be disclosed without written permission from Matrox Graphics Inc. © Copyright Matrox Graphics Inc., 1997. All rights reserved. Disclaimer: Matrox Graphics Inc. reserves the right to make changes to specifications at any time and without notice. The information provided by this document is believed to be accurate and reliable. However, no responsibility is assumed by Matrox Graphics Inc. for its use; nor for any infringements of patents or other rights of third parties resulting from its use. No license is granted under any patents or patent rights of Matrox Graphics Inc. or Matrox Electronic Systems Ltd. # **Contents** | Chapte | er 1: MGA Overview | |--------|------------------------------------------------------------| | 1.1 | Introduction | | | 1.1.1 Supported Multimedia Features | | 1.2 | System Block Diagram | | 1.3 | Chip Specifications1-4 | | | 1.3.1 Performance Characteristics and Key Features 1-4 | | | 1.3.2 2D Drawing Engine1-5 | | | 1.3.3 3D Rendering Engine | | | 1.3.4 Video and Multimedia Features | | 1.4 | Typographical Conventions Used | | 1.5 | Locating Information | | Chapte | er 2: Resource Mapping | | 2.1 | Memory Mapping | | | 2.1.1 Configuration Space Mapping | | | 2.1.2 MGA General Map | | | 2.1.3 MGA Control Aperture | | 2.2 | Register Mapping | | Chapte | er 3: Register Descriptions | | • | Power Graphic Mode Register Descriptions | | | 3.1.1 Power Graphic Mode Configuration Space Registers 3-2 | | | 3.1.2 Power Graphic Mode Memory Space Registers | | 3.2 | VGA Mode Register Descriptions | | | 3.2.1 VGA Mode Register Descriptions | | 3.3 | DAC Registers | | | 3.3.1 DAC Register Descriptions | | Chapte | er 4: Programmer's Specification | | 4.1 | HOST Interface | | | 4.1.1 Introduction | | | 4.1.2 PCI Retry Handling | | | 4.1.3 PCI Burst Support | | | 4.1.4 PCI Target-Abort Generation | | | 4.1.5 Transaction Ordering | | | 4.1.6 Direct Access Read Cache | | | 4.1.7 Big-Endian Support | | | 4.1.8 Host Pixel Format | | | 4.1.9 Programming Bus Mastering for DMA Transfers 4-12 | | 4.2 | Memory Interface | | | 4.2.1 | Frame Buffer Organization | 4-19 | |-----|--------|------------------------------------------------------------------|------| | | 4.2.2 | Pixel Format | 4-21 | | 4.3 | Chip C | Configuration and Initialization | 4-23 | | | 4.3.1 | Reset | 4-23 | | | 4.3.2 | Operations After Hard Reset | 4-23 | | | 4.3.3 | Power Up Sequence | 4-24 | | 4.4 | Direct | Frame Buffer Access | 4-28 | | 4.5 | Drawir | ng in Power Graphic Mode | 4-29 | | | | Drawing Register Initialization Using General Purpose Pseudo-DMA | | | | | Overview | | | | 4.5.3 | Global Initialization (All Operations) | 4-31 | | | 4.5.4 | Line Programming | 4-31 | | | 4.5.5 | Trapezoid / Rectangle Fill Programming | 4-36 | | | 4.5.6 | Sub-Pixel Trapezoids | 4-54 | | | 4.5.7 | Bitblt Programming | 4-58 | | | | ILOAD Programming | | | | 4.5.9 | Loading the Texture Color Palette | 4-68 | | 4.6 | CRTC | Programming | 4-70 | | | 4.6.1 | Horizontal Timing | 4-70 | | | | Vertical Timing | | | | | Memory Address Counter | | | | 4.6.4 | Programming in VGA Mode | 4-73 | | | | Programming in Power Graphic Mode | | | 4.7 | Video | Interface | 4-79 | | | | Operation Modes | | | | 4.7.2 | Palette RAM (LUT) | 4-80 | | | 4.7.3 | Hardware Cursor | 4-81 | | | 4.7.4 | Keying Functions | 4-81 | | | 4.7.5 | Zooming | 4-82 | | | 4.7.6 | Feature Connector | 4-82 | | | 4.7.7 | Test Functions | 4-85 | | | 4.7.8 | Clock Generator Circuit | 4-86 | | 4.8 | | Input Interface | | | | | Overview of the Video-Grabber | | | | | MAFC Mode Selection | | | | 4.8.3 | Vertical Blanking and VBI Count | 4-94 | | | | Capture Modes / C-Cube Compatibility | | | | 4.8.5 | UYVY and YUY2 Formats | 4-98 | | | 4.8.6 | Task Based VBI Detection | 4-98 | | | 4.8.7 | Field/Task Generated Interrupts | 4-98 | | | 4.8.8 | Horizontal Downscaling by 1/2 | 4-99 | | | 4.8.9 Feedback Path from Second CRTC | . 4-99 | |------|---------------------------------------------------------|--------------| | | 4.8.10 Maximum Height Definition | . 4-99 | | | 4.8.11 Programming Sequence | . 4-99 | | | 4.8.12 Programming Table | 4-100 | | 4.9 | CODEC Interface | 4-101 | | | 4.9.1 Memory Organization | 4-101 | | | 4.9.2 Command Execution | 4-102 | | | 4.9.3 Output mode | 4-106 | | | 4.9.4 CODEC Interface RESET to IDLE Procedure | 4-107 | | | 4.9.5 Recovery Width Programming | <b>4-107</b> | | | 4.9.6 Miscellaneous Control Programming | 4-108 | | | 4.9.7 Compressing data | 4-108 | | | 4.9.8 Decompressing data | 4-112 | | | 4.9.9 Error Recovery | 4-114 | | 4.10 | Backend Scaler | 4-115 | | | 4.10.1 Introduction | 4-115 | | | 4.10.2 Horizontal Scaling | 4-118 | | | 4.10.3 Vertical Scaling | 4-121 | | | 4.10.4 Keying | 4-128 | | | 4.10.5 Miscellaneous Functions | 4-129 | | | 4.10.6 BES Parameter Example: | 4-130 | | 4.11 | Interrupt Programming | 4-131 | | 4.12 | Power Saving Features | 4-135 | | | 4.12.1 Entering Power Saving Mode | 4-135 | | | 4.12.2 Coming Out of Power Saving Mode | | | 4.13 | Accessing the Serial EEPROM | | | | 4.13.1 SEEPROM State Machine Bypass | 4-138 | | 4.14 | Second CRTC Programming | 4-140 | | | 4.14.1 Characteristics | 4-140 | | | 4.14.2 Horizontal Timing | 4-142 | | | 4.14.3 Vertical Timing | | | | 4.14.4 Second CRTC Memory Address Generator | 4-143 | | | 4.14.5 Register Programming Methodology | 4-149 | | | 4.14.6 DVD Support Programming | 4-150 | | | 4.14.7 Data Control | 4-152 | | | 4.14.8 NTSC Support | | | | 4.14.9 Stop the Second CRTC Memory Requests | 4-153 | | | 4.14.10 Turning Off the Second CRTC (Power Saving Mode) | 4-153 | | 4.15 | AGP I/O Buffer Compensation | | | | 4.15.1 Compensation Override | 4-154 | | Chapte | er 5: Hardware Designer's Notes | |--------------|------------------------------------------------------------| | 5.1 | Introduction | | 5.2 | Host AGP Interface | | 5.3 | Snooping 5-2 | | 5.4 | EEPROM Devices5-3 | | 5.5 | Memory Interface | | | 5.5.1 SGRAM Configurations | | 5.6 | Video interface | | | 5.6.1 Slaving the Matrox G400 | | | 5.6.2 Genlock Mode | | | 5.6.3 Crystal Resonator Specification | | Appen | dix A: Technical Information | | A.1 | Pin List | | | A.1.1 Host (AGP) | | | A.1.2 Host (Local Mode) | | | A.1.3 Memory Interface | | | A.1.4 Video Display Interface | | | A.1.5 Video In Interface | | | A.1.6 Video Out Interface | | | A.1.7 CODEC Interface | | | A.1.8 SEEPROM | | | A.1.9 Analog Signals | | | A.1.10 Miscellaneous Functions | | | A.1.11 TEST | | | A.1.12 Power and Ground Supplies | | | AGP Pinout Illustration and Table | | A.3 | Electrical Specification | | | A.3.1 DC Specifications | | | A.3.2 AC Specifications | | | Mechanical Specification | | A.5 | NAND-Tree | | | A.5.1 Nand-Tree Operation for Matrox G400 Rev. A | | | A.5.2 Nand-Tree Operation for Matrox G400 Rev. B and later | | A.6 | Ordering Information | | <b>Appen</b> | dix B: Changes | | B.1 | Changes in the Document Since Revision 0100 | | | B.1.1 Chip Revision Notes and Changes | # List of Figures | Chapter 1: MGA Overview | |------------------------------------------------------------------| | Figure 1-1: System Block Diagram | | Figure 1-2: Matrox G400 Block Diagram | | Figure 1-3: Matrox G400 DualHead Display | | Chapter 2: Resource Mapping Not Applicable | | Chapter 3: Register Descriptions | | Figure 3-1: : Alpha Processing Unit | | Figure 3-2: : Color Processing Unit | | Figure 3-3: Transparency and Lighting Control | | Figure 3-4: Lighting Module (RGB) | | Chapter 3: | | Not Applicable | | Chapter 4: Programmer's Specification | | Figure 4-1: OPTION<12:10> memconfig [2:0] = '000' or '100' | | Figure 4-2: OPTION<12:0> memconfig [2:0] = '001' or '010' | | Figure 4-3: OPTION<12:10> memconfig [2:0] = '011' or '101' | | Figure 4-4: Drawing Multiple Primitives | | Figure 4-5: CRTC Horizontal Timing | | Figure 4-6: CRTC Vertical Timing | | Figure 4-7: Video Timing in Interlace Mode | | Figure 4-8: System Clocks | | Figure 4-9: Video Clocks | | Figure 4-10: CODEC Interface Organization | | Figure 4-11: CODEC Command Format | | Figure 4-12: Address Space of I33 CODEC in Code Slave Mode 4-104 | | Figure 4-13: Compression of a Live Video Source | | Figure 4-14: Decompressing Data from the Memory 4-112 | | Figure 4-15: Second CRTC Data Path | | Figure 4-16: 420 YCbCr data groupings | | Figure 4-17: 420 YCbCr data groupings (cont) | | Figure 4-18: 420 YCbCr data groupings (cont) | | Figure 4-19: 420 YCbCr data groupings (cont) | | Chapter 5: Hardware Designer's Notes | | |-----------------------------------------------------------------------|------| | Figure 5-1: AGP Interface | 5-2 | | Figure 5-2: External Device Configuration | 5-3 | | Figure 5-3: Memory Pinout Mapping (memconfig = '000') | 5-8 | | Figure 5-4: Memory Pinout Mapping (memconfig = '001') | 5-9 | | Figure 5-5: Memory Pinout Mapping (memconfig = '010') | 5-10 | | Figure 5-6: Memory Pinout Mapping (memconfig = '011') | 5-11 | | Figure 5-7: Memory Pinout Mapping (memconfig = '100') | 5-12 | | Figure 5-8: Memory Pinout Mapping (memconfig = '101') | 5-13 | | Figure 5-9: VIDRST, Internal Horizontal/Vertical Active, and VOBLANKN | 5-14 | | Figure 5-10: Video Interface | 5-17 | | Figure 5-11: Video Connector | 5-18 | | Chapter A: Technical Information | | | Figure A-1: AGP Pinout Illustration | A-8 | | Figure A-2: V/I Curves for AGP 2X Buffers (Pull Up) Vddq = 3.3V | A-13 | | Figure A-3: V/I Curves for AGP 2X Buffers (Pull Down) Vddq = 3.3V | A-13 | | Figure A-4: V/I Curves for AGP 4X Buffers (Pull Up) Vddq = 1.5V | A-14 | | Figure A-5: V/I Curves for AGP 4X Buffers (Pull Down) Vddq = 1.5V | A-14 | | Figure A-6: AGP 1X Timing | A-18 | | Figure A-7: AGP 2X Timing Diagram | A-19 | | Figure A-8: AGP 2X Strobe/Data Turnaround Timings | | | Figure A-9: AGP 4X Timing Diagram | A-21 | | Figure A-10: AGP 4X Strobe/Data Turnaround Timings | | | Figure A-11: Serial EEPROM Waveform | A-22 | | Figure A-12: MAFC Waveform | | | Figure A-13: Panel Link Mode | | | Figure A-14: Bypass Mode & CRTC2 656 mode | A-24 | | Figure A-15: PanelLink and MAFC RGB Datapath | | | Figure A-16: MAFC 656 Datapath | | | Figure A-17: Memory Interface Waveform | | | Figure A-18: Read Followed by Precharge (Tcl=3) | | | Figure A-19: Read Followed by a Precharge (Tcl = 2) | | | Figure A-20: Write Followed by Precharge | | | Figure A-21: Read Followed by Write (Tcl =3) | | | Figure A-22: Read Followed by Write (Tcl =2) | | | Figure A-23: Write Followed by Read (same chip select) | | | Figure A-24: Write Followed by Read (different chip select) | | | Figure A-25: Read to Both Banks (same chip select) | A-32 | | Figure A-26: Read to Different Banks (different chip select) | A-32 | |---------------------------------------------------------------|------| | Figure A-27: Write to Both Banks (same chip select) | A-33 | | Figure A-28: Write to Different Banks (different chip select) | A-33 | | Figure A-29: Power-On Sequence | A-34 | | Figure A-30: Block Write and Special Mode Register command | A-34 | | Figure A-31: Memory Refresh Sequence | A-35 | | Figure A-32: I33 Mode, Writes | A-36 | | Figure A-33: I33 Mode, Reads | A-36 | | Figure A-34: VMI Mode A Writes | A-37 | | Figure A-35: VMI Mode A, Reads | A-37 | | Figure A-36: VMI Mode B, Writes | A-38 | | Figure A-37: VMI Mode B, Reads | A-38 | | Figure A-38: Video In Timings | A-40 | | Figure A-39: Matrox G400 Mechanical Drawing | A-41 | # **Chapter B: Changes** Not Applicable # List of Tables | Chapter 1: MGA Overview | |-----------------------------------------------------------------------------------| | Table 1-1: Typographical Conventions | | Chapter 2: Resource Mapping | | Table 2-1: Matrox G400 Configuration Space Mapping2-2 | | Table 2-2: MGA General Map | | Table 2-3: MGA Control Aperture (extension of Table 3-2) | | Table 2-4: Register Map (Part 1 of 14) | | Chapter 3: Register Descriptions | | Table 3-1: Lighting Module (ALPHA) | | Chapter 4: Programmer's Specification | | Table 4-1: Display Modes (Part 1 of 2) | | Table 4-2: offsetselect = '0000' 4-46 | | Table 4-3: offsetselect = 'XXX1' | | Table 4-4: offsetselect = 'XX10' | | Table 4-5: offsetselect = 'X100' | | Table 4-6: offsetselect = '1000' 4-48 | | Table 4-7: ILOAD Source Size | | Table 4-8: ILOAD Supported Formats | | Table 4-9: Bitblt with Expansion Supported Formats | | Table 4-10: Contents of the Command Area | | Table 4-11: Contents of the Read Data Area | | Table 4-12: Supported Functionality for each Interrupt Source | | Chapter 5: Hardware Designer's Notes | | Table 5-1: Supported SGRAM/SDRAM Commands | | Table 5-2: Slice Address Decoded5-5 | | Table 5-3: 2 bank (memconfig<2:0> = '000'), | | 16Mb (x16) and 32 (x32) device address mapping | | Table 5-4: 2 bank (memconfig<2:0> = '001'), 16Mb (x32) device address mapping 5-6 | | Table 5-5: 4 bank (memconfig<2:0> = '010'), 16Mb (x32) device address mapping 5-6 | | Table 5-6: 4 bank (memconfig<2:0> = '011'), 64Mb (x32) device address mapping 5-6 | | Table 5-7: 4 bank (memconfig<2:0> = '100'), 32Mb (x32) device address mapping 5-6 | | Table 5-8: 2 bank (memconfig<2:0> = '101'), 64Mb (x32) device address mapping 5-7 | # **Chapter A: Technical Information** | Table A-1: Pin Count Summary Matrox G400 (Rev. 0) | A-2 | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------| | Table A-2: Pin Count Summary Matrox G400 (Rev. 1) | A-2 | | Table A-3: AGP Pinout Legend (Top View) | A-9 | | Table A-4: Absolute Maximum Ratings | A-10 | | Table A-5: Recommended Operating Conditions | A-11 | | Table A-6: DC Characteristics | | | $ (VDD3 = 3.3 \pm 0.3 \text{V}, VDD2.5 = 2.5 \pm 0.2 \text{V}, VDDq = 3.3 \pm 0.15 \text{V}, TA = 0^{\circ} \text{ to } 55^{\circ}) (AGP 3.3) \\ (VDD3 = 3.3 \pm 0.3 \text{V}, VDD2.5 = 2.5 \pm 0.2 \text{V}, VDDq = 1.5 \pm 0.075 \text{V}, TA = 0^{\circ} \text{ to } 55^{\circ}) (AGP 1.5) \ . $ | A-12 | | Table A-7: Buffer Type and Pin Load (Part 1 of 2) | A-15 | | Table A-8: RAMDAC Parameter List | A-17 | | Table A-9: PLL Parameter List | A-17 | | Table A-10: AGP 1X Timing | A-19 | | Table A-11: AGP 2X Timing | A-20 | | Table A-12: AGP 4X Timing | A-21 | | Table A-13: Serial EEPROM Clock Period Cycle | A-22 | | Table A-14: Serial EEPROM Parameter List | A-22 | | Table A-15: MAFC Waveform data information | A-25 | | Table A-16: Memory Interface Parameter List | A-28 | | Table A-17: Matrox G400 Sync. RAM Clock-Based Parameter Table | A-35 | | Table A-18: Codec Parameters | A-39 | | Table A-19: Video In Parameters | A-40 | | Table A-20: Rev. A Nand Tree | A-44 | | Table A-21: Rev. B and later Nand Tree - 1 | A-48 | | Table A-22: Rev. B and later Nand Tree - 2 | A-50 | # **Chapter B: Changes** Not Applicable # Chapter 1: MGA Overview | Introduction | 1-2 | |--------------------------------|-----| | System Block Diagram | 1-3 | | Chip Specifications | 1-4 | | Typographical Conventions Used | 1-9 | | Locating Information | 1-9 | #### 1.1 Introduction The 256-bit DualBus Matrox G400 is a continuation of Matrox's expertise to deliver "Uncompromisingly High Performance in all Areas", as demonstrated by the award winning MGA-G200 Series of products. Implemented in an advanced 0.25-micron, five-layer metal, high performance process, the Matrox G400 exceeds the performance, image quality and multimedia capabilities of the MGA-G200 in every way. The Matrox G400 is one of the first full AGP 4X capable graphics controller to hit the marketplace. It has been conceived with AGP 4X in mind and is the only device created to fully utilize over 1GB/sec of AGP bandwidth with it's unique Multi-threaded Bus Mastering capability. The Matrox G400 achieves up to three times the 3D rendering performance of the award winning MGA-G200 in real applications at high resolution via a new Rendering Array Process (RAP) architecture. RAP is a technique used to maximize parallelism during 3D setup and 3D rendering allowing the chip to perform single cycle multi-texturing as well as setup multiple triangles in parallel. The Matrox G400 provides industry leading 3D performance levels at the absolute highest image quality. It targets the high-performance mainstream and entry-level 3D professional workstation markets. Innovative new features including true environment mapped bump mapping, single cycle multi-texturing, DualHead Display and Motion Video Rendering differentiate the Matrox G400 from all competition. Following the tradition of no compromise quality in 3D rendering, the Matrox G400 builds upon the outstanding Vibrant Color Quality 3D rendering architecture of the G200 chip by offering Vibrant Color Quality2 (VCQ2), the foundation of which is the placement of full precision in all blending units inside the chip to ensure that multi-textured polygons remain as vibrant as single textured polygons. With support for up to 32MB of SDRAM or SGRAM, the Matrox G400 supports 3D resolution up to 2056x1536 in 16.7 million colors including 8-bits of destination alpha, triple-buffered, a 24-bit Z-buffer and an 8-bit stencil buffer all while texturing out of AGP system memory. The Matrox G400 surpasses Matrox's reputation of engineering the fastest business acceleration solutions in the industry. The Matrox G400's integration of the 256-bit DualBus architecture into a proven, high performance 2D core clearly positions the chip as the world leader in graphics acceleration. The Matrox G400 series uses a high speed RAMDAC (up to 300 MHz) to eliminate screen flicker and produce the sharp and crystal clear displays. The high speed integrated Ramdac of the 256-bit DualBus Matrox G400 coupled with a full 128-bit bus to video memory compliments the most advanced monitors available in the high performance marketplace. The 2D performance of the Matrox G400 is to be by far the best in the world. For the last five years, Matrox has led the industry with a 64-bit interface between MGA graphics chips and memory subsystems, consistently outperforming competitors' 128-bit designs. By increasing the datapath to 128-bits, Matrox is doubling the speed of most 2D operations. The internal 2D architecture has been re-balanced to use this extra bandwidth, and the results are expected to "max out" the 2D benchmarks on the most powerful machines, at the highest resolutions, color depths and refresh rates. The Matrox G400 is able to playback DVD streams at extremely high picture quality at full frame rate while leaving a large portion of the CPU bandwidth available for other applications. This combined with the flexibility offered by DualHead display makes Matrox G400 the most versatile software DVD playback solution in the industry. Growing from Matrox's success with comprehensive video upgrade options, the Matrox G400 features a video input port, video CODEC port and video output port. Providing high performance interfaces for external Video Decoder, Video Encoder, hardware Motion-JPEG and hardware MPEG-2 CODECs makes the Matrox G400 the centerpiece of a fully multimedia upgradeable solution. The convergence of the PC, the TV and the Internet sees the graphics/multimedia subsystem as the essential enabler and multimedia connectivity is becoming a key feature for powerful graphics solution in today's market. The Matrox G400's architecture reflects Matrox's expertise in graphics and professional video markets and is the cornerstone of the most complete multimedia solution in the industry. #### 1.1.1 Supported Multimedia Features - Software DVD playback at full display resolution, - High-quality video encoder chip (MGA-TVO) - Support for HD0 Digital Television input and output, - Video input, output and CODEC port - Interface for Hardware video encode, decode, MJPEG and MPEG-2 CODECs - TV tuning - Second CRTC display output using DualHead Display The second CRTC of DualHead Display can drive a TV output, a second monitor, or a flat panel display, while the primary CRTC drives the high-resolution monitor. This capability meets the PC'99 System Design Guide's requirement so that "a second display controller can allow the PC in the den to drive its monitor at 75Hz for word processing, while at the same time displaying a DVD movie, or broadcast program, on the family room television at 60Hz". #### 1.2 System Block Diagram Figure 1-1: System Block Diagram Figure 1-2: Matrox G400 Block Diagram #### 1.3 Chip Specifications #### 1.3.1 Performance Characteristics and Key Features - 0.25-micron, five layer metal process technology - 256-bit DualBus architecture - True 128-bit external bus to frame buffer memory - A choice of 3.3V (AGP 1X, AGP 2X) or 1.5V (AGP 1X, AGP 2X, AGP 4X) in a single device - 3D Rendering Array Process (RAP) architecture - 8MB to 32MB frame buffer configurations supported - Vibrant Color Quality 2 (VCQ2) Rendering - 32-bit internal precision specially enhanced for multi-texturing using 32-bit source textures - 32-bit Z-buffer including 8-bit stencil buffer - Symmetric Rendering Architecture - Matrox DualHead Display technology enables multiple displays within a single AGP card: - monitor / monitor - monitor / TV - monitor / flat panel display (with Matrox flat panel configurations only) - High speed integrated RAMDAC (up to 300MHz) with UltraSharp RAMDAC technology - Flicker-free display up to 2056 x 1536 @ 32bpp - Industry leading 3D feature set and performance - True DX-6 hardware bump-mapping - Bilinear, trilinear and anisotropic filtering - DirectX6, PC 98/99, Broadcast PC, DirectShow, OpenGL compatible #### 1.3.2 2D Drawing Engine - Benchmark-winning 2D performance optimized for true color operation at high resolution - UltraSharp RAMDAC technology for highest quality analog output - Full acceleration of all GDI and DirectDraw functions - Linear frame buffer - Programmable, transparent BLTter - Linear packed pixel frame buffer - 32-bit ultra-fast VGA core #### 1.3.3 3D Rendering Engine - Floating Point 3D Setup Engine with dynamically re-allocatable resources - Ultra-pipelined floating point and culling engines - 4KB of instruction cache - Optimized support for Direct3D and OpenGL triangles, strips, fans and vectors - Flexible Vertex Format natively supported - Vertex Buffers natively supported - 3D Rendering Array Process (RAP) architecture - Single Cycle Multi-texturing - True DX-6 Hardware Bump-mapping - Vertex and table fogging - Specular highlighting (any color) - True color RGB Flat and Gouraud shading - · Vibrant Color Quality 2 (VCQ2) Rendering - 32 bit precision internal rendering for single and multi-texturing - 32 bit source textures - 32 bit output - 16bpp dithering down from 32bpp palette for 16bpp output - Full Subpixel and subtexel correction - 8-bit precision for filter coefficients - Highly saturated & separated analog color output - Texturing support: - Texture sizes up to 2048x2048 - All texture formats are supported - Perspective Correct Texture Mapping - Texturing from local and AGP memory - Single Cycle Multi-texturing - Opaque Texture Surfaces - Alpha in Texture Palettes - 11 level mip-mapping support - Texture transparency - Unique Motion Video Rendering Architecture - Native support for non-power of 2 textures - Allows support of 16:9 aspect ratio to be preserved when textures mapping video streams - Mip-map non-power of 2 textures - Multiple YCbCr source texture formats for Video Stream Texture Mapping - Full subpicture blended DVD as texture source - Filtering support: - Bilinear filtering - True eight-sample per pixel trilinear filtering - Anisotropic filtering - Alpha blending: - All blend modes under DirectX6 and OpenGL - Supports all permutations of passes including light maps, environment maps, reflection maps, etc. - Z-buffer support: - 16-bit - 32-bit - 24-bit plus 8-bit stencil buffer used for shadows, overlays, special rendering effects - Guard Band Clipping - Single, Double or Triple buffering - 3D-image effects combined with no exclusion conditions - Hardware dithering including dithering of LUT textures #### 1.3.4 Video and Multimedia Features - Planar YCbCr support - Multiple YCbCr pixel formats - Independent front end and back end scalars - Independent X and Y scaling with high quality 12-tap scaling filter, comprised of 4 taps horizontally and 3 taps vertically to produce the best quality images - Full hardware subpicture support and blending for high quality DVD playback - Aspect ratio conversion supported for proper display of 4:3 and 16:9 contents - Full screen output to TV independent of Primary RGB display - AGP 4X bus mastering of video data - · Support for unlimited number of simultaneous video windows and sprites - Parallelized video input port, video CODEC port and video output port - HD0 format support for HDTV - (720p or 1280x720 resolution) as video input and output - Second CRTC of DualHead Display supports RGB and YCbCr packed and planar data in interlaced and non-interlaced rasters for PC graphics and video display to a TV or a monitor - Connectivity to high quality MGA-TVO video encoder chip - Supports output to TV up to 1024x768 @ 32 bpp - Software controllable flicker filter, up to 6 lines - Underscan and overscan capabilities - Video editing architecture enables real-time A/B roll capability - Back-end scaler supports overlay modes at high resolution - Enhanced alpha blended overlay modes to support DVD-Video subpicture information as well as WebTV User Interfaces - Additional independent and resizable overlay for support of picture-in-picture and multiple video conferencing windows - Widest range of multimedia add-ons in the industry - Full WDM support for video capture - Full Microsoft DirectShow and Broadcast PC compliant **Optional Display (only one) Primary Display** Flat Panel Television Color Monitor High Resolution Color Monitor NTSC / PAL Up to 1280 x Up to 1280 x **SECAM** 1024 at 1024 at 32 bpp 32 bpp Up to 2056 x 1536 at 32bpp MGA-TVO MGA-TVO PanelLink **Multimedia Options** RAMDAC MAFC Port VIP / VMI Port DVD CODEC Primary CRTC **CODEC** Port Second CRTC Video Programmable Ultra-pipelined Scaling Units Floating Point setup Engine CSC Advanced 3D Texturing and Rendering Engine 2D Engine 32bit VGA **HOST BUS** 128-bit Frame Buffer Memory Interface AGP 2x / 4x Interface **AGP SYSTEM MEMORY** 8-, 16- or 32MByte Local Frame Buffer \* The MGA-TVO supports monitor resolutions up to 1024x768. The MGA-TVO can also act as an external RAMDAC, and can support up to 1280x1024 Figure 1-3: Matrox G400 DualHead Display ## 1.4 Typographical Conventions Used Table 1-1: Typographical Conventions | Description | Example | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------| | Active low signals are indicated by a trailing forward slash. Signal names appear in upper-case characters. | VHSYNC/ | | Numbered signals appear within angle brackets, separated by a colon. | MA<8:0> | | Register names are indicated by upper-case bold sans-serif letters. | DEVID | | Fields within registers are indicated by lower-case bold sans-serif letters. | vendor | | Bits within a field appear within angle brackets, separated by a colon. | vendor<15:0> | | Hexadecimal values are indicated by a trailing letter 'h'. | CFFFh | | Binary values are indicated by a trailing letter 'b' or are enclosed in single quotes, as: '00' or '1'. In a bulleted list within a register description field, 0: and 1: are assumed to be binary. | 0000 0010Ь | | Special conventions are used for the register descriptions. Refer to the sample rein Sections 3.1.1, 3.2.1, and 3.3.1. | gister description pages | | In a table, X = "don't care" (the value doesn't matter) | 1X = Register Set C | | Emphasized text and table column titles are set in bold italics. | This bit <i>must be set</i> . | | In the <b>DWGCTL</b> illustrations (in Chapter 4), the '+' and '#' symbols have a special meaning. This is explained in 'Programmer's Specification' on page 4-1. | trans | #### 1.5 Locating Information The Matrox $G400^{(1)}$ register descriptions are located in Chapter 3. These descriptions are divided into several sections, and arranged in alphabetical order within each section. - To find a register by name (when you know which section it's in): go to the section and search the names at the top of each page for the register you want. - To find a register by its index or address, refer to the tables in Chapter 2. Indirect access register indexes are duplicated on the description page of the direct access register that they refer to. - To find a particular field within a register, search in the Alphabetical List of Register Fields at the back of the manual. Information on how to program the Matrox G400 registers is located in Chapter 4. Hardware design information is located in Chapter 5. Appendix A contains pinout, timing, and other general information. At the beginning of this manual you will find a complete Table of Contents, a List of (major) Figures, and a List of (major) Tables. <sup>(1)</sup> Note: Matrox G400 is implied with all references made to MGA-G400 or MGA. # Chapter 2: Resource Mapping | Memory Mapping | <mark>2-2</mark> | |-----------------------------|------------------| | Configuration Space Mapping | 2-2 | | MGA General Map | | | MGA Control Aperture | <mark>2-4</mark> | | Register Mapping | 2-5 | ### 2.1 Memory Mapping •• *Note:* All addresses and bits within dwords are labelled for a Little-Endian processor (X86 series, for example). #### 2.1.1 Configuration Space Mapping Table 2-1: Matrox G400 Configuration Space Mapping | Address | Name/Note | Description | |---------|--------------------------|---------------------------------------------------------------| | 00h-03h | DEVID | Device Identification | | 04h-07h | DEVCTRL | Device Control | | 08h-0Bh | CLASS | Class Code | | 0Ch-0Fh | HEADER | Header | | 10h-13h | MGABASE2 | MGA Frame Buffer Aperture Address | | 14h-17h | MGABASE1 | MGA Control Aperture Base | | 18h-1Bh | MGABASE3 | MGA ILOAD Aperture Base Address | | 1Ch-2Bh | Reserved (1) | _ | | 2Ch-2Fh | SUBSYSID | Location for reading the Subsystem ID. | | 30h-33h | ROMBASE | Writing has no effect. ROM Base Address | | 34h-37h | | 2 200 2 0 0 | | | CAP_PTR Reserved (1) | Capabilities Pointer | | 38h-3Bh | INTCTRL | — | | 3Ch-3Fh | _ | Interrupt Control | | 40h-43h | OPTION | Option register number 1 | | 44h-47h | MGA_INDEX <sup>(2)</sup> | MGA Indirect Access Index | | 48h-4Bh | MGA_DATA <sup>(2)</sup> | MGA Indirect Access Data | | 4Ch-4Fh | SUBSYSID | Location for writing the Subsystem ID. Reading will give 0's. | | 50h-53h | OPTION2 | Option register number 2 | | 54h-57h | OPTION3 | Option register number 3 | | 58h-DBh | Reserved (1) | _ | | DCh-DFh | PM_IDENT | Power Management Identifier | | E0h-E3h | PM_CSR | Power Management Control / Status | | E4h-EFh | Reserved (1) | _ | | F0h-F3h | AGP_IDENT (3) | AGP Capability Identifier | | F4h-F7h | AGP_STS (3) | AGP Status | | F8h-FBh | AGP_CMD (3) | AGP Command | | FCh-FFh | Reserved (1) | <u> </u> | <sup>(1)</sup> Writing to a reserved location has no effect. Reading from a reserved location will give '0's. Access to any location (including a reserved one) will be decoded. <sup>&</sup>lt;sup>(2)</sup> Not supported when powerpc is '1'. Reading to these locations will return unknown values; writing to these locations may modify any register described in the MGABASE1 range. <sup>(3)</sup> These locations exist only for the MGA-G400-AGP. These locations are reserved and will return '0' when read. #### 2.1.2 MGA General Map Table 2-2: MGA General Map | Address | Condition | Name/Notes | |----------------------------|--------------------------------------------------|--------------------------------------------------| | 000A0000h-000BFFFFh | <b>GCTL6</b> <3:2> = '00', <b>MISC</b> <1> = '1' | VGA frame buffer (1)(2) | | 000A0000h-000AFFFFh | GCTL6<3:2> = '01', MISC<1> = '1' | (Note 2 applies <b>only</b> if<br>MGAMODE = '1') | | 000B0000h-000B7FFFh | <b>GCTL6</b> <3:2> = '10', <b>MISC</b> <1> = '1' | | | 000B8000h-000BFFFFh | <b>GCTL6</b> <3:2> = '11', <b>MISC</b> <1> = '1' | | | ROMBASE + 0000h to | <b>biosen</b> = 1 (see <b>OPTION</b> ) and | BIOS EPROM (1) | | ROMBASE + FFFFh | romen = 1 (see ROMBASE) | | | <b>MGABASE1</b> + 0000h to | MGA control aperture | (1) | | MGABASE1 + 3FFFh | (see Table 2-3) | | | MGABASE2 + 000000h to | Direct frame buffer access aperture | (1)(2)(3) | | MGABASE2 + FFFFFFh | | | | MGABASE3 + 000000h to | 8 MByte Pseudo-DMA window | (1)(4)(5) | | MGABASE3 + 7FFFFFh | | | <sup>(1)</sup> Memory space accesses are decoded only if **memspace** = 1 (see the **DEVCTRL** configuration register). <sup>(2)</sup> Hardware swapping for Big-Endian support is performed in accordance with the settings of the **OPMODE** register's **dirDataSiz** bits. <sup>(3)</sup> The usable range depends on how much memory has been installed. Reading or writing outside the usable range will yield unpredictable results. <sup>(4)</sup> Hardware swapping for Big-Endian support is performed in accordance with the settings of the **OPMODE** register's **dmaDataSiz** bits. $<sup>^{(5)}</sup>$ This memory space is Write Only. Reads will return unknown values. #### 2.1.3 MGA Control Aperture Table 2-3: MGA Control Aperture (extension of Table 3-2) | MGABASE1 + | Attr. | Mnemonic | Device name | |-------------|-------|------------|------------------------------------------------------| | 0000h-1BFFh | W | DMAWIN | 7KByte Pseudo-DMA window (1)(4) | | 1C00h-1DFFh | W | DWGREG0 | First set of drawing registers (2)(3)(4) | | 1E00h-1EFFh | R/W | HSTREG | Host registers <sup>(2)(3)</sup> | | 1F00h-1FFFh | R/W | VGAREG | VGA registers (3)(5) | | 2000h-207Fh | R/W | WIMEMDATA | WARP instruction memory <sup>(2)(3)</sup> | | 2080h-20FFh | | _ | Reserved (6) | | 2100h-217Fh | R/W | WIMEMDATA1 | WARP instruction memory <sup>(2)(3)</sup> | | 2180h-2DFFh | W | DWGREG1 | Second set of drawing registers <sup>(2)(3)(4)</sup> | | 2E00h-3BFFh | _ | _ | Reserved <sup>(6)</sup> | | 3C00h-3C0Fh | R/W | DAC | RAMDAC registers <sup>(3)</sup> | | 3C10h-3C58h | R/W | CRTC2 | Second CRTC | | 3C60h-3CFFh | | _ | Reserved (6) | | 3D00h-3DFFh | R/W | BESREG | Backend Scaler register (2)(3) | | 3E00h-3EFFh | R/W | VINCODEC | Video-in and codec interface (2)(3) | | 3F00h-3FFFh | _ | _ | Reserved (6) | <sup>(1)</sup> Hardware swapping for Big-Endian support is performed in accordance with the settings of the **OPMODE** register's **dmaDataSiz** bits. <sup>(2)</sup> Hardware swapping for Big-Endian support is performed when the **OPTION** configuration register's **powerpc** bit is '1'. <sup>(3)</sup> See the register map in Table 2-4 for a more detailed view of this memory space. <sup>(4)</sup> Reads of these locations return *unknown* values (*except* for range 2C40 to 2C4F and 2CD0 to 2CD7). <sup>&</sup>lt;sup>(5)</sup> VGA registers have been memory mapped to provide access to the **CRTC** registers in order to program MGA video modes when the VGA I/O space is not enabled. <sup>(6)</sup> Reserved locations are decoded. The returned values are unknown. # 2.2 Register Mapping •• Note: For the values in Table 2-4, reserved locations should *not* be accessed. Writing to reserved locations may affect other registers. Reading from reserved locations will return *unknown* data. All footnote references can be found at the end of the table. Table 2-4: Register Map (Part 1 of 14) | | | Memory | I/O | | | | |---------------------------|--------|------------------------|-----------------|-------|------------------------------------|-------| | Register Mnemonic Name | Access | Address <sup>(1)</sup> | $Address^{(2)}$ | Index | Description/Comments | Page | | DWGCTL | WO | 1C00h | _ | 00h | Drawing Control | 3-132 | | MACCESS | WO | 1C04h | _ | 01h | Memory Access | 3-152 | | MCTLWTST | WO | 1C08h | _ | 02h | Memory Control Wait State | 3-154 | | ZORG | WO | 1C0Ch | _ | 03h | Z-Depth Origin | 3-286 | | PAT0 | WO | 1C10h | _ | 04h | Pattern | 3-161 | | PAT1 | WO | 1C14h | | 05h | Pattern | " | | _ | | 1C18h | _ | | Reserved | | | PLNWT | WO | 1C1Ch | | 07h | Plane Write Mask | 3-163 | | BCOL | WO | 1C20h | _ | 08h | Background Color / Blit Color Mask | 3-46 | | FCOL | WO | 1C24h | | 09h | Foreground Color / Blit Color Key | 3-140 | | _ | | 1C28h | | | Reserved | | | _ | | 1C2Ch | | 0Bh | Reserved (SRCBLT) | | | SRC0 | WO | 1C30h | _ | 0Ch | Source | 3-186 | | SRC1 | WO | 1C34h | | 0Dh | Source | " | | SRC2 | WO | 1C38h | _ | 0Eh | Source | ** | | SRC3 | WO | 1C3Ch | _ | 0Fh | Source | " | | XYSTRT (3) | WO | 1C40h | _ | 10h | XY Start Address | 3-281 | | XYEND (3) | WO | 1C44h | _ | 11h | XY End Address | 3-280 | | _ | 1C48 | 3h-1C4Fh | _ | | Reserved | | | SHIFT (3) | WO | 1C50h | _ | 14h | Funnel Shifter Control | 3-175 | | DMAPAD (3) | WO | 1C54h | _ | 15h | DMA Padding | 3-114 | | <b>SGN</b> <sup>(3)</sup> | WO | 1C58h | _ | 16h | Sign | 3-172 | | LEN (3) | WO | 1C5Ch | _ | 17h | Length | 3-151 | | AR0 (3) | WO | 1C60h | _ | 18h | Multi-Purpose Address 0 | 3-39 | | AR1 <sup>(3)</sup> | WO | 1C64h | _ | 19h | Multi-Purpose Address 1 | 3-40 | | AR2 (3) | WO | 1C68h | _ | 1Ah | Multi-Purpose Address 2 | 3-41 | | AR3 (3) | WO | 1C6Ch | _ | 1Bh | Multi-Purpose Address 3 | 3-42 | | AR4 <sup>(3)</sup> | WO | 1C70h | | 1Ch | Multi-Purpose Address 4 | 3-43 | | AR5 <sup>(3)</sup> | WO | 1C74h | _ | 1Dh | Multi-Purpose Address 5 | 3-44 | | AR6 (3) | WO | 1C78h | _ | 1Eh | Multi-Purpose Address 6 | 3-45 | | CXBNDRY (3) | WO | 1C80h | | 20h | Clipper X Boundary | 3-107 | | FXBNDRY (3) | WO | 1C84h | | 21h | X Address (Boundary) | 3-146 | Table 2-4: Register Map (Part 2 of 14) | | | Memory | I/O | | | | |------------------------|--------|-----------------|------------------------|-------|---------------------------------|-------| | Register Mnemonic Name | Access | $Address^{(1)}$ | Address <sup>(2)</sup> | Index | Description/Comments | Page | | YDSTLEN (3) | WO | 1C88h | _ | | Y Destination and Length | 3-284 | | PITCH (3) | WO | 1C8Ch | _ | 23h | Memory Pitch | 3-162 | | YDST | WO | 1C90h | _ | 24h | Y Address | 3-283 | | _ | | 1C94h | _ | _ | Reserved | _ | | <b>YTOP</b> (3) | WO | 1C98h | _ | 26h | Clipper Y Top Boundary | 3-285 | | <b>YBOT</b> (3) | WO | 1C9Ch | | 27h | Clipper Y Bottom Boundary | 3-282 | | CXLEFT (3) | WO | 1CA0h | | 28h | Clipper X Minimum Boundary | 3-108 | | CXRIGHT (3) | WO | 1CA4h | | 29h | Clipper X Maximum Boundary | 3-109 | | FXLEFT (3) | WO | 1CA8h | | 2Ah | X Address (Left) | 3-147 | | FXRIGHT (3) | WO | 1CACh | | 2Bh | X Address (Right) | 3-148 | | XDST (3) | WO | 1CB0h | _ | 2Ch | X Destination Address | 3-279 | | _ | 1CB4 | h-1CBFh | _ | _ | Reserved | _ | | DR0 | WO | 1CC0h | _ | 30h | Data ALU 0 | 3-118 | | FOGSTART | WO | 1CC4h | _ | 31h | Fog Start | 3-143 | | DR2 | WO | 1CC8h | | 32h | Data ALU 2 | 3-119 | | DR3 | WO | 1CCCh | | 33h | Data ALU 3 | 3-120 | | DR4 | WO | 1CD0h | | 34h | Data ALU 4 | 3-121 | | FOGXINC | WO | 1CD4h | | 35h | Fog X Inc | 3-144 | | DR6 | WO | 1CD8h | | 36h | Data ALU 6 | 3-122 | | DR7 | WO | 1CDCh | | 37h | Data ALU 7 | 3-123 | | DR8 | WO | 1CE0h | | 38h | Data ALU 8 | 3-124 | | FOGYINC | WO | 1CE4h | _ | 39h | Fog Y Inc | 3-145 | | DR10 | WO | 1CE8h | _ | 3Ah | Data ALU 10 | 3-125 | | DR11 | WO | 1CECh | _ | 3Bh | Data ALU 11 | 3-126 | | DR12 | WO | 1CF0h | | 3Ch | Data ALU 12 | 3-127 | | FOGCOL | WO | 1CF4h | | 3Dh | Fog Color | 3-142 | | DR14 | WO | 1CF8h | | 3Eh | Data ALU 14 | 3-128 | | DR15 | WO | 1CFCh | | 3Fh | Data ALU 15 | 3-129 | | _ | 1D00 | h-1DBFh | | (6) | Same mapping as 1C00h-1CBFh (4) | | | WIADDR | WO | 1DC0h | | 70h | WARP Instruction Address | 3-268 | | WFLAG | WO | 1DC4h | | 71h | WARP Flags | 3-263 | | WGETMSB | WO | 1DC8h | | 72h | WARP GetMSB Value | 3-267 | | WVRTXSZ | WO | 1DCCh | | 73h | WARP Vertex Size | 3-278 | | _ | _ | 1DD0h | | 74h | Reserved (WDBR) | | | WACCEPTSEQ | WO | 1DD4h | | 75 | WARP Accept Sequence | 3-260 | | WIADDR2 | WO | 1DD8h | | 76 | WARP Instruction Address 2 | 3-269 | Table 2-4: Register Map (Part 3 of 14) | | | Memory | I/O | | - | | |------------------------|--------|------------------------|------------------------|-------|--------------------------------------|-------| | Register Mnemonic Name | Access | Address <sup>(1)</sup> | Address <sup>(2)</sup> | Index | Description/Comments | Page | | WFLAG1 | WO | 1DE0h | | 78 | WARP Flags 1 | 3-264 | | WIADDRNB2 | WO | 1E00h | | | WARP Instruct. Add. (Non-Blocking) 2 | 3-272 | | WIADDRNB1 | RO | 1E04h | _ | | WARP Instruct. Add. (Non-Blocking) 1 | 3-271 | | WFLAGNB1 | R/W | 1E08h | _ | | WARP Flags (Non-Blocking) 1 | 3-266 | | TEST1 | R/W | 1E0Ch | _ | | Test1 | 3-207 | | FIFOSTATUS | RO | 1E10h | | | Bus FIFO Status | 3-141 | | STATUS | R/W | 1E14h | | _ | Status | 3-188 | | ICLEAR | WO | 1E18h | _ | | Interrupt Clear | 3-149 | | IEN | R/W | 1E1Ch | _ | _ | Interrupt Enable | 3-150 | | VCOUNT | RO | 1E20h | _ | _ | Vertical Count | 3-242 | | DMAMAP30 | R/W | 1E30h | _ | | DMA Map 3h to 0h | 3-110 | | DMAMAP74 | R/W | 1E34h | | _ | DMA Map 7h to 4h | 3-111 | | DMAMAPB8 | R/W | 1E38h | | _ | DMA Map Bh to 8h | 3-112 | | DMAMAPFC | R/W | 1E3Ch | | _ | DMA Map Fh to Ch | 3-113 | | RST | R/W | 1E40h | | | Reset | 3-167 | | MEMRDBK | R/W | 1E44h | | | Memory Read Back | 3-157 | | TEST0 | R/W | 1E48h | | | Test0 | 3-204 | | CFG_OR | R/W | 1E4Ch | _ | | Configuration Override | 3-99 | | PRIMPTR | R/W | 1E50h | _ | | Primary List Status Fetch Pointer | 3-166 | | OPMODE | R/W | 1E54h | _ | | Operating Mode | 3-159 | | PRIMADDRESS | R/W | 1E58h | _ | | Primary DMA Current Address | 3-164 | | PRIMEND | R/W | 1E5Ch | _ | _ | Primary DMA End Address | 3-165 | | WIADDRNB | R/W | 1E60h | _ | _ | WARP Instruct. Add. (Non-Blocking) | 3-270 | | WFLAGNB | R/W | 1E64h | _ | | WARP Flags (Non-Blocking) | 3-265 | | WIMEMADDR | WO | 1E68h | _ | | WARP Instruction Memory Address | 3-273 | | WCODEADDR | RO | 1E6Ch | _ | | WARP Microcode Address | 3-262 | | WMISC | R/W | 1E70h | _ | | WARP Miscellaneous | 3-276 | | _ | 1E7C | Ch - 1E7Fh | _ | | Reserved | _ | | DWG_INDIR_WT<0> | WO | 1E80h | _ | | Drawing Register Indirect Write 0 | 3-131 | | ••• | | 1E84h- | -1EB8h | | | | | DWG_INDIR_WT<15> | WO | 1EBCh | _ | | Drawing Register Indirect Write 15 | 3-131 | | _ | 1EC0 | h - 1FBFh | | _ | Reserved | | | ATTR (Index) | R/W | 1FC0h | 3C0h | | Attribute Controller | 3-289 | | ATTR (Data) | WO | 1FC0h | 3C0h | | Attribute Controller | " | | ATTR (Data) | RO | 1FC1h | 3C1h | | Attribute Controller | " | | _ | _ | 1FC1h | 3C1h | | Reserved | | Table 2-4: Register Map (Part 4 of 14) | | | Memory | I/O | | | | |------------------------|--------|-----------------|---------------------|-------|------------------------------------|-------| | Register Mnemonic Name | Access | $Address^{(1)}$ | $Address^{(2)}$ | Index | Description/Comments | Page | | ATTR0 | R/W | _ | _ | 00h | Palette entry 0 | 3-289 | | ATTR1 | R/W | _ | _ | 01h | Palette entry 1 | " | | ATTR2 | R/W | _ | _ | 02h | Palette entry 2 | " | | ATTR3 | R/W | _ | _ | 03h | Palette entry 3 | " | | ATTR4 | R/W | _ | _ | 04h | Palette entry 4 | " | | ATTR5 | R/W | | | 05h | Palette entry 5 | " | | ATTR6 | R/W | | | 06h | Palette entry 6 | " | | ATTR7 | R/W | _ | _ | 07h | Palette entry 7 | " | | ATTR8 | R/W | _ | _ | 08h | Palette entry 8 | " | | ATTR9 | R/W | | _ | 09h | Palette entry 9 | " | | ATTRA | R/W | _ | _ | 0Ah | Palette entry A | " | | ATTRB | R/W | | _ | 0Bh | Palette entry B | " | | ATTRC | R/W | _ | _ | 0Ch | Palette entry C | " | | ATTRD | R/W | _ | _ | 0Dh | Palette entry D | " | | ATTRE | R/W | _ | _ | 0Eh | Palette entry E | " | | ATTRF | R/W | | _ | 0Fh | Palette entry F | " | | ATTR10 | R/W | | _ | 10h | Attribute Mode Control | 3-292 | | ATTR11 | R/W | _ | | 11h | Overscan Color | 3-294 | | ATTR12 | R/W | | | 12h | Color Plane Enable | 3-295 | | ATTR13 | R/W | | | 13h | Horizontal Pel Panning | 3-296 | | ATTR14 | R/W | | | 14h | Color Select | 3-297 | | _ | | _ | _ | | 15h-1Fh: Reserved | | | INSTS0 | RO | 1FC2h | 3C2h | _ | Input Status 0 | 3-356 | | MISC | WO | 1FC2h | 3C2h | _ | Miscellaneous Output | 3-358 | | _ | R/W | 1FC3h | 3C3h <sup>(5)</sup> | _ | Reserved, not decoded for I/O | | | SEQ (Index) | R/W | 1FC4h | 3C4h | _ | Sequencer | 3-360 | | SEQ (Data) | R/W | 1FC5h | 3C5h | _ | Sequencer | _ | | SEQ0 | R/W | | | 00h | SEQ0 | 3-361 | | SEQ1 | R/W | _ | _ | 01h | Clocking Mode | 3-362 | | SEQ2 | R/W | _ | _ | 02h | Map Mask | 3-363 | | SEQ3 | R/W | | | 03h | Character Map Select | 3-364 | | SEQ4 | R/W | _ | _ | 04h | Memory Mode | 3-365 | | _ | R/W | _ | _ | | 05h - 07h: Reserved | | | | | 1FC6h | _ | | Reserved | | | DACSTAT | RO | 1FC7h | 3C7h | | DAC Status(requires a byte access) | 3-343 | | | WO | 1FC7h | | _ | Reserved | | Table 2-4: Register Map (Part 5 of 14) | | | Memory | I/O | | | | |------------------------|--------|------------------------|------------------------|-------|------------------------------------------|-------| | Register Mnemonic Name | Access | Address <sup>(1)</sup> | Address <sup>(2)</sup> | Index | Description/Comments | Page | | | 1FC8 | 3h-1FC9h | _ | _ | Reserved | _ | | FEAT | RO | 1FCAh | 3CAh | | Feature Control | 3-344 | | _ | WO | 1FCAh | 3CAh | | Reserved | _ | | _ | | 1FCBh | 3CBh <sup>(5)</sup> | | Reserved, not decoded for I/O | _ | | MISC | RO | 1FCCh | 3CCh | | Miscellaneous Output | 3-358 | | | WO | 1FCCh | 3CCh | _ | Reserved | _ | | | _ | 1FCDh | 3CDh <sup>(5)</sup> | | Reserved, not decoded for I/O | _ | | GCTL (Index) | R/W | 1FCEh | 3CEh | | Graphics Controller | 3-345 | | GCTL (Data) | R/W | 1FCFh | 3CFh | | Graphics Controller | " | | GCTL0 | R/W | _ | _ | 00h | Set/Reset | 3-346 | | GCTL1 | R/W | _ | _ | 01h | Enable Set/Reset | 3-347 | | GCTL2 | R/W | _ | _ | 02h | Color Compare | 3-348 | | GCTL3 | R/W | | _ | 03h | Data Rotate | 3-349 | | GCTL4 | R/W | _ | _ | 04h | Read Map Select | 3-350 | | GCTL5 | R/W | _ | _ | 05h | Graphics Mode | 3-351 | | GCTL6 | R/W | | _ | 06h | Miscellaneous | 3-353 | | GCTL7 | R/W | | _ | 07h | Color Don't Care | 3-354 | | GCTL8 | R/W | | _ | 08h | Bit Mask | 3-355 | | | _ | _ | _ | 09h - | 0Fh: Reserved | _ | | _ | 1FD0 | h-1FD3h | _ | _ | Reserved | _ | | CRTC (Index) | R/W | 1FD4h | 3D4h | _ | CRTC Registers (or 3B4h <sup>(6)</sup> ) | 3-299 | | CRTC (Data) | R/W | 1FD5h | 3D5h | | CRTC Registers (or 3B5h <sup>(6)</sup> ) | 11 | | CRTC0 | R/W | _ | _ | 00h | Horizontal Total | 3-301 | | CRTC1 | R/W | _ | _ | 01h | Horizontal Display Enable End | 3-302 | | CRTC2 | R/W | _ | _ | 02h | Start Horizontal Blanking | 3-303 | | CRTC3 | R/W | _ | _ | 03h | End Horizontal Blanking | 3-304 | | CRTC4 | R/W | _ | _ | 04h | Start Horizontal Retrace Pulse | 3-305 | | CRTC5 | R/W | _ | _ | 05h | End Horizontal Retrace | 3-306 | | CRTC6 | R/W | _ | _ | 06h | Vertical Total | 3-307 | | CRTC7 | R/W | | _ | 07h | Overflow | 3-308 | | CRTC8 | R/W | | | 08h | Preset Row Scan | 3-309 | | CRTC9 | R/W | | | 09h | Maximum Scan Line | 3-310 | | CRTCA | R/W | | | 0Ah | Cursor Start | 3-311 | | CRTCB | R/W | | | 0Bh | Cursor End | 3-312 | | CRTCC | R/W | | | 0Ch | Start Address High | 3-313 | | CRTCD | R/W | | | 0Dh | Start Address Low | 3-314 | Table 2-4: Register Map (Part 6 of 14) | | | Memory | I/O | | | | |------------------------|--------|-----------------|------------------------|-------|---------------------------------------------------------|-------| | Register Mnemonic Name | Access | $Address^{(1)}$ | Address <sup>(2)</sup> | Index | Description/Comments | Page | | CRTCE | R/W | _ | _ | | Cursor Location High | 3-315 | | CRTCF | R/W | _ | _ | 0Fh | Cursor Location Low | 3-316 | | CRTC10 | R/W | _ | | 10h | Vertical Retrace Start | 3-317 | | CRTC11 | R/W | _ | _ | 11h | Vertical Retrace End | 3-318 | | CRTC12 | R/W | _ | | 12h | Vertical Display Enable End | 3-319 | | CRTC13 | R/W | | | 13h | Offset | 3-320 | | CRTC14 | R/W | _ | _ | 14h | Underline Location | 3-321 | | CRTC15 | R/W | _ | _ | 15h | Start Vertical Blank | 3-322 | | CRTC16 | R/W | | _ | 16h | End Vertical Blank | 3-323 | | CRTC17 | R/W | _ | _ | 17h | CRTC Mode Control | 3-324 | | CRTC18 | R/W | _ | _ | 18h | Line Compare | 3-328 | | | | _ | _ | 19h - | 21h: Reserved | _ | | CRTC22 | R/W | | _ | 22h | CPU Read Latch | 3-329 | | _ | _ | | _ | 23h | Reserved | _ | | CRTC24 | R/W | _ | _ | 24h | Attributes Address/Data Select | 3-330 | | | | _ | _ | 25h | Reserved | | | CRTC26 | R/W | _ | _ | 26h | Attributes Address | 3-331 | | _ | — | | | 27h - | 3Fh: Reserved | | | _ | — | 1FD6h | 3D6h <sup>(5)</sup> | _ | Reserved, not decoded for I/O (or $3B6h^{(6)}$ ) | _ | | _ | _ | 1FD7h | 3D7h <sup>(5)</sup> | | Reserved, not decoded for I/O (or 3B7h <sup>(6)</sup> ) | _ | | _ | 1FD8 | 8h-1FD9h | _ | | Reserved | | | INSTS1 | RO | 1FDAh | 3DAh | | Input Status 1 (or 3BAh <sup>(6)</sup> ) | 3-357 | | FEAT | WO | 1FDAh | 3DAh | | Feature Control (or 3BAh <sup>(6)</sup> ) | 3-344 | | _ | — | 1FDBh | 3DBh <sup>(5)</sup> | _ | Reserved, not decoded for I/O (or 3BBh <sup>(6)</sup> ) | | | _ | 1FDC | h-1FDDh | _ | | Reserved | _ | | CRTCEXT (Index) | R/W | 1FDEh | 3DEh | | CRTC Extension | 3-332 | | CRTCEXT (Data) | R/W | 1FDFh | 3DFh | | CRTC Extension | " | | CRTCEXT0 | R/W | | | 00h | Address Generator Extensions | 3-333 | | CRTCEXT1 | R/W | | | 01h | Horizontal Counter Extensions | 3-334 | | CRTCEXT2 | R/W | _ | _ | 02h | Vertical Counter Extensions | 3-335 | | CRTCEXT3 | R/W | _ | _ | 03h | Miscellaneous | 3-336 | | CRTCEXT4 | R/W | _ | | 04h | Memory Page | 3-338 | | CRTCEXT5 | R/W | | | 05h | Horizontal Video Half Count | 3-339 | | CRTCEXT6 | R/W | _ | | 06h | Priority Request Control | 3-340 | Table 2-4: Register Map (Part 7 of 14) | | | Memory | I/O | | | | |------------------------|--------|------------------------|------------------------|-------|----------------------------------------------|-------| | Register Mnemonic Name | Access | Address <sup>(1)</sup> | Address <sup>(2)</sup> | Index | Description/Comments | Page | | CRTCEXT7 | R/W | _ | _ | 07h | Requester Control | 3-341 | | CRTCEXT8 | R/W | _ | _ | 08h | Address Extension | 3-342 | | _ | 1FE0 | h - 1FFEh | | _ | Reserved | | | CACHEFLUSH | R/W | 1FFFh | | | Cache Flush | 3-298 | | WIMEMDATA | R/W | 2000h | -207Fh | | WARP Instruction Memory Data | 3-274 | | _ | 2080 | h-20FFh | _ | | Reserved | | | WIMEMDATA1 | R/W | 2100h | -217Fh | _ | WARP Instruction Memory Data 1 | 3-275 | | _ | 2180 | h-2BFFh | _ | | Reserved | | | TMR0 | WO | 2C00h | _ | 80h | Texture Mapping ALU 0 | 3-230 | | TMR1 | WO | 2C04h | | 81h | Texture Mapping ALU 1 | 3-231 | | TMR2 | WO | 2C08h | | 82h | Texture Mapping ALU 2 | 3-232 | | TMR3 | WO | 2C0Ch | _ | 83h | Texture Mapping ALU 3 | 3-233 | | TMR4 | WO | 2C10h | _ | 84h | Texture Mapping ALU 4 | 3-234 | | TMR5 | WO | 2C14h | _ | 85h | Texture Mapping ALU 5 | 3-235 | | TMR6 | WO | 2C18h | _ | 86h | Texture Mapping ALU 6 | 3-236 | | TMR7 | WO | 2C1Ch | _ | 87h | Texture Mapping ALU 7 | 3-237 | | TMR8 | WO | 2C20h | _ | 88h | Texture Mapping ALU 8 | 3-238 | | TEXORG | WO | 2C24h | | 89h | Texture Origin | 3-221 | | TEXWIDTH | WO | 2C28h | | 8Ah | Texture Width | 3-228 | | TEXHEIGHT | WO | 2C2Ch | | 8Bh | Texture Height | 3-219 | | TEXCTL | WO | 2C30h | | 8Ch | Texture Map Control | 3-210 | | TEXTRANS | WO | 2C34h | | 8Dh | Texture Transparency | 3-226 | | TEXTRANSHIGH | WO | 2C38h | | 8Eh | Texture Transparency | 3-227 | | TEXCTL2 | WO | 2C3Ch | | 8Fh | Texture Map Control 2 | 3-215 | | SECADDRESS | R/W | 2C40h | | 90h | Secondary DMA Current Address <sup>(7)</sup> | 3-168 | | SECEND | R/W | 2C44h | | 91h | Secondary DMA End Address (7) | 3-169 | | SOFTRAP | R/W | 2C48h | | 92h | Soft Trap Handle (7) | 3-176 | | DWGSYNC | R/W | 2C4Ch | | 93h | Drawing Synchronisation | 3-139 | | DR0_Z32 LSB | WO | 2C50h | | 94h | Extended Data ALU 0 | 3-115 | | DR0_Z32 MSB | WO | 2C54h | | 95h | Extended Data ALU 0 | " | | TEXFILTER | WO | 2C58h | | 96h | Texture Filtering | 3-217 | | TEXBORDERCOL | WO | 2C5Ch | | 97h | Texture Border Color | 3-209 | | DR2_Z32 LSB | WO | 2C60h | | 98h | Extended Data ALU 2 | 3-116 | | DR2_Z32 MSB | WO | 2C64h | | 99h | Extended Data ALU 2 | " | | DR3_Z32 LSB | WO | 2C68h | | 9Ah | Extended Data ALU 3 | 3-117 | | DR3_Z32 MSB | WO | 2C6Ch | | 9Bh | Extended Data ALU 3 | ** | Table 2-4: Register Map (Part 8 of 14) | | | Memory | I/O | | | | |------------------------|--------|-----------------|------------------------|-------|-------------------------------|-------| | Register Mnemonic Name | Access | $Address^{(1)}$ | Address <sup>(2)</sup> | Index | Description/Comments | Page | | ALPHASTART | WO | 2C70h | _ | | Alpha Start | 3-36 | | ALPHAXINC | WO | 2C74h | _ | | Alpha X Inc | 3-37 | | ALPHAYINC | WO | 2C78h | _ | 9Eh | Alpha Y Inc | 3-38 | | ALPHACTRL | WO | 2C7Ch | _ | 9Fh | Alpha CTRL | 3-33 | | SPECRSTART | WO | 2C80h | | A0h | Specular Lighting Red Start | 3-183 | | SPECRXINC | WO | 2C84h | _ | A1h | Specular Lighting Red X Inc | 3-184 | | SPECRYINC | WO | 2C88h | _ | A2h | Specular Lighting Red Y Inc | 3-185 | | SPECGSTART | WO | 2C8Ch | _ | A3h | Specular Lighting Green Start | 3-180 | | SPECGXINC | WO | 2C90h | _ | A4h | Specular Lighting Green X Inc | 3-181 | | SPECGYINC | WO | 2C94h | _ | A5h | Specular Lighting Green Y Inc | 3-182 | | SPECBSTART | WO | 2C98h | _ | A6h | Specular Lighting Blue Start | 3-177 | | SPECBXINC | WO | 2C9Ch | | A7h | Specular Lighting Blue X Inc | 3-178 | | SPECBYINC | WO | 2CA0h | | A8h | Specular Lighting Blue Y Inc | 3-179 | | TEXORG1 | WO | 2CA4h | | A9h | Texture Origin 1 | 3-222 | | TEXORG2 | WO | 2CA8h | | AAh | Texture Origin 2 | 3-223 | | TEXORG3 | WO | 2CACh | _ | ABh | Texture Origin 3 | 3-224 | | TEXORG4 | WO | 2CB0h | | ACh | Texture Origin 4 | 3-225 | | SRCORG | WO | 2CB4h | _ | ADh | Source Origin | 3-187 | | DSTORG | WO | 2CB8h | _ | AEh | Destination Origin | 3-130 | | _ | _ | 2CBCh | - 2CC4h | _ | Reserved | | | STENCIL | WO | 2CC8h | | B2h | Stencil | 3-191 | | STENCILCTL | WO | 2CCCh | _ | B3h | Stencil Control | 3-192 | | SETUPADDRESS | R/W | 2CD0h | _ | B4h | Setup DMA Current Address (7) | 3-170 | | SETUPEND | R/W | 2CD4h | | B5h | Setup DMA End Address (7) | 3-171 | | _ | 2CD8 | h - 2CECh | _ | _ | Reserved | | | TBUMPMAT | WO | 2CF0h | _ | BCh | Text. Bump Map Transform | 3-194 | | TBUMPFMT | WO | 2CF4h | | BDh | Text. Bump Map Format | 3-195 | | TDUALSTAGE0 | WO | 2CF8h | | BE | Texture Dual Stage 0 | 3-196 | | TDUALSTAGE1 | WO | 2CFCh | | BF | Texture Dual Stage 1 | 3-201 | | WR0 | WO | 2D00h | | C0h | WARP Register 0 | 3-277 | | WR1 | WO | 2D04h | | C1h | WARP Register 1 | " | | WR2 | WO | 2D08h | | C2h | WARP Register 2 | " | | | | | | | | | | WR63 | WO | 2DFCh | | FFh | WARP Register 63 | 3-277 | | _ | 2E00 | h-3BFFh | | | Reserved | | | PALWTADD | R/W | 3C00h | 3C8h | | Palette RAM Write Address | 3-371 | Table 2-4: Register Map (Part 9 of 14) | | | Maria | I/O | _ | | | |------------------------|--------|----------------------------------|------------------------|-------|----------------------------------|-------| | Register Mnemonic Name | Access | Memory<br>Address <sup>(1)</sup> | Address <sup>(2)</sup> | Index | Description/Comments | Page | | PALDATA | R/W | 3C01h | 3C9h | | Palette RAM Data | 3-369 | | PIXRDMSK | R/W | 3C02h | 3C6h | | Pixel Read Mask | 3-372 | | PALRDADD | R/W | 3C03h | 3C7h | | Palette RAM Read Address. This | 3-370 | | PALRUADU | IX/ VV | 300311 | 30/11 | | register is WO for I/O accesses. | 3-370 | | _ | 3C04 | h - 3C09h | | | Reserved | | | X_DATAREG | R/W | 3C0Ah | | | Indexed Data | 3-373 | | | | | — | 00h - | 03h: Reserved | | | XCURADDL | R/W | _ | _ | 04h | Cursor Base Address Low | 3-384 | | XCURADDH | R/W | | | 05h | Cursor Base Address High | 3-383 | | XCURCTRL | R/W | | | 06h | Cursor Control | 3-386 | | _ | _ | _ | _ | 07h | Reserved | _ | | XCURCOL0RED | R/W | | _ | 08h | Cursor Control 0 Red | 3-385 | | XCURCOL0GREEN | R/W | | | 09h | Cursor Control 0 Green | " | | XCURCOL0BLUE | R/W | | _ | 0Ah | Cursor Control 0 Blue | " | | _ | _ | _ | _ | 0Bh | Reserved | _ | | XCURCOL1RED | R/W | _ | _ | 0Ch | Cursor Control 1 Red | 3-385 | | XCURCOL1GREEN | R/W | _ | _ | 0Dh | Cursor Control 1 Green | 3-385 | | XCURCOL1BLUE | R/W | _ | _ | 0Eh | Cursor Control1 Blue | " | | _ | | _ | _ | 0Fh | Reserved | _ | | XCURCOL2RED | R/W | _ | _ | 10h | Cursor Control 2 Red | 3-385 | | XCURCOL2GREEN | R/W | _ | _ | 11h | Cursor Control 2 Green | " | | XCURCOL2BLUE | R/W | | _ | 12h | Cursor Control 2 Blue | " | | _ | _ | _ | _ | 13h - | 17h: Reserved | _ | | XVREFCTRL | R/W | _ | _ | 18h | Voltage Reference Control | 3-407 | | XMULCTRL | R/W | _ | _ | 19h | Multiplex Control | 3-395 | | XPIXCLKCTRL | R/W | _ | _ | 1Ah | Pixel Clock Control | 3-397 | | | _ | | _ | 1Bh | - 1Ch: Reserved | _ | | XGENCTRL | R/W | _ | _ | 1Dh | General Control | 3-388 | | XMISCCTRL | R/W | _ | _ | 1Eh | Miscellaneous Control | 3-393 | | XPANELMODE | R/W | _ | _ | 1Fh | Panel Mode | 3-396 | | XMAFCDEL | R/W | | _ | 20h | MAFC Delay | 3-392 | | _ | | _ | | 1 | · 29h: Reserved | | | XGENIOCTRL | R/W | | | | General Purpose I/O Control | 3-389 | | XGENIODATA | R/W | _ | | | General Purpose I/O Data | 3-390 | | XSYSPLLM | R/W | _ | _ | | SYSPLL M Value | 3-403 | | XSYSPLLN | R/W | _ | | | SYSPLL N Value | 3-404 | | XSYSPLLP | R/W | | | | SYSPLL P Value | 3-405 | | | 14 11 | | | | DIDI THE | 5 105 | Table 2-4: Register Map (Part 10 of 14) | | | Memory | I/O | | | | |------------------------|--------|-----------------|-----------------|-------|-------------------------------|-------| | Register Mnemonic Name | Access | $Address^{(1)}$ | $Address^{(2)}$ | Index | Description/Comments | Page | | XSYSPLLSTAT | RO | | | 2Fh | SYSPLL Status | 3-406 | | _ | | | | 30h - | 37h: Reserved | | | XZOOMCTRL | R/W | | | 38h | Zoom Control | 3-408 | | _ | | | | 39h | Reserved | _ | | XSENSETEST | R/W | | | 3Ah | Sense Test | 3-402 | | _ | | _ | _ | 3Bh | Reserved | _ | | XCRCREML | RO | _ | _ | 3Ch | CRC Remainder Low | 3-382 | | XCRCREMH | RO | _ | _ | 3Dh | CRC Remainder High | 3-381 | | XCRCBITSEL | R/W | _ | _ | 3Eh | CRC Bit Select | 3-380 | | _ | _ | _ | _ | 3Fh | Reserved | _ | | XCOLMSK | R/W | _ | _ | 40h | Color Key Mask | 3-378 | | _ | | _ | _ | 41h | Reserved | | | XCOLKEY | R/W | | _ | 42h | Color Key | 3-376 | | _ | _ | _ | _ | 43h | Reserved | _ | | XPIXPLLAM | R/W | | _ | 44h | PIXPLL M Value Register Set A | 3-398 | | XPIXPLLAN | R/W | | _ | 45h | PIXPLL N Value Register Set A | 3-399 | | XPIXPLLAP | R/W | | _ | 46h | PIXPLL P Value Register Set A | 3-400 | | _ | | | | 47h | Reserved | | | XPIXPLLBM | R/W | _ | _ | 48h | PIXPLL M Value Register Set B | 3-398 | | XPIXPLLBN | R/W | _ | _ | 49h | PIXPLL N Value Register Set B | 3-399 | | XPIXPLLBP | R/W | | | 4Ah | PIXPLL P Value Register Set B | 3-400 | | _ | | | | 4Bh | Reserved | | | XPIXPLLCM | R/W | _ | | 4Ch | PIXPLL M Value Register Set C | 3-398 | | XPIXPLLCN | R/W | _ | | 4Dh | PIXPLL N Value Register Set C | 3-399 | | XPIXPLLCP | R/W | | | 4Eh | PIXPLL P Value Register Set C | 3-400 | | XPIXPLLSTAT | RO | | | 4Fh | PIXPLL Status | 3-401 | | _ | | | | 50h | Reserved | | | XKEYOPMODE | R/W | | | 51h | KEYING Operating Mode | 3-391 | | XCOLMSK0RED | R/W | | | 52h | Color Mask 0 Red | 3-379 | | XCOLMSK0GREEN | R/W | | | 53h | Color Mask 0 Green | " | | XCOLMSK0BLUE | R/W | | | 54h | Color Mask 0 Blue | " | | XCOLKEY0RED | R/W | | | 55h | Color Key 0 Red | 3-377 | | XCOLKEY0GREEN | R/W | | _ | 56h | Color Key 0 Blue | " | | XCOLKEY0BLUE | R/W | _ | | 57h | Color Key 0 Green | " | | _ | | | | 58h - | 5Fh: Reserved | | | XCURCOL3RED | R/W | _ | | 60h | Cursor Color 3 Red | 3-385 | Table 2-4: Register Map (Part 11 of 14) | | | Memory | I/O | | | | |------------------------|--------|------------------------|------------------------|-------|-----------------------|------| | Register Mnemonic Name | Access | Address <sup>(1)</sup> | Address <sup>(2)</sup> | Index | Description/Comments | Page | | XCURCOL3GREEN | R/W | _ | _ | 61h | Cursor Color 3 Green | " | | XCURCOL3BLUE | R/W | _ | | 62h | Cursor Color 3 Blue | " | | XCURCOL4RED | R/W | | | 63h | Cursor Color 4 Red | " | | XCURCOL4GREEN | R/W | _ | | 64h | Cursor Color 4 Green | " | | XCURCOL4BLUE | R/W | _ | _ | 65h | Cursor Color 4 Blue | " | | XCURCOL5RED | R/W | _ | _ | 66h | Cursor Color 5 Red | " | | XCURCOL5GREEN | R/W | _ | _ | 67h | Cursor Color 5 Green | " | | XCURCOL5BLUE | R/W | _ | _ | 68h | Cursor Color 5 Blue | " | | XCURCOL6RED | R/W | _ | | 69h | Cursor Color 6 Red | " | | XCURCOL6GREEN | R/W | _ | _ | 6Ah | Cursor Color 6 Green | " | | XCURCOL6BLUE | R/W | | | 6Bh | Cursor Color 6 Blue | " | | XCURCOL7RED | R/W | | | 6Ch | Cursor Color 7 Red | 11 | | XCURCOL7GREEN | R/W | | | 6Dh | Cursor Color 7 Green | " | | XCURCOL7BLUE | R/W | | _ | 6Eh | Cursor Color 7 Blue | " | | XCURCOL8RED | R/W | _ | _ | 6Fh | Cursor Color 8 Red | " | | XCURCOL8GREEN | R/W | _ | _ | 70h | Cursor Color 8 Green | " | | XCURCOL8BLUE | R/W | _ | _ | 71h | Cursor Color 8 Blue | " | | XCURCOL9RED | R/W | _ | _ | 72h | Cursor Color 9 Red | " | | XCURCOL9GREEN | R/W | _ | _ | 73h | Cursor Color 9 Green | " | | XCURCOL9BLUE | R/W | _ | _ | 74h | Cursor Color 9 Blue | " | | XCURCOL10RED | R/W | _ | _ | 75h | Cursor Color 10 Red | " | | XCURCOL10GREEN | R/W | _ | _ | 76h | Cursor Color 10 Green | " | | XCURCOL10BLUE | R/W | _ | | 77h | Cursor Color 10 Blue | " | | XCURCOL11RED | R/W | _ | | 78h | Cursor Color 11 Red | " | | XCURCOL11GREEN | R/W | | | 79h | Cursor Color 11 Green | " | | XCURCOL11BLUE | R/W | | | 7Ah | Cursor Color 11 Blue | " | | XCURCOL12RED | R/W | | | 7Bh | Cursor Color 12 Red | " | | XCURCOL12GREEN | R/W | | | 7Ch | Cursor Color 12 Green | " | | XCURCOL12BLUE | R/W | | | 7Dh | Cursor Color 12 Blue | " | | XCURCOL13RED | R/W | | | 7Eh | Cursor Color 13 Red | " | | XCURCOL13GREEN | R/W | _ | | 7Fh | Cursor Color 13 Green | " | | XCURCOL13BLUE | R/W | _ | | 80h | Cursor Color 13 Blue | " | | XCURCOL14RED | R/W | _ | | 81h | Cursor Color 14 Red | " | | XCURCOL14GREEN | R/W | _ | | 82h | Cursor Color 14 Green | " | | XCURCOL14BLUE | R/W | _ | | 83h | Cursor Color 14 Blue | " | | XCURCOL15RED | R/W | | | 84h | Cursor Color 15 Red | " | Table 2-4: Register Map (Part 12 of 14) | | | Memory | I/O | | | | |------------------------|--------|-----------------|-----------------|-------|---------------------------------------|-------| | Register Mnemonic Name | Access | $Address^{(1)}$ | $Address^{(2)}$ | Index | Description/Comments | Page | | XCURCOL15GREEN | R/W | _ | | 85h | Cursor Color 15 Green | " | | XCURCOL15BLUE | R/W | | | 86h | Cursor Color 15 Blue | " | | _ | | 3C0Bh | | | Reserved | | | CURPOSXL | R/W | 3C0Ch | _ | | Cursor Position X LSB | 3-368 | | CURPOSXH | R/W | 3C0Dh | | | Cursor Position X MSB | " | | CURPOSYL | R/W | 3C0Eh | _ | | Cursor Position Y LSB | " | | CURPOSYH | R/W | 3C0Fh | _ | | Cursor Position Y MSB | " | | C2CTL | R/W | 3C10h | _ | _ | CRTC2 Control | 3-77 | | C2HPARAM | WO | 3C14h | _ | _ | CRTC2 Horizontal Parameters | 3-82 | | C2HSYNC | WO | 3C18h | _ | _ | CRTC2 Horizontal Sync | 3-83 | | C2VPARAM | WO | 3C1Ch | _ | | CRTC2 Vertical Parameters | 3-97 | | C2VSYNC | WO | 3C20h | _ | 1 | CRTC2 Vertical Sync | 3-98 | | C2PRELOAD | WO | 3C24h | _ | _ | CRTC2 Preload Values | 3-90 | | C2STARTADD0 | WO | 3C28h | _ | _ | CRTC2 Field #0 Start Add. | 3-93 | | C2STARTADD1 | WO | 3C2Ch | _ | | CRTC2 Field #1 Start Add. | 3-94 | | C2PL2STARTADD0 | WO | 3C30h | _ | | CRTC2 Field #0 Plane #2 Start Add. | 3-86 | | C2PL2STARTADD1 | WO | 3C34h | _ | _ | CRTC2 Field #1 Plane #2 Start Add. | 3-87 | | C2PL3STARTADD0 | WO | 3C38h | _ | | CRTC2 Field #0 Plane #3 Start Add. | 3-88 | | C2PL3STARTADD1 | WO | 3C3Ch | _ | _ | CRTC2 Field #1 Plane #3 Start Add. | 3-89 | | C2OFFSET | WO | 3C40h | _ | _ | CRTC2 Offset Values | 3-85 | | C2MISC | R/W | 3C44h | | | CRTC2 Miscellaneous | 3-84 | | C2VCOUNT | RO | 3C48h | | | CRTC2 Vertical Count | 3-96 | | C2DATACTL | R/W | 3C4Ch | _ | _ | CRTC2 Data Control | 3-80 | | C2SUBPICLUT | WO | 3C50h | | _ | CRTC2 Sub-Picture Color LUT | 3-95 | | C2SPICSTARTADD0 | WO | 3C54h | | | CRTC2 Field #0 Sub-Picture Start Add. | 3-91 | | C2SPICSTARTADD1 | WO | 3C58h | | | CRTC2 Field #1 Sub-Picture Start Add. | 3-92 | | _ | 3C50 | C-3CFFh | | | Reserved | — | | BESA1ORG | WO | 3D00h | | | BES Buffer A-1 Org. | 3-49 | | BESA2ORG | WO | 3D04h | | | BES Buffer A-2 Org. | 3-52 | | BESB1ORG | WO | 3D08h | | | BES Buffer B-1 Org. | 3-55 | | BESB2ORG | WO | 3D0Ch | | | BES Buffer B-2 Org. | 3-58 | | BESA1CORG | WO | 3D10h | | | BES Buffer A-1 Chroma Org. | 3-48 | | BESA2CORG | WO | 3D14h | _ | | BES Buffer A-2 Chroma Org. | 3-51 | | BESB1CORG | WO | 3D18h | | | BES Buffer B-1 Chroma Org. | 3-54 | | BESB2CORG | WO | 3D1Ch | | | BES Buffer B-2 Chroma Org. | 3-57 | | BESCTL | R/W | 3D20h | | | BES Control | 3-59 | Table 2-4: Register Map (Part 13 of 14) | | | Memory | I/O | | | | |------------------------|--------|-----------------|------------------------|-------|------------------------------------|-------| | Register Mnemonic Name | Access | $Address^{(1)}$ | Address <sup>(2)</sup> | Index | Description/Comments | Page | | BESPITCH | WO | 3D24h | | | BES Pitch | 3-69 | | BESHCOORD | WO | 3D28h | | | BES Horiz. Coordinates | 3-63 | | BESVCOORD | WO | 3D2Ch | _ | | BES Vert. Coordinates | 3-75 | | BESHISCAL | WO | 3D30h | _ | | BES Horiz. Inv. Scaling Factor | 3-64 | | BESVISCAL | WO | 3D34h | _ | _ | BES Vert. Inv. Scaling Factor | 3-76 | | BESHSRCST | WO | 3D38h | | | BES Horiz. Source Start | 3-67 | | BESHSRCEND | WO | 3D3Ch | | | BES Horiz. Source Ending | 3-65 | | BESLUMACTL | WO | 3D40h | | | BES Luma Control | 3-68 | | _ | _ | 3D44h | _ | | Reserved | | | BESV1WGHT | WO | 3D48h | _ | | BES Field 1 Vert. Weight Start | 3-73 | | BESV2WGHT | WO | 3D4Ch | _ | _ | BES Field 2 Vert. Weight Start | 3-74 | | BESHSRCLST | WO | 3D50h | _ | | BES Horiz. Source Last | 3-66 | | BESV1SRCLST | WO | 3D54h | | | BES Field 1 Vert. Source Last Pos. | 3-71 | | BESV2SRCLST | WO | 3D58h | | | BES Field 2 Vert. Source Last Pos. | 3-72 | | BESA1C3ORG | WO | 3D60h | | | BES Buffer A-1 Chroma 3-Plane Org. | 3-47 | | BESA2C3ORG | WO | 3D64h | | | BES Buffer A-2 Chroma 3-Plane Org. | 3-50 | | BESB1C3ORG | WO | 3D68h | | | BES Buffer B-1 Chroma 3-Plane Org. | 3-53 | | BESB2C3ORG | WO | 3D6Ch | | | BES Buffer B-2 Chroma 3-Plane Org. | 3-56 | | | | 3D70h - | - 3DBCh | | Reserved | | | BESGLOBCTL | R/W | 3DC0h | | | BES Global Control | 3-61 | | BESSTATUS | RO | 3DC4h | | | BES Status | 3-70 | | | 3DC8 | h - 3DFFh | | | Reserved | | | VINCTL0 | WO | 3E00h | _ | _ | Video Input Control Window 0 | 3-252 | | VINCTL1 | WO | 3E04h | | | Video Input Control Window 1 | 3-253 | | VBIADDR0 | WO | 3E08h | | | VBI Address Window 0 | 3-239 | | VBIADDR1 | WO | 3E0Ch | _ | _ | VBI Address Window 1 | 3-240 | | VINADDR0 | WO | 3E10h | | | Video Input Address Window 0 | 3-245 | | VINADDR1 | WO | 3E14h | | | Video Input Address Window 1 | 3-246 | | VBICOUNT | WO | 3E18h | _ | _ | Video In VBI Count | 3-241 | | VINCTL | WO | 3E1Ch | | | Video Input Control | 3-249 | | VINADDR2 | WO | 3E20h | | | Video Input Address Window 2 | 3-247 | | VINADDR3 | WO | 3E24h | | | Video Input Address Window 3 | 3-248 | | VINCTL2 | WO | 3E28h | | | Video Input Control Window 2 | 3-254 | | VINCTL3 | WO | 3E2Ch | | | Video Input Control Window 3 | 3-255 | | VSTATUS | RO | 3E30h | | | Video Status | 3-257 | | VICLEAR | WO | 3E34h | | | Video Interrupt Clear | 3-243 | Table 2-4: Register Map (Part 14 of 14) | Register Mnemonic Name | Access | $Memory$ $Address^{(1)}$ | I/O<br>Address <sup>(2)</sup> | Index | Description/Comments | Page | |------------------------|--------|--------------------------|-------------------------------|-------|----------------------------|-------| | VIEN | R/W | 3E38h | _ | | Video Interrupt Enable | 3-244 | | VINHEIGHT | | 3E3Ch | _ | _ | Video In Maximum Height | 3-256 | | CODECCTL | WO | 3E40h | _ | | CODEC Control | 3-102 | | CODECADDR | WO | 3E44h | _ | | CODEC Buffer Start Address | 3-101 | | CODECHOSTPTR | WO | 3E48h | _ | | CODEC Host Pointer | 3-105 | | CODECHARDPTR | RO | 3E4Ch | _ | _ | CODEC Hard Pointer | 3-104 | | CODECLCODE | RO | 3E50h | _ | | CODEC LCODE Pointer | 3-106 | | _ | 3E5 | 4 - 3FFF | _ | | Reserved | _ | <sup>(1)</sup> The Memory Address for the direct access registers is a byte address offset from MGABASE1. ### Legend: <sup>(2)</sup> I/O space accesses are decoded only if VGA emulation is active (see the **OPTION** configuration register) and **iospace** = 1 (see the **DEVCTRL** configuration register). <sup>(3)</sup> Since the address processor finishes its processing before the data processor, we recommend that you initialize these registers first, in order to take advantage of the instruction overlay capability of the address processor. <sup>(4)</sup> Accessing a register in this range instructs the drawing engine to start a drawing operation. For the General Purpose index value, use the index value found in the corresponding register and/or the index with 40h. <sup>(5)</sup> Word or dword accesses to these specific reserved locations will be decoded. (The PCI convention states that I/O space should only be accessed in bytes, and that a bridge will not perform byte packing.) <sup>(6)</sup> VGA I/O addresses in the 3DXh range are for CGA emulation (the **MISC**<0> register (**ioaddsel** field) is '1'). VGA I/O addresses in the 3BXh range are for monochrome (MDA) emulation (the **ioaddsel** field is '0'). *Exception:* for **CRTCEXT**, the 3BEh and 3BFh I/O addresses are reserved, *not* decoded. <sup>(7)</sup> These registers are not writable through **MGABASE1** + 2C40h to 2C48h and **MGABASE1** + 2CDxh. They can only be written via bus mastering operations from the Matrox G400. They *can* be read through **MGABASE1** + 2C4xh and **MGABASE1** + 2CDxh. # Chapter 3: Register Descriptions | Power Graphic Mode Register Descriptions | 3-2 | |---------------------------------------------------------------------|-------| | Power Graphic Mode Configuration Space Registers Power Graphic Mode | | | Memory Space Registers | 3-31 | | VGA Mode Registers | 3-288 | | VGA Mode Register Descriptions | 3-288 | | DAC Registers | 3-367 | | DAC Register Descriptions | 3-367 | **Note:** All the register descriptions within this chapter are arranged in alphabetical order by mnemonic name. For more information on finding registers see 'Locating Information' on page 1-9. ### 3.1 Power Graphic Mode Register Descriptions ### 3.1.1 Power Graphic Mode Configuration Space Registers Power Graphic Mode register descriptions contain a (double-underlined) main header which indicates the register's mnemonic abbreviation and full name. Below the main header, the memory address (30h, for example), attributes, and reset value for the register are provided. Next, an illustration identifies the bit fields, which are then described in detail underneath. Reserved fields are identified by black underscore bars; all other fields display alternating white and gray bars. | Sample Pov | wer Graphic Mod | de Config. Space Register | SAMPLE_CS | |-------------------|---------------------------------------|---------------------------------------------------------------------------------------|------------------------------| | Address | <value>(CS)</value> | | <u> </u> | | Attributes | R/W | | Main header | | Reset Value | <value></value> | | mani neade. | | | field3 ij | | / Underscore bars | | Reserved | field3 ≟ | field1 | | | 31 30 29 28 27 | 26 25 24 23 22 21 2 | 0 19 18 17 16 15 14 13 12 11 10 | 9 8 7 6 5 4 3 2 1 0 | | field1<br><22:0> | | escription of the <b>field1</b> field of the to 0. <i>Font and case changes withi</i> | _ & . | | field2<23> | Field 2. Detailed d | escription of field2 in SAMPLE_ | <b>CS</b> , which is bit 23. | | field3<br><26:24> | Field 3. Detailed d comprises bits 26 | escription of the <b>field3</b> field of the to 24. | e SAMPLE_CS register, which | | Reserved <31:27> | | riting to this register, the bits in the salways appear at the end of a reg | | ### **Memory Address** The addresses of all the Power Graphic Mode registers are provided in Chapter 2. → *Note:* CS indicates that the address lies within the configuration space. #### **Attributes** The Power Graphic Mode configuration space register attributes are: - RO There are no writable bits.WO: There are no readable bits. - R/W: The state of the written bits can be read. - BYTE: 8-bit access to the register is possible. - WORD: 16-bit access to the register is possible. - DWORD: 32-bit access to the register is possible. - STATIC: The contents of the register will *not* change during an operation. ### **Reset Value** Here are some of the symbols that appear as part of a register's reset value: ``` 000? 0000 000S ???? 1101 0000 S000 0000b (b = binary,? = unknown, S = bit's reset value is affected by a strap setting, N/A = not applicable) ``` AGP Command AGP\_CMD 19 18 17 16 15 14 data\_rate <2:0> 31 30 29 28 27 26 25 24 23 22 21 20 Indicates the operational data rate of the device. Only one bit in this field must be set: 12 11 10 9 8 6 5 4 3 2 1 13 | data_rate | description | |-----------|------------------------------| | '000' | reset value | | '001' | 1 x data rate | | '010' | 2 x data rate | | '100' | 4 x data rate <sup>(1)</sup> | | others | Reserved | <sup>(1)</sup> **Note:** the 4x data rate is **only** available when **typedetN** pin is tied to '0'. agp\_enable When set, this bit enables the Matrox G400 to initiate AGP operation. <8> **sba\_enable** When set, the side address bus of the device is enabled. <9> rq\_depth <28:24> This should be programmed with the maximum number of pipelined operations that the Matrox G400 is allowed to queue. This value should be equal, or less, than the value reported in the **rq** field of **AGP\_STS** register. Reserved <31:29> <23:10> <7:3> Reserved. Writing has no effect. Reading will give '0's. •• *Note:* To initiate the AGP cycle, both **agp\_enable** and **sba\_enable** must be set together with the proper **data\_rate** value (either 1X, 2X, or 4X). <31:24> Address F0h(CS) Attributes RO, BYTE/WORD/DWORD, STATIC | Reserved | I | agp_re | V | | ag | Jp_ι | next | _ptı | r | | agp_cap_id | | | | | | | | |------------------------|------------------------------------|------------|---------|---------|-------|------|-------|------|------|-------|------------|--------|-------|----------|-------|----|--|--| | 31 30 29 28 27 20 | 6 25 24 23 22 2 | 21 20 19 | 18 17 | 16 15 | 14 1 | 3 1 | 2 11 | 10 | 9 | 8 7 | 6 | 5 4 | 3 | 2 | 1 | 0 | | | | agp_cap_id<br><7:0> | This field continformation co | | | • | | | | | | vhich | des | scribe | s the | <b>)</b> | | | | | | agp_next_ptr<br><15:8> | This field contact capabilities in | | nard-c | oded v | alue | of 0 | 0h, v | vhic | h in | dica | es t | hat th | ere i | s no | oth | er | | | | agp_rev<br><23:16> | This field contains (as in 2.0) | ains the | AGP s | pecific | ation | rev | isior | ı to | whi | ch th | is d | evice | com | plie | s: 20 | 0h | | | | Reserved | Reserved. Writ | ting has i | no effe | ct. Rea | ading | wil | l giv | e '0 | 's. | | | | | | | | | | **AGP Status** AGP\_STS F4h (CS) for Matrox G400-AGP only **Address** RO, BYTE/WORD/DWORD, STATIC **Attributes** **Reset Value** 0001 1111 0000 0000 0000 0010 0000 0S11b | Reset value | 0001 1111 0000 0000 0000 0010 0000 05116 | |-------------------|------------------------------------------------------------------------------------------------------------------------------------| | rq | sba_cap Reserved addr4g_cap fw_cap Reserved rate_cap | | 31 30 29 28 27 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | rate_cap<br><2:0> | When <b>typedetN</b> is '0', the hard-coded '111b' indicates that the device supports all the AGP transfer rates (1X, 2X, and 4X). | | | When <b>typedetN</b> is '1', the hard-coded '011b' indicates that the device supports two AGP transfer rate modes (1X, 2X). | | fw_cap<br><4> | Hard-coded '0's indicate that the device does <i>not</i> support fastwrite transfers. | | addr4g_cap<br><5> | Hard-coded '0's indicate that the device does <i>not</i> support addresses greater than 4GB | | sba_cap<br><9> | The hard-coded '1' indicates that the device supports AGP Side band addressing. | | rq<br><31:24> | The hard-coded '1Fh' indicates that the device can manage 32 outstanding AGP Requests. | | Reserved | <23:10> <8:6> <3> | | | Reserved. Writing has no effect. Reading will give '0's. | Address 34h (CS) Attributes RO, BYTE/WORD/DWORD, STATIC **Reset Value** 0000 0000 0000 0000 0000 1101 1100b | Reserved | cap_pt | tr | |----------|--------|----| | | | | | 31 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| **cap\_ptr** This field contains the hard-coded offset byte (DCh) within the device configuration space of the PCI Bus Power Management Interface Specification Capability Identifier register. **Reserved** Reserved. Writing has no effect. Reading will give '0's. <31:8> Class Code CLASS Address 08h (CS) Attributes RO, BYTE/WORD/DWORD, STATIC class revision | 3 | 1 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| revision Holds the current chip revision: <7:0> • 00h for Matrox G400 Rev. 0 • 01h for Matrox G400 Rev. 1 class <31:8> Identifies the generic function of the device and a specific register-level programming interface as per the PCI specification. Two values can be read in this field according to the vgaboot strap, which is sampled on hard reset. | vgaboot strap | Value | Meaning | |---------------|---------|----------------------------------| | '0' | 038000h | Non-Super VGA display controller | | '1' | 030000h | Super VGA compatible controller | The sampled state of the vgaboot strap (pin HDATA[0], described on page A-5) can be read through this register. DEVCTRL Device Control Address 04h (CS) Attributes R/W, BYTE/WORD/DWORD, DYNAMIC | | detparerr | sigsyserr | recmastab | rectargab | sigtargab | deveeltim. | )<br>> | Reserved | fastbackcap | ndfsup | cap66mhz | caplist | | | | I | Res | ser | vec | I | | | | serrenable | waitcycle | resparerr | vgasnoop | memwrien | specialcycle | busmaster | memspace | iospace | | |---|-----------|-----------|-----------|-----------|-----------|------------|--------|----------|-------------|--------|----------|---------|----|----|----|----|-----|-----|-----|----|----|----|---|------------|-----------|-----------|----------|----------|--------------|-----------|----------|---------|--| | I | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 2.7 | 26 | 25 | 24 | 23 | 2.2. | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | iospace R/W <0> I/O space. Controls device response to I/O SPACE accesses (VGA registers). - 0: disable the device response - 1: enable the device response memspace R/W <1> Memory space. Controls device response to memory accesses (EPROM, VGA frame buffer, MGA control aperture, MGA direct access aperture, and 8 MByte Pseudo-DMA window). - 0: disable the device response - 1: enable the device response busmaster R/W <2> Bus master. Controls a device's ability to act as a master on the PCI bus (used to access system memory): - 0: prevents the device from generating PCI accesses - 1: allows the device to behave as a bus master specialcycle RO <3> The hard-coded '0' indicates that the MGA will *not* respond to a special cycle. memwrien RO <4> The hard-coded '0' indicates that an MGA acting as a bus master will never generate the write and invalidate command. vgasnoop R/W <5> Controls how the chip handles I/O accesses to the VGA DAC locations. The **vgasnoop** field is only used when **vgaioen** (see **OPTION** on page 3-18) is '1'. - 0: The chip will reply to read and write accesses at VGA locations 3C6h, 3C7h, 3C8h, and 3C9h. - 1: The chip will **snoop** writes to VGA DAC locations. It will *not* assert PTRDY/, PSTOP/, and PDEVSEL/, but will internally decode the access and program the on-board DAC. In situations where the chip is not ready to snoop the access, it will acknowledge the cycle by asserting PDEVSEL/, and force a retry cycle by asserting PSTOP/. Read accesses to VGA DAC locations are *not* affected by vgasnoop. resparerr RO <6> The hard-coded '0' indicates that the MGA will *not* detect and signal parity errors (MGA does generate parity information as per the PCI specification requirement). Writing has no effect. waitcycle RO <7> This bit reads as '0', indicating that no address/data stepping is performed for read accesses in the target (data stepping) and the master (address stepping). Writing has no effect **Device Control DEVCTRL** | serrenable<br>RO <8> | This hard-coded '0' indicates that MGA does <i>not</i> generate SERR interrupts. Writing has no effect. | |-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | caplist<br>RO <20> | The hard-coded '1' indicates that the device has a capability list in the configuration space. The list is located at the offset in the CAP_PTR register. Writing has no effect. | | cap66mhz<br>RO <21> | The hard-coded '0' indicates that the device does <i>not</i> comply with the PCI 66 MHz timing specification. Writing has no effect. | | | •• Note: PCI transactions at 66 Mhz are supported as per the AGP timing specification. | | udfsup<br>RO <22> | The hard-coded '0' indicates that the MGA does <i>not</i> support user-definable features. | | fastbackcap<br>RO <23> | The hard-coded '1' indicates that the MGA supports fast back-to-back transactions when part of the transaction targets a different agent. Writing has no effect. | | devseltim<br>RO <26:25> | Device select timing. Specifies the timing of devsel. It is read as '01'. | | sigtargab<br>R/W <27> | Signaled target abort. Set to '1' when the MGA terminates a transaction in target mode with target-abort. This bit is cleared to '0' when written with '1'. | | rectargab<br>R/W <28> | Received target abort. Set to '1' when the MGA is a master and a transaction is terminated with target-abort. This bit is cleared to '0' when written with '1'. | | recmastab<br>R/W <29> | Received master abort. Set to '1' when a transaction is terminated with master-abort by the MGA. This bit is cleared to '0' when written with '1'. | | sigsyserr<br>RO <30> | MGA does not assert SERR/. Writing has no effect. Reading will return '0's. | | detparerr<br>RO <31> | MGA does <i>not</i> detect parity errors. Writing has no effect. Reading will return '0's. | | Reserved | <19:9> <24> | | | Reserved. Writing has no effect. Reading will return '0's. | | | | Address 00h (CS) Attributes RO, BYTE/WORD/DWORD, STATIC **Reset Value** 0000 0101 0010 0101 0001 0000 0010 1011b device vendor 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 vendor This field contains the Matrox manufacturer identifier for PCI: 102Bh. <15:0> **device** This field contains the Matrox device identifier, which for the Matrox G400-AGP is: **<31:16>** 0525h. Header HEADER Address 0Ch(CS) Attributes R/W, BYTE/WORD/DWORD, STATIC | | | R | ese | erv | ed | | | | | ŀ | nea | ıdeı | r | | | | | la | atei | ntir | n | | | Reserve | | ( | cac | he | line | ) | | |----|----|----|-----|-----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|------|------|----|---|---|---------|---|---|-----|----|------|---|---| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | R/W <15:11> Once the count expires, the master must initiate transaction termination as soon as its PGNT/ signal is removed. **RO <23:16>** This field specifies the layout of bytes 10h through 3Fh in the configuration space and also indicates that the current device is a single function device. This field is read as 00h. Reserved <7> <31:24> Reserved. Writing has no effect. Reading will return '0's. Address 3Ch (CS) **Attributes** R/W, BYTE/WORD/DWORD, STATIC Reset Value | maxlat | | | | | min | an | ŀ | | | | | | int | nin | 1 | | | | | | intl | line | | | |----------------------|-----------------|------|--------|-------------|---------------|-----------|-----------|------------|------|-------------|------------------------|-----|------|-------------|-------|-------------|------------------|-------|------|-------|------|------|------|------------------| | maxiat | | | | | | 9 | _ | | | ı | | | | γ | | | | | | | | | | | | 31 30 29 28 27 20 | 5 25 2 | 24 2 | 23 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 | | intline<br>R/W <7:0> | up to<br>interr | the | | figu<br>and | ırati<br>d pr | on<br>ogr | pro<br>am | gra<br>the | m t | o d<br>tlir | leter<br>l <b>e</b> fi | rmi | ne v | whi<br>core | ch i | inte<br>gly | rru <sub>]</sub> | ot le | eve | lis | tiec | | | et. It is<br>MGA | | intpin<br>RO <15:8> | Selec | ctec | d inte | rrup | ot pi | ins. | Re | ad a | as 1 | h t | o ir | dic | ate | tha | t oı | ne F | CI | inte | errı | ıpt l | line | | | d (PCl<br>ignal) | | mingnt | This | fie | ld spe | cif | ies 1 | the | PC | I de | evic | e's | rec | uir | ed ł | our | st le | engi | th i | 1/ | ′4 u | s. a | ssu | miı | าย ล | clock | RO <23:16> This field specifies the PCI device's required burst length in $1/4 \mu s$ , assuming a clock rate of 33 MHz. maxlat RO <31:24> This field specifies how often the PCI device must gain access to the PCI bus in 1/4 μs, assuming a clock rate of 33 MHz. Address 48h (CS) Attributes R/W, BYTE/WORD/DWORD, STATIC Reset Value unknown ### mga\_data | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ◆ *Note:* The MGA\_INDEX and MGA\_DATA registers cannot be used to access Pseudo-DMA windows (DMAWIN). (see page 4-29) Address 44h (CS) Attributes R/W, BYTE/WORD/DWORD, STATIC | | | | | | | | R | ese | ervo | ed | | | | | | | | | | | | mç | ga_ | ind | lex | | | | | 0000 | 19690 | |---|------|------|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|-----|---|---|---|---|------|-------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 3 | 31 3 | 0 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | # mga\_index <13:2> Dword index. Used to reach any of the registers that are mapped into the MGA control aperture through the configuration space. This mechanism should be used for initialization purposes only, since it is inefficient. This 'back door' access to the control register can be useful when the control aperture cannot be mapped below the 1 MByte limit of the real mode of an x86 processor (during BIOS execution, for example). ### Reserved <1:0> <31:14> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Reading will return '0's. - ◆ *Note:* The MGA\_INDEX and MGA\_DATA registers cannot be used to access Pseudo-DMA windows (DMAWIN) (see page 4-29). - •• *Note:* The valid range for MGA\_INDEX is 1C00h to 3FFCh (see Table 2-3 for device addresses). Address 14h (CS) Attributes R/W, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | | | | | m | gak | oas | e1 | | | | | | | | | | | Re | ese | erve | ed | | | | prefetchable | tvne | | memspaceind | |---------------------------------------------------------------------------------------|-------|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|----|---|---|---|--------------|------|---|-------------| | | 31 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | memspace The hard-coded '0' indicates that the map is in the memory space. ind RO <0> type RO <2:1> The hard-coded '00' instructs the configuration program to locate the aperture anywhere within the 32-bit address space. prefetchable RO <3> The hard-coded '0' indicates that this space *cannot* be prefetchable. mgabase1 <31:14> Specifies the base address of the MGA memory mapped control registers (16 Kilobyte control aperture). In situations where the MGA control aperture overlaps the MGA frame buffer aperture and/or the ROM aperture, the following order of precedence will be used (listed from highest to lowest priority): - 1. BIOS EPROM - 2. MGA control aperture - 3. 8 MByte Pseudo-DMA window - 4. VGA frame buffer aperture - 5. MGA frame buffer aperture An aperture will be decoded *only* if the preceding ones are *not* decoded. If no aperture is decoded, the Matrox G400 will *not* respond to memory accesses. Decoding of an aperture is related to the address (if it corresponds to one of the base addresses), the command, and some of the control bits, such as **memspace**, **biosen**, **romen**, and **rammapen**. Reserved Reserved. When writing to this register, the bits in this field *must* be set to '0'. <13:4> Reading will return '0's. p Address 10h (CS) Attributes R/W, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 1000b | | ı | mga | aba | se | 2 | | | | | | | | | | ı | Res | ser | ved | I | | | | | | | | prefetchable | tvpe | 2 | memspacei | |----|-------|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|-----|----|----|---|---|---|---|---|---|--------------|------|---|-----------| | 31 | 30 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | memspace ind RO <0> The hard-coded '0' indicates that the map is in the memory space. type RO <2:1> The hard-coded '00' instructs the configuration program to locate the aperture anywhere within the 32-bit address space. prefetchable RO <3> A '1' indicates that this space can be prefetchable (better system performance can be achieved when the bridge enables prefetching into that range). mgabase2 <31:25> Specifies the PCI start address of the 32 megabytes of MGA memory space in the PCI map. In situations where the MGA control aperture overlaps the MGA frame buffer aperture and/or the ROM aperture, the following precedence order will be used, listed from highest to lowest priority: - 1. BIOS EPROM - 2. MGA control aperture - 3. 8 MByte Pseudo-DMA window - 4. VGA frame buffer aperture - 5. MGA frame buffer aperture An aperture will be decoded *only* if the preceding ones are **not** decoded. If no aperture is decoded, the Matrox G400 will **not** respond to memory accesses. Decoding of an aperture is related to the address (if it corresponds to one of the base addresses), the command, and some of the control bits, such as **memspace**, **biosen**, **romen**, and **rammapen**. When mgamode = 0 (CRTCEXT3<7>), the MGA frame buffer Aperture is *not* usable. Reserved Reserved. When writing to this register, the bits in this field *must* be set to '0'. <24:4> Reading will return '0's. Address 18h (CS) Attributes R/W, BYTE/WORD/DWORD, STATIC ## Reserved | memspace ind RO <0> The hard-coded '0' indicates that the map is in the memory space. type RO <2:1> The hard-coded '00' instructs the configuration program to locate the aperture anywhere within the 32-bit address space. prefetchable RO <3> The hard-coded '0' indicates that this space *cannot* be prefetchable. mgabase3 <31:23> Specifies the base address of the 8 MByte Pseudo-DMA window. In situations where the MGA control aperture overlaps the MGA frame buffer aperture and/or the ROM aperture, the following precedence order will be used, listed from highest to lowest priority: - 1. BIOS EPROM - 2. MGA control aperture - 3. 8 MByte Pseudo-DMA window - 4. VGA frame buffer aperture - 5. MGA frame buffer aperture An aperture will be decoded *only* if the preceding ones are *not* decoded. If no aperture is decoded, the Matrox G400 will *not* respond to memory accesses. Decoding of an aperture is related to the address (if it corresponds to one of the base addresses), the command, and some of the control bits, such as **memspace**, **biosen**, **romen**, and **rammapen**. Reserved Reserved. When writing to this register, the bits in this field *must* be set to '0'. **<22:4>** Reading will return '0's. OPTION Option Address 40h (CS) Attributes R/W, BYTE/WORD/DWORD, STATIC Reset Value 0S00 0000 0000 0000 0000 000S 0000 0000b | powerpc<br>biosen | noretry | <b>-</b> | Res | ser <sub>'</sub> | vec | I | enhmemacc | Reserved | | | rfh | cnt | ì | | hardpwmsk | Reserved | | memconfig | | Reserved | vgaioen | Reserved | plisel | syspllpdn | Š | מבו א מ<br>מבו | syscIkdis | Recerved | אנו אנו<br>אנו אנו | |-------------------|---------|----------|-----|------------------|-----|----|-----------|----------|----|----|-----|-----|----|----|-----------|----------|----|-----------|----|----------|---------|----------|--------|-----------|---|----------------|-----------|----------|--------------------| | 31 30 | 29 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | sysclkdis System clock disable. This bit controls the system clock output: <2> • 0: enable system clock oscillations • 1: disable system clock oscillations sysplipdN <5> System PLL power down. • 0: power down • 1: power up pllsel <6> PLL Select. When set to '1', the pixel clock comes from **syspll**. • 0: PLL P1 drives the pixel clock PLL P2 drives the system clock • 1: PLL P1 drives the system clock PLL P2 drives the pixel clock •• *Note:* This bit *must* be set to '0' for normal operation. (A '1' will swap **pixpll** with **syspll**). vgaioen <8> VGA I/O map enable. | vgaioen | Status | |---------|--------------------------------------------------------------------| | '0' | VGA I/O locations are not decoded (hard reset mode if vgaboot = 0) | | '1' | VGA I/O locations are decoded (hard reset mode if vgaboot = 1) | On hard reset, the sampled vgaboot strap (HDATA[0]) will replace the **vgaioen** value. •• Note: The MGA control registers and MGA frame buffer map are always enabled for all modes. ### memconfig <12:10> Memory Configuration. This field *must* be loaded before initiating a memory reset or attempting to read or write to the frame buffer. Once synchronized, **memconfig** is used to determine the correct address boundaries for the bank select, chip select, row address, and column address. This signal should *not* be changed during normal operation. Option OPTION | memconfig [2:0] | Memory Organization of parts used in Frame Buffer | |-----------------|--------------------------------------------------------------------------------| | ,000, | 256 cols, 2048 rows, 2 x 512K x 16 (16Mb) SDRAM and 2 x 512K x 32 (32Mb) SGRAM | | '001' | 256 cols, 1024 rows, 2 x 256K x 32 (16Mb) SGRAM | | '010' | 256 cols, 512 rows, 4 x128K x 32 (16Mb) SGRAM | | '011' | 256 cols, 2048 rows, 4 x 512K x 32 (64Mb) SDRAM | | '100' | 256 cols, 1024 rows, 4 x 256K x 32 (32Mb) SGRAM | | '101' | 256 cols, 4096 rows, 2 x 1M x 32 (64Mb) SDRAM | | '11X' | Reserved | •• *Note:* For memconfig = '000', the 16Mb SDRAM is distinguished from the 32 Mb SGRAM using the **hardpwmsk** field. # hardpwmsk <14> Hardware plane write mask. This field is used to enable SGRAM special functions. This field must *always* be set to '0' when SDRAM is used. (when SGRAM is used, software *must* set **hardpwmsk** to '1' in order to take advantage of special SGRAM functions). This field must *always* be loaded *before* attempting to write to the frame buffer and should *not* be changed during normal operation. - 0: Special SGRAM functions are *not* available; however, a plane write mask cycle will be emulated in the Matrox G400 at a reduced performance level. - 1: Special SGRAM functions are enabled, so plane write mask operations will be performed by the memory (with optimal performance) and block mode operations are available. - **► Note:** hardpwmsk must *never be set to '1'* when the memory does *not* consist of *SGRAM*. # nohireq <28> mfifo High priority Request disable. A '1' disables the mfifo high priority requests and causes all the requests to be generated in low priority. # rfhcnt <20:15> Refresh counter. Defines the rate of the Matrox G400's memory refresh. Page cycles will *not* be interrupted by a refresh request unless a second request is queued (in this case, the refresh request becomes the highest priority after the screen refresh). Since all banks have to be pre-charged, both queued refreshes will keep this new highest priority. When programming the **rfhcnt** register, the following rule must be respected: ram refresh period >= (rfhcnt<5:0> \* 64 + 1) \* MCLK period •• *Note:* Setting **rfhcnt** to zero *halts* the memory refresh. ### enhmemacc <22> Enable the use of advance Read commands by the PCI Master (MRL & MRM). ### noretry <29> Retry disable. A '1' disables generation of the retry sequence and the delayed read on the PCI bus (except during a VGA snoop cycle). At this setting, PCI latency rules may be violated. # biosen <30> BIOS Enable. On hard reset, the sampled bios boot strap (HDATA[1]) is loaded into this field. • 0: The **ROMBASE** space is automatically disabled. A small serial eeprom can be OPTION Option present on board. • 1: The **ROMBASE** space is enabled - **rombase** must be correctly initialized since it contains *unpredictable* data. A big serial eeprom is present on board. # powerpc <31> Power PC mode. - 0: No special swapping is performed. The host processor is assumed to be of Little-Endian type. - 1: Enables byte swapping for the memory range MGABASE1 + 1C00h to MGABASE1 + 1EFFh, as well as MGABASE1 + 2000h to MGABASE1 + 3BFFh and MGABASE1 + 3D00h to MGABASE1 + 3FFFh. This swapping allows a Big-Endian processor to access the information in the same manner as a Little-Endian processor. - **Note:** There is **no** swapping in the configuration space. #### Reserved <1:0> <4:3> <7> <9> <13> <21> <28:23> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. Option2 OPTION2 Address 50h (CS) Attributes R/W, BYTE/WORD/DWORD, STATIC | Re | ese | erv | ed | codpstdiv | codprediv | . 200 | 5 | Doggada | ָ<br>ט | | modcIkp | | | mod2clkp | | | Ī | Res | ser | ved | l | | eepromwt | | | R | ese | erve | ed | | | |----|-----|-----|----|-----------|-----------|-------|----|---------|--------|----|---------|----|----|----------|----|----|----|-----|-----|-----|----|---|----------|---|---|---|-----|------|----|---|---| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | eepromwt <8> EEPROM write enable. When set to '1', a write access to the BIOS EPROM aperture will program that location. When set to '0', write access to the BIOS EPROM aperture has **no** effect. mod2clkp <18:16> Module Clock Period. On hard reset, the sampled module clock period strap (MDQ2<31:29>) value will replace the value of **mod2clkp**. This field is used to determine the frequency at which an LVTTL memory expansion module is designed to operate. modclkp <21:19> Module Clock Period. On hard reset, the sampled module clock period strap (MDQ<31:29>) value will replace the value of **modclkp**. This field is used to determine the frequency at which an LVTTL memory expansion module is designed to operate. codclksl <25:24> CPDEC Clock frequency Select. This field is used to select the frequency source for the codec clock generator. • '00': PCI '01': System PLL'10': MCLK PIN'11': AGP DLL ◆ *Note:* Hard reset at '11'. codprediv <26> This field determines if the pre-divider (divide by 2) is used. '0': no divide'1': divide by 2 •• *Note:* hard reset at '0'. OPTION2 Option2 # codpstdiv <27> This field determines if the pre-divider (divide by 3/2) is used. '0': no divide'1': divide by 3/2 ◆ *Note:* hard reset at '1'. ### Reserved <7:0> <15:9> <31:28> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. Option3 OPTION Address 54h (CS) Attributes R/W, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 | Reserved | W | /clk | dc | ус | w | ciko | vib | Reserved | | WCIPSG | m | clk | dc | ус | m | cld | iv | Reserved | 100/100 | IIICINSCI | ge | clk | dcy | /C | gc | lkd | liv | Reserved | 100/100 | 100 P | |----------|-------|------|----|----|----|------|-----|----------|----|--------|----|-----|----|----|----|-----|----|----------|---------|-----------|----|-----|-----|----|----|-----|-----|----------|---------|-------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 3 | 30 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | gclksel <1:0> Graphic Clock Selection. These bits select the source for the Graphic Clock. • '00': select the PCI clock - '01': select the output of the system PLL (as defined by PLLSEL) - '10': selects an external source from the MCLK pin (permitted only if MCLK has been configured as an input). - '11': selects the AGPDLL clock gclkdiv <5:3> Graphic Clock Divider. These bits select the division factor used on the Graphic Clock Source. - '000': select Graphic Clock Source multiplied by 1/3 - '001': select Graphic Clock Source multiplied by 2/5 - '010': select Graphic Clock Source multiplied by 4/9 - '011': select Graphic Clock Source multiplied by 1/2 - '100': select Graphic Clock Source multiplied by 2/3 - '101': Graphic Clock Source bypass - '110': Reserved - '111': Reserved gclkdcyc <9:6> Graphic Clock Duty Cycle Correction. These bits control the duty cycle of the Graphic Clock after division. | gclkdcyc | Duty cycle correction in ns at a source clock of: | |----------|---------------------------------------------------| | '0000' | duty cycle unaffected | | '0001' | 2.75 to 3.25 | | '0010' | 3.25 to 3.75 | | '0011' | 3.75 to 4.25 | | '0100' | 4.25 to 4.75 | | '0101' | 4.75 to 5.25 | | '0110' | 5.25 to 5.75 | | '0111' | 5.75 to 6.25 | | '1000' | 6.25 to 6.75 | | '1001' | 6.75 to 7.25 | | '1010' | 7.25 to 7.75 | OPTION3 Option3 | gclkdcyc | Duty cycle correction in ns at a source clock of: | |----------|---------------------------------------------------| | '1011' | 7.25 to 8.25 | | '1100' | 8.25 to 8.75 | | '1101' | 8.75 to 9.25 | | '1110' | 9.25 to 9.75 | | '1111' | 9.75 to 10.25 | ### mclksel <11:10> Memory Clock Selection. These bits select the source for the Memory Clock. - '00': select the PCI clock - '01': select the output of the system PLL (as defined by PLLSEL) - '10': selects an external source from the MCLK pin (permitted only if MCLK has been configured as an input.) - '11': select the AGPDLL clock # mcldiv <15:13> Memory Clock Divider. These bits select the division factor used on the Memory Clock source. - '000': select Graphic Clock Source multiplied by 1/3 - '001': select Graphic Clock Source multiplied by 2/5 - '010': select Graphic Clock Source multiplied by 4/9 - '011': select Graphic Clock Source multiplied by 1/2 - '100': select Graphic Clock Source multiplied by 2/3 - '101': Graphic Clock Source bypass - '110': Reserved - '111': Reserved # mclkdcyc <19:16> Memory Clock Duty Cycle Correction. These bits control the duty cycle of the Memory Clock after division. | mclkdcyc | Duty cycle correction in ns at a source clock of: | |---------------|---------------------------------------------------| | '0000' | duty cycle unaffected | | '0001' | 2.75 to 3.25 | | '0010' | 3.25 to 3.75 | | '0011' | 3.75 to 4.25 | | '0100' | 4.25 to 4.75 | | '0101' | 4.75 to 5.25 | | '0110' | 5.25 to 5.75 | | '0111' | 5.75 to 6.25 | | '1000' | 6.25 to 6.75 | | '1001' | 6.75 to 7.25 | | '1010' | 7.25 to 7.75 | | <b>'1011'</b> | 7.25 to 8.25 | | '1100' | 8.25 to 8.75 | | '1101' | 8.75 to 9.25 | | '1110' | 9.25 to 9.75 | | '1111' | 9.75 to 10.25 | Option3 OPTION # wclksel <21:20> Warp Clock Selection. These bits select the source for the Warp Clock. - '00': select the PCI clock - '01': select the output of the system PLL 9as defined by PLLSEL) - '10': selects an external source from the MCLK pin (permitted only if MCLK has been configured as an input) - '11': select the AGPDLL clock # wclkdiv <25:23> Warp Clock Divider. These bits select the division factor used on the Warp Clock. - '000': select Graphic Clock Source multiplied by 1/3 - '001': select Graphic Clock Source multiplied by 2/5 - '010': select Graphic Clock Source multiplied by 4/9 - '011': select Graphic Clock Source multiplied by 1/2 - '100': select Graphic Clock Source multiplied by 2/3 - '101': Graphic Clock Source bypass - '110': Reserved - '111': Reserved # wclkdcyc <29:26> Warp Clock Duty Cycle Correction. These bits control the duty cycle of the Warp after division. | wclkdcyc | Duty cycle correction in ns at a source clock of: | |----------|---------------------------------------------------| | '0000' | duty cycle unaffected | | '0001' | 2.75 to 3.25 | | '0010' | 3.25 to 3.75 | | '0011' | 3.75 to 4.25 | | '0100' | 4.25 to 4.75 | | '0101' | 4.75 to 5.25 | | '0110' | 5.25 to 5.75 | | '0111' | 5.75 to 6.25 | | '1000' | 6.25 to 6.75 | | '1001' | 6.75 to 7.25 | | '1010' | 7.25 to 7.75 | | '1011' | 7.25 to 8.25 | | '1100' | 8.25 to 8.75 | | '1101' | 8.75 to 9.25 | | '1110' | 9.25 to 9.75 | | '1111' | 9.75 to 10.25 | Reserved <2> <12> <22> <31:30> Address E0 h (CS) Attributes R/W, BYTE/WORD/DWORD, STATIC powerstate ### Reserved | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| powerstate <1:0> This two bit field is used to determine the current power state of the device, and to set the device into a new power state. Writing to this register will place the device in the appropriate power state. | powerstate | Video Controller Power State definition <sup>(1)(2)(3)</sup> | |-------------|----------------------------------------------------------------------------| | | D0 | | | Back-end: On | | '00' | Video Controller Context: Preserved | | | Video Memory Contents: Preserved | | | • Interrupts: Possible | | | D3 (Power may be removed) | | | Back-end: Off | | | Video Controller Context: Lost | | | Video memory Contents: Lost | | | <ul><li>Interrupts: Disabled</li><li>TCLUT and TCACHE data: Lost</li></ul> | | | - TCLUT and TCACHE data: Lost | | | Mask bits of <b>DEVCTRL</b> register: | | | • iospace = '0' | | | • memspace = '0' | | | • busmaster = '0' | | | Power down of SSTL buffers (memory bus) | | | <ul> <li>data/address/command</li> </ul> | | | <ul> <li>by selecting LVTTL buffers</li> </ul> | | <b>'11'</b> | Power down of RAMDAC section: | | | • pixclkdis = '1' | | | • dacpdN = '0' | | | • ramcs ='0' | | | • pixpllpdN = '0' | | | Power down of MEMORY/GRAPHIC/WARP section: | | | • sysclkdis = '1' | | | • sysplipdN = '0' | | | Power down of TCACHE and TCLUT: | | | Power down of ZORAN_I_33 and ZORAN_I_34: | | | | <sup>&</sup>lt;sup>(1)</sup> Since D1 and D2 mode are *not* supported, only writes with valid values will modify the powerstate field. •• *Note:* The above table complies with the Display Device Class Power Management Reference Specification. Reserved: <31:2> Reserved. When writing to this register, the bits in this field *must* be set to '0'. <sup>(2)</sup> PCI BPMI Spec. states that hardware has at least 16 PCI clocks after the powerstate bits were written to D3 before **PCLK** may be stopped. <sup>(3)</sup> An internal reset (used like the hard reset) is generated for 16 PCI clocks when returning from D3 (with power) to D0. Address DC h (CS) Attributes RO, BYTE/WORD/DWORD | | Res | ser | vec | d | d2_sup | d1_sup | | Reserved | | dsi | Postragad | Deal ved | | pm_version | | | F | om. | _ne | ext_ | _ptı | r | | | | pm | ո_c | ap_ | _id | | | |----|-----|-----|-----|----|--------|--------|----|----------|----|-----|-----------|----------|----|------------|----|----|----|-----|-----|------|------|---|---|---|---|----|-----|-----|-----|---|---| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | pm\_cap\_id Power Management Capabilities Identifier. This field contains the PCI Bus Power Management Interface Specification Capabilities Identifier: 01h, which describes the information contained in the capability entry (DCh-E0h) pm\_next\_ptr<15:8>Next pointer. This field contains the pointer to the next capability in the link list. For Matrox G400-AGP, a hard-coded "F0h" points to the AGP capabilities. pm\_version Version. Version '010b' indicates that the Matrox G400 complies with revision 1.1 of the PCI Power Management Interface Specification. dsi Device Specific Initialization. A '1' indicates that the Matrox G400 requires a device specific initialization sequence when returning from d3. **d1\_sup** The D1 Power Management state is *not* supported. **<25>** **d2\_sup** The D2 Power Management state is *not* supported. **<26>** Reserved <31:27> <24:22> <20:19> Address 30h (CS) Attributes R/W, BYTE/WORD/DWORD, STATIC rombase Reserved 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 romen <0> ROM enable. This field can assume different attributes, depending on the contents of the **biosen** field. This allows booting with or without the BIOS EPROM (typically, a motherboard implementation will boot the MGA without the BIOS, while an add-on adapter will boot the MGA with the BIOS EPROM). | biosen | romen attribute | |------------|-----------------| | '0' | RO (read as 0) | | <b>'1'</b> | R/W | rombase <31:16> ROM base address. Specifies the base address of the EPROM. This field can assume different attributes, depending on the contents of **biosen**. | biosen | rombase attribute | |--------|-------------------| | '0' | RO (read as 0) | | '1' | R/W | •• *Note:* The exact size of the EPROM used is application-specific (could be 128 bytes, 32 KBytes, or 64 KBytes). In situations where the MGA control aperture overlaps the MGA frame buffer aperture and/or the ROM aperture, the following precedence order will be used, listed from highest to lowest: - 1. BIOS EPROM (highest precedence) - 2. MGA control aperture - 3. 8 MByte Pseudo-DMA window - 4. VGA frame buffer aperture - 5. MGA frame buffer aperture (lowest precedence) An aperture will be decoded *only* if the preceding ones are **not** decoded. If no aperture is decoded, the Matrox G400 will **not** respond to memory accesses. Decoding of an aperture is related to the address (if it corresponds to one of the base addresses), the command, and some of the control bits, such as **memspace**, **biosen**, **romen**, and **rammapen**. Even if MGA supports only a serial EPROM, this does *not* constitute a system performance limitation, since the PCI specification requires the configuration software to move the EPROM contents into shadow memory and execute the code at that location. Reserved <15:1> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Reading will return '0's. SUBSYSID Subsystem ID Address 2Ch (CS) RO; 4Ch (CS) WO Attributes BYTE/WORD/DWORD, STATIC subsysid subsysvid | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ### subsysvid <15:0> Subsystem Vendor ID. This field is reset with the value that is found in word location 0078h (128 bytes ROM used), or 7FF8h of the BIOS ROM (32K ROM used), or at word location FFF8h of the BIOS ROM (64K ROM used). It indicates a subsystem vendor ID as provided by the PCI Special Interest Group to the manufacturer of the add-in board which contains the Matrox G400 chip. # subsysid <31:16> Subsystem ID. This field is reset with the value that is found in word location 007Ah (128 bytes ROM used), at word location 7FFAh of the BIOS ROM (32K ROM used), or at word location FFFAh of the BIOS ROM (64K ROM used). It indicates a subsystem ID as determined by the manufacturer of the add-in board which contains the Matrox G400 chip. - Note: If the bios boot strap is '0', this may mean that no ROM, or a small ROM, is present (usually on a motherboard implementation). If no ROM is present, the value found on the register will be incorrect. In this case, the system bios must write the correct values to this register (at location 4Ch) after the delay following a hard reset. - ► Note: This register must contain all zeros if the manufacturer of the add-in board does not have a subsystem vendor ID, or if the manufacturer does not wish to support the SUBSYSID register. - •• Note: There will be a delay following a hard reset before this register is initialized. For a small serial eeprom, this delay is 50μs. For a big serial eeprom, this delay is 15μs. - •• *Note:* Writing to addresses FFF8h to FFFBh is supported for 128 bytes, 32k ROM and 64k ROM. (If the address is bigger than the size of the ROM, it is wrapped around). ### 3.1.2 Power Graphic Mode Memory Space Registers Power Graphic Mode register descriptions contain a (double-underlined) main header which indicates the register's mnemonic abbreviation and full name. Below the main header, the memory address (1C00h, for example), attributes, and reset value for the register are provided. Next, an illustration identifies the bit fields, which are then described in detail underneath. Reserved fields are identified by black underscore bars; all other fields display alternating white and gray bars. | Sample Power Graphic Mode Memory Space Register | | | SAMPLE_PG | |-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|------------------------------| | Address | <value></value> | | <u> </u> | | Attributes | R/W | | Main header | | Reset Value | <value></value> | | Walli Headel | | | field3 | | / Underscore bars | | Reserved | field3 ≔ | field1 | | | 31 30 29 28 27 | 26 25 24 23 22 2 | 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 | 7 6 5 4 3 2 1 0 | | field1<br><22:0> | Field 1. Details comprises bits | ed description of the <b>field1</b> field of the <b>SAMPI</b> 22 to 0. | <b>LE_PG</b> register, which | | | ◆ <i>Note:</i> The f | Font and case changes which indicate a register | or field in the text. | | field2<23> | Field 2. Detailed description of <b>field2</b> in <b>SAMPLE_PG</b> , which is bit 23. | | | | field3<br><26:24> | Field 3. Detailed description of the <b>field3</b> field of the <b>SAMPLE_PG</b> register, which comprises bits 26 to 24. | | | | Reserved <31:27> | Reserved. When writing to this register, the bits in this field <i>must</i> be set to '0'. (Reserved registers always appear at the end of a register description.) | | | ### **Memory Address** The addresses of all the Power Graphic Mode registers are provided in Chapter 2. **Note:** MEM indicates that the address lies in the memory space; IO indicates that the address lies in the I/O space. ### **Attributes** The Power Graphic Mode attributes are: | • RO | There are no writable bits. | | |------------|--------------------------------------------------------------------------|--| | • WO: | The state of the written bits cannot be read. | | | • R/W: | The state of the written bits can be read. | | | • BYTE: | 8-bit access to the register is possible. | | | • WORD: | 16-bit access to the register is possible. | | | • DWORD: | 32-bit access to the register is possible. | | | • STATIC: | The contents of the register will <i>not</i> change during an operation. | | | • DYNAMIC: | The contents of the register might change during an operation. | | | • FIFO: | Data written to this register will pass through the BFIFO. | | ### **Reset Value** Here are some of the symbols that appear as part of a register's reset value. Most bits are reset on hard reset. Some bits are also reset on soft reset, and they are underlined when they appear in the register description headers. Alpha CTRL ALPHACTRL Address MGABASE1 + 2C7Ch (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value 0000 0000 0000 0000 0000 0000 0001b | | Re | ese | erve | ed | | 9 | alpilasei | | | | atı | ref | | | | atı | no | de | aten | astipple | Reserved | phomedale | pilailiou<br>m | ds | stbl | len | df | sr | cbl | lene | df | | |----|----|-----|------|----|----|----|-----------|----|----|----|-----|-----|----|----|----|-----|----|----|------|----------|----------|-----------|----------------|----|------|-----|----|----|-----|------|----|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | srcblendf <3:0> Source Blend Function. | srcblendf | source blending function | |----------------|--------------------------| | ,0000, | ZERO | | '0001' | ONE | | '0010' | DST_COLOR | | '0011' | ONE_MINUS_DST_COLOR | | '0100' | SRC_ALPHA | | '0101' | ONE_MINUS_SRC_ALPHA | | <b>'</b> 0110' | DST_ALPHA | | '0111' | ONE_MINUS_DST_ALPHA | | '1000' | SRC_ALPHA_SATURATE | **►►** *Note:* To disable alpha blending, **srcblendf** must be programmed with 1 and **dstblendf** with 0. **►♦** *Note:* When using **SRC\_ALPHA\_SATURATE**, **dstblendf** *must not* be programmed to 0. dstblendf <7:4> Destination Blend Function. | dstblendf | destination blending function | |----------------|-------------------------------| | '0000' | ZERO | | '0001' | ONE | | '0010' | SRC_COLOR | | '0011' | ONE_MINUS_SRC_COLOR | | '0100' | SRC_ALPHA | | '0101' | ONE_MINUS_SRC_ALPHA | | <b>'</b> 0110' | DST_ALPHA | | '0111' | ONE MINUS DST ALPHA | ALPHACTRL Alpha CTRL alphamode <9:8> Select the alpha mode that will be written in the frame buffer. | alphamode | description | |-------------|-----------------------------------------------| | '00' | FCOL | | '01' | alpha channel | | '10' | video alpha (1-((1-SrcAlpha) * (1-DstAlpha))) | | <b>'11'</b> | RSVD | ◆ *Note:* When using video alpha, **dstblendf** *must not* be programmed to zero. ◆ *Note:* Video alpha *must not* be used when **astipple** = '1'. astipple <11> Alpha Stipple Mode. Approximation of alpha blending using a dithering matrix. When the alpha stipple mode is selected, only the following Src and Dst function combinations are supported: | Src function | Dst function | screen-door mask | |---------------------|---------------------|----------------------------| | ZERO | ONE | 100% opaque mask | | ONE | ZERO | 0% mask | | SRC_ALPHA | ONE_MINUS_SRC_ALPHA | src_alpha% opaque mask | | ONE_MINUS_SRC_ALPHA | SRC_ALPHA | (1-src_alpha)% opaque mask | aten <12> Alpha Test Enable. Enables the first alpha test. atmode <15:13> Alpha Test Mode. Update the pixel when the alpha test comparison with **atref** is true. | atr | node | | |--------------|----------|------------------| | Value | Mnemonic | Pixel Update | | '000' | NOACMP | Always | | '001' | | Reserved | | '010' | AE | When alpha is = | | '011' | ANE | When alpha is <> | | '100' | ALT | When alpha is < | | '101' | ALTE | When alpha is <= | | '110' | AGT | When alpha is > | | <b>'111'</b> | AGTE | When alpha is >= | atref <23:16> Alpha Test Reference. Reference value for the alpha test. Alpha CTRL ALPHACTRI alphasel <25:24> Alpha Select. Determine the alpha for the pixel. | alphasel | description | |-------------|---------------------------------| | '00' | alpha from texture | | '01' | diffused alpha | | '10' | modulated alpha | | <b>'11'</b> | transparency? 0: diffused alpha | ► Note: Alpha testing is done in *two* separate places. Both use the same reference value (atRef) and alpha test mode (atMode). The first test is done right after texture filtering and can be disabled by setting the 'atEn' bit to '0', or by setting 'atmode' to "ALWAYS". The second test is done before alpha blending and can be disabled by programming 'atmode' to "ALWAYS". #### Reserved #### <10> <31:26> - Note: This register can be set in broadcast mode. For more details see the definition of TEXCTL2.map1, TEXWIDTH.map1, or TEXHEIGHT.map1. - •• Note: The first alpha test can be different for each texture in the pipeline, but the second alpha test is done after the texture blending stage and has a singe value for all programming passes. (For further information see Chapter 4: Programmer's Specification). ALPHASTART Alpha Start Address MGABASE1 + 2C70h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved alphastart | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| alphastart <23:0> Alpha Start Register. This field holds a signed 9.15 value in two's complement notation. For 3D primitives, the **ALPHASTART** register is used to scan the left edge of the trapezoid for the alpha component of the source. This register must be initialized with its starting alpha value. Reserved <31:24> Alpha X Inc ALPHAXING Address MGABASE1 + 2C74h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved alphaxinc | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| alphaxinc <23:0> Alpha X Increment register. this field holds a signed 9.15 value in two's complement notation. For 3D primitives, the **ALPHAXINC** register holds the alpha increment along the x axis. Reserved <31:24> ALPHAYINC Alpha Y Inc Address MGABASE1 + 2C78h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved alphayinc | ı | | | | | | | | | | | | | | | | | | | | | | | | | | | | | _ | | | | |---|----|----|----|----|----|----|----|----|-----|----|-----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|---|---|-----|-----|-----|-----|---| | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 123 | 22 | 121 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 17 | 6 | 5 | 1 4 | - 3 | 1 2 | 1 1 | 0 | | ۱ | | | | | | | | | | | | | | | | | | | | | | | - | - | | - | _ | | _ | _ | _ | - | alphayinc <23:0> Alpha ALU register 2. This field holds a signed 9.15 value in two's complement notation. For 3D primitives, the **ALPHAYINC** register holds the alpha increment along the y- axis. Reserved <31:24> Address MGABASE1 + 1C60h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved ar0 | ? | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ar0 <21:0> Address register 0. The **ar0** field is an 22-bit signed value in two's complement notation. - For AUTOLINE, this register holds the x end address (in pixels). See the **XYEND** register on page 3-280. - For LINE, it holds 2 x 'b'. - For a filled trapezoid, it holds 'dYl'. - For a BLIT, **ar0** holds the line end source address (in pixels). - for sub-pixel trapezoids, it holds 'dYl' on an 18-bit signed value in two's complement notation (1/16 Or 1/32 precision). Reserved <31:22> Address MGABASE1 + 1C64h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved ar1 | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ar1 <23:0> Address register 1. The **ar1** field is a 24-bit signed value in two's complement notation. This register is also loaded when **ar3** is accessed. - For LINE, it holds the error term (initially 2 x 'b' 'a' [sdy]). - This register does *not* need to be loaded for AUTOLINE. - For a filled trapezoid, it holds the error term in two's complement notation; initially: 'errl' = $$[sdxl]$$ ? 'dXl' + 'dYl' - 1 : -'dXl' - For a BLIT, **ar1** holds the line start source address (in pixels). Because the start source address is also required by **ar3**, and because **ar1** is loaded when writing **ar3** this register doesn't need to be explicitly initialized. - This register is used during sub-pixel trapezoids, but does *not* need to be initialized. ## Reserved <31:24> Address MGABASE1 + 1C68h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved ar2 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ar2 <21:0> Address register 2. The **ar2** field is an 22-bit signed value in two's complement notation. - For AUTOLINE, this register holds the y end address (in pixels). See the **XYEND** register on page 3-280. - For LINE, it holds the minor axis error increment (initially 2 x 'b' 2 x 'a'). - For a filled trapezoid, it holds the minor axis increment (-|dXl|). - For sub-pixel trapezoids, it holds 'dXl' in an 18-bit signed value in two's complement notation (1/16 or 1/32 precision). Reserved <31:22> Address MGABASE1 + 1C6Ch (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved spage ar3 | 31 | 1 3 | 80 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ar3 <23:0> Address register 3. The **ar3** field is a 24-bit signed value in two's complement notation or a 24-bit unsigned value. - This register is used during AUTOLINE, but does not need to be initialized. - This register is *not* used for LINE without auto initialization, *nor* is it used by TRAP. - In the two-operand Blit algorithms and ILOAD **ar3** contains the source current address (in pixels). This value must be initialized as the starting address for a Blit. The source current address is always linear. spage <26:24> These three bits are used as an extension to **ar3** in order to generate a 27-bit source or pattern address (in pixels). They are *not* modified by ALU operations. In BLIT operations, the spage field is only used with monochrome source data. The **spage** field is *not* used for TRAP, LINE or AUTOLINE operations. Reserved <31:27> Address MGABASE1 + 1C70h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved ar4 | ĺ | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2. | 1 | 0 | |---|-----|----|----|----|-----|----|----|-------|----|----|----|----|----|-------|-----|-----|----|----|----|----|----|----|---|---|-----|---|---|---|---|----|---|---| | | - 1 | -0 | | | - ' | | | ı – · | | | | -0 | | 1 - 0 | - ' | - 0 | 10 | | 13 | | | -0 | | | ı ′ | | | | | _ | - | 1 | ar4 <21:0> Address register 4. The **ar4** field is an 22-bit signed value in two's complement notation. • For TRAP, it holds the error term. Initially: 'errr' = $$[sdxr]$$ ? 'dXr' + 'dYr' - 1 : -'dXr' - This register is used during AUTOLINE, but doesn't need to be initialized. - This register is *not* used for LINE or BLIT operations without scaling. - This register is used during sub-pixel trapezoids, but does *not* need to be initialized. Reserved <31:22> Address MGABASE1 + 1C74h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved ar5 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ar5 <21:0> Address register 5. The **ar5** field is an 22-bit signed value in two's complement notation. - At the beginning of AUTOLINE, **ar5** holds the x start address (in pixels). See the **XYSTRT register on page 3-281**. At the end of AUTOLINE the register is loaded with the x end, so it is not necessary to reload the register when drawing a polyline. - This register is *not* used for LINE without auto initialization. - For TRAP, it holds the minor axis increment (-|dXr|). - In BLIT algorithms, **ar5** holds the pitch (in pixels) of the source operand. A negative pitch value specifies that the source is scanned from bottom to top while a positive pitch value specifies a top to bottom scan. - For sub-pixel trapezoids, it holds 'dXr' in an 18-bit signed value in two's complement notation (1/16 or 1/32 precision). Reserved <31:22> Address MGABASE1 + 1C78h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved ar6 | ſ | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ar6 <21:0> Address register 6. This field is an 22-bit signed value in two's complement notation. It is sign extended to 24 bits before being used by the ALU. - At the beginning of AUTOLINE, **ar6** holds the y start address (in pixels). See the **XYSTRT register on page 3-281**. During AUTOLINE processing, this register is loaded with the signed y displacement. At the end of AUTOLINE the register is loaded with the y end, so it is *not* necessary to reload the register when drawing a polyline. - This register is *not* used for LINE without auto initialization. - For TRAP, it holds the major axis increment ('dYr'). - For sub-pixel trapezoids, it holds 'dXr' in an 18-bit signed value in two's complement notation (1/16 or 1/32 notation). Reserved <31:22> Address MGABASE1 + 1C20h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown #### backcol | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | - [ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |---------------------------------------------------------------------------------------|-----|----|----|----|----|----|----|----|----|--|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | | 31 | 30 | 29 | 28 | 26 | 40 | 24 | 23 | | 19 | 18 | 17 | 16 | 15 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | #### **bltcmsk** ## backcol <31:0> Background color. The **backcol** field is used by the color expansion module to generate the source pixels when the background is selected. - In 8 bits/pixel only **backcol**<7:0> is used. - In 16 bits/pixel, only **backcol**<15:0> is used. - In 24 bits/pixel, when not in block mode, **backcol**<31:24> is *not* used. - In 24 bits/pixel, when in block mode, all **backcol** bits are used. Refer to 'Pixel Format' on page 4-21 for the definition of the slice in each mode. ## bltcmsk <31:0> Blit color mask. This field enables blit transparency comparison on a planar basis ('0' indicates a masked bit). Refer to the description of the **transc** field of **DWGCTL** for the transparency equation. - In 8 bits/pixel only **bltcmsk**<7:0> is used. - In 16 bits/pixel, only **bltcmsk**<15:0> is used. Address MGABASE1 + 3D60h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved besa1c3org | 31 | 1 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ## besa1c3org <24:0> Backend Scaler buffer A field 1 Chroma 3-plane Origin. Top left corner of the buffer A field 1 chroma plane data used by the backend scaler. The field **besa1c3org** corresponds to a byte address in memory and holds a 25-bit unsigned value which provides an offset value (the base address) in order to position the first pixel chroma plane data to be read from the buffer A field 1 of the window to scale. This register must be initialized when in planar 4:2:0 format, 3-plane mode, this register is the *Cr* plane origin. ◆ *Note:* This address must be aligned on a paragraph boundary when no horizontal mirror is used (the 4 LSBs must be set to '0000') and on the last byte of a paragraph when horizontal mirror is used (the 4 LSBs must be set to '1111'). ## Reserved <31:25> Address MGABASE1 + 3D10h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved besa1corg | 3 | 1 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ## besa1corg <24:0> Backend Scaler buffer A field 1 Chroma plane Origin. Top left corner of the buffer A field 1 chroma plane data used by the backend scaler. The field **besa1corg** corresponds to a byte address in memory and holds a 25-bit unsigned value which provides an offset value (the base address) in order to position the first pixel chroma plane data to be read from the buffer A field 1 of the window to scale. This register must be initialized when in planar 4:2:0 format. In 4:2:0, 2-plane mode, this register is the chroma plane origin. In 4:2:0, 3-plane mode, this register is the *Cb* plane origin. ◆ *Note:* This address must be aligned on a paragraph boundary when no horizontal mirror is used (the 4 LSBs must be set to '0000') and on the last byte of a paragraph when horizontal mirror is used (the 4 LSBs must be set to '1111'). ## Reserved <31:25> Address MGABASE1 + 3D00h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved besa1org | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ## besa1org <24:0> Backend Scaler buffer A field 1 Origin. Top left corner of the buffer A field 1 data used by the backend scaler. The field **besa1org** corresponds to a byte address in memory and it holds a 25-bit unsigned value which provides an offset value (the base address), in order to position the first pixel to read of the buffer A field 1 of the window to scale. In 4:2:0 mode, this register is the luma plane origin. ► Note: This address must be aligned on a paragraph boundary when no horizontal mirror is used (the 4 LSBs must be set to '0000'), and on the last byte of a paragraph when horizontal mirror is used (the 4 LSBs must be set to '1111'). ## Reserved <31:25> Address MGABASE1 + 3D64h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved besa2c3org | ĺ. | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ## besa2c3org <24:0> Backend Scaler buffer A field 2 Chroma 3-plane Origin. Top left corner of the buffer A field 2 chroma plane data used by the backend scaler. The field **besa2c3org** corresponds to a byte address in memory and holds a 25-bit unsigned value which provides an offset value (the base address) in order to position the first pixel chroma plane data to be read from the buffer A field 2 of the window to scale. This register must be initialized when in planar 4:2:0 format, 3-plane mode, this register is the *Cr* plane origin. ◆ *Note:* This address must be aligned on a paragraph boundary when no horizontal mirror is used (the 4 LSBs must be set to '0000') and on the last byte of a paragraph when horizontal mirror is used (the 4 LSBs must be set to '1111'). ## Reserved <31:25> Address MGABASE1 + 3D14h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved besa2corg | | | | | 7 | - | | | | 22 | - | - | | | | | | | | | | | - | _ | | - | - | | - | - | , | | |-----|----|----|----|----|----|-----|----|----|------|----|----|----|----|----|----|----|----|----|----|-----|----|---|-----|---|---|---|---|----|----|-----|-----| | 131 | 30 | 29 | 28 | 27 | 26 | 2.5 | 24 | 23 | 122. | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 111 | 10 | 9 | - 8 | 7 | 6 | 5 | 4 | 13 | 2. | 1 1 | () | | - | | | | | | | | | | | | | | | | | | | | | | _ | - | | - | _ | | _ | _ | _ | - 1 | ## besa2corg <24:0> Backend Scaler buffer A field 2 Chroma plane Origin. Top left corner of the buffer A field 2 chroma plane data used by the backend scaler. The field **besa2corg** corresponds to a byte address in memory and holds a 25-bit unsigned value which provides an offset value (the base address) in order to position the first pixel chroma plane data to be read from the buffer A field 2 of the window to scale. This register must be initialized when in planar 4:2:0 format. In 4:2:0, 2-plane mode, this register is the chroma plane origin. In 4:2:0, 3-plane mode, this register is the *Cb* plane origin. Note: This address must be aligned on a paragraph boundary when no horizontal mirror is used (the 4 LSBs must be set to '0000') and on the last byte of a paragraph when horizontal mirror is used (the 4 LSBs must be set to '1111'). ## Reserved <31:25> Address MGABASE1 + 3D04h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved besa2org | 31 | 1 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ## besa2org <24:0> Backend Scaler buffer A field 2 Origin. Top left corner of the buffer A field 2 data used by the backend scaler. The field **besa2org** corresponds to a byte address in memory and holds a 25-bit unsigned value which provides an offset value (the base address) in order to position the first pixel to be read from the buffer A field 2 of the window to scale. In 4:2:0 mode, this register is the luma plane origin. ◆ *Note:* This address must be aligned on a paragraph boundary when no horizontal mirror is used (the 4 LSBs must be set to '0000') and on the last byte of a paragraph when horizontal mirror is used (the 4 LSBs must be set to '1111'). ## Reserved <31:25> Address MGABASE1 + 3D68h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved besb1c3org | Ī | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ### besb1c3org <24:0> Backend Scaler buffer B field 1 Chroma 3-plane Origin. Top left corner of the buffer B field 1 chroma plane data used by the backend scaler. The field **besb1c3org** corresponds to a byte address in memory and holds a 25-bit unsigned value which provides an offset value (the base address) in order to position the first pixel chroma plane data to be read from the buffer B field 1 of the window to scale. This register must be initialized when in planar 4:2:0 format, 3-plane, this register is the *Cr* plane origin. ◆ *Note:* This address must be aligned on a paragraph boundary when no horizontal mirror is used (the 4 LSBs must be set to '0000') and on the last byte of a paragraph when horizontal mirror is used (the 4 LSBs must be set to '1111'). ## Reserved <31:25> Address MGABASE1 + 3D18h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved besb1corg | 3 | 1 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ## besb1corg <24:0> Backend Scaler buffer B field 1 Chroma plane Origin. Top left corner of the buffer B field 1 chroma plane data used by the backend scaler. The field **besb1corg** corresponds to a byte address in memory and holds a 25-bit unsigned value which provides an offset value (the base address) in order to position the first pixel chroma plane data to be read from the buffer B field 1 of the window to scale. This register must be initialized when in planar 4:2:0 format. In 4:2:0, 2-plane mode, this register is the chroma plane origin. In 4:2:0, 3-plane mode, this register is the *Cb* plane origin. ◆ *Note:* This address must be aligned on a paragraph boundary when no horizontal mirror is used (the 4 LSBs must be set to '0000') and on the last byte of a paragraph when horizontal mirror is used (the 4 LSBs must be set to '1111'). ## Reserved <31:25> Address MGABASE1 + 3D08h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved besb1org | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ## besb1org <24:0> Backend Scaler buffer B field 1 Origin. Top left corner of the buffer B field 1 data used by the backend scaler. The field **besb1org** corresponds to a byte address in memory and holds a 25-bit unsigned value which provides an offset value (the base address) in order to position the first pixel to be read from the buffer B field 1 of the window to scale. In 4:2:0 mode, this register is the luma plane origin. ◆ *Note:* This address must be aligned on a paragraph boundary when no horizontal mirror is used (the 4 LSBs must be set to '0000') and on the last byte of a paragraph when horizontal mirror is used (the 4 LSBs must be set to '1111'). ## Reserved <31:25> Address MGABASE1 + 3D6Ch (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved besb2c3org | | | • | • | • | 27 | • | | | | 22 | | • | 4.0 | 10 | - | | | | | | | 4.0 | | | - | , | _ | | • | _ | , | | |------|-----|----|----|----|----|----|----|----|----|-----|----|----|-----|----|----|----|----|----|----|----|----|-----|---|-----|---|---|---|---|---|---|---|---| | - 13 | 311 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | ,,, | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | - 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ## besb2c3org <24:0> Backend Scaler buffer B field 2 Chroma 3-plane Origin. Top left corner of the buffer B field 2 chroma plane data used by the backend scaler. The field **besb2c3org** corresponds to a byte address in memory and holds a 25-bit unsigned value which provides an offset value (the base address) in order to position the first pixel chroma plane data to be read from the buffer B field 2 of the window to scale. This register must be initialized when in planar 4:2:0 format, 3-plane, this register is the *Cr* plane origin. ◆ *Note:* This address must be aligned on a paragraph boundary when no horizontal mirror is used (the 4 LSBs must be set to '0000') and on the last byte of a paragraph when horizontal mirror is used (the 4 LSBs must be set to '1111'). ## Reserved <31:25> Address MGABASE1 + 3D1Ch (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved besb2corg | | | | | 7 | - | | | | 22 | - | - | | | | | | | | | | | - | _ | | - | - | | - | - | , | | |-----|----|----|----|----|----|-----|----|----|------|----|----|----|----|----|----|----|----|----|----|-----|----|---|-----|---|---|---|---|----|----|-----|-----| | 131 | 30 | 29 | 28 | 27 | 26 | 2.5 | 24 | 23 | 122. | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 111 | 10 | 9 | - 8 | 7 | 6 | 5 | 4 | 13 | 2. | 1 1 | () | | - | | | | | | | | | | | | | | | | | | | | | | _ | - | | - | _ | | _ | _ | _ | - 1 | ## besb2corg <24:0> Backend Scaler buffer B field 2 Chroma plane Origin. Top left corner of the buffer B field 2 chroma plane data used by the backend scaler. The field **besb2corg** corresponds to a byte address in memory and holds a 25-bit unsigned value which provides an offset value (the base address) in order to position the first pixel chroma plane data to be read from the buffer B field 2 of the window to scale. This register must be initialized when in planar 4:2:0 format. In 4:2:0, 2-plane mode, this register is the chroma plane origin. In 4:2:0, 3-plane mode, the register is the *Cb* plane origin. ◆ *Note:* This address must be aligned on a paragraph boundary when no horizontal mirror is used (the 4 LSBs must be set to '0000') and on the last byte of a paragraph when horizontal mirror is used (the 4 LSBs must be set to '1111'). ## Reserved <31:25> Address MGABASE1 + 3D0Ch (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved besb2org | 31 | 1 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| ## besb2org <24:0> Backend Scaler buffer B field 2 Origin. Top left corner of the buffer B field 2 data used by the backend scaler. The field **besb2org** corresponds to a byte address in memory and holds a 25-bit unsigned value which provides an offset value (the base address) in order to position the first pixel to be read from the buffer B field 2 of the window to scale. In 4:2:0 mode, this register is the luma plane origin. ◆ *Note:* This address must be aligned on a paragraph boundary when no horizontal mirror is used (the 4 LSBs must be set to '0000') and on the last byte of a paragraph when horizontal mirror is used (the 4 LSBs must be set to '1111'). # Reserved <31:25> BES Control BESCT Address MGABASE1 + 3D20h (MEM) Attributes R/W, STATIC, BYTE, WORD, DWORD **Reset Value** ???? ???0 ???? ???? ???? ???? ???? | | | I | Re | ser | ve | d | | 900 | bestsel | | besfselm | | Recerved | מאפו | besblank | besbwen | beshmir | besdith | bes420pl | pescups | | Reserved | | beshfixc | besvfen | beshfen | 2 | บ | besv2srcstp | besv1srcstp | ĺ | Res | ser | ved | ľ | besen | |-------------------------------------------------------------------------------------|---|---|----|-----|----|---|-----|-----|---------|----|----------|---|----------|------|----------|---------|---------|---------|----------|---------|----|----------|----|----------|---------|---------|---|---|-------------|-------------|---|-----|-----|-----|---|-------| | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 3 | 1 | 30 | 29 | 28 | 2 | 2.7 | 26 | 12 | 25 | 24 | 2 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | besen <0> Backend Scaler Enable. • 0: The backend scaler is disabled • 1: The backend scaler is enabled besv1srcstp Backend Scaler field 1 vertical source start polarity. <6> • 0: source start line is even • 1: source start line is odd besv2srcstp Backend Scaler field 2 vertical source start polarity. <7> • 0: source start line is even • 1: source start line is odd beshfen <10> Backend Scaler Horizontal Filtering Enable. • 0: The horizontal filtering is disabled •Drop algorithm is used in downscaling and replicated in upscaling. • 1: The horizontal filtering is enabled (*only* when horizontal scaling is performed). • Interpolation algorithm is used besvfen <11> Backend Scaler Vertical Filtering Enable. • 0: The vertical filtering is disabled • Drop algorithm is used in downscaling and replicated in upscaling. • 1: The vertical filtering is enabled (*only* when vertical scaling is performed) • Interpolation algorithm is used. beshfixc <12> Backend Scaler Horizontal Fixed Coefficient. Forces the horizontal weight to 0.5 for the interpolation regardless of the actual calculated weight. • 0: The horizontal actual calculated weight is used for interpolation. • 1: The horizontal fixed coefficient is used for interpolation bescups <16> Backend Scaler Chroma Upsampling enable. Horizontally interpolates a new chroma value with a fixed coefficient of 0.5 in between each sample pair. • 0: Chroma upsampling is disabled • 1: Chroma upsampling is enabled bes420pl <17> Backend Scaler 4:2:0 Planar data format. • 0: The source data is in 4:2:2 format • 1: The source data is in 4:2:0 format **BES Control** BESCTL #### besdith <18> Backend Scaler Dither enable. Dithering is applied to smooth out some nonlinearities. - 0: Dithering is disabled - 1: Dithering is enabled ### beshmir <19> Backend Scaler Horizontal Mirror enable. The source data is read linearly with descendant addressing instead of ascendant. Origin registers must point to the latest pixel of the line instead of the first. Address origins must be aligned on a paragraph boundary when no horizontal mirror is used (the 4 LSBs must be set to '0000') and on the last byte of the paragraph when horizontal mirror is used (the 4 LSBs must be set to '1111'). - 0: The horizontal mirror is disabled - 1: The horizontal mirror is enabled #### besbwen <20> Backend Scaler Black and White enable. This bit forces both chromas to 128. - 0: window is in color - 1: window is in black and white ### besblank <21> Backend Scaler Blanking enable. When blanking is applied, the image in the window becomes black. - 0: Blanking is disabled - 1: Blanking is enabled ### besfselm Backend Scaler Field Select Mode. <24> - 0: Software field select - 1: Hardware automatic field select is triggered and selected by the video in port. ### besfsel Backend Scaler Field Select. In software field select mode only. ### <26:25> - '00': Buffer A field 1 is displayed • '01': Buffer A field 2 is displayed - '10': Buffer B field 1 is displayed • '11': Buffer B field 2 is displayed #### Reserved #### <31:27> <23:22> <15:13> <9:8><5:1> Address MGABASE1 + 3DC0h (MEM) Attributes R/W, STATIC, BYTE, WORD, DWORD **Reset Value** ???? ???? ???? ???? 0000 0000 0?00 | Reserved | | | | b | es | vcr | nt | | | | | ĺ | Res | serv | vec | ł | besvcbcrsingle | 2 | | besprocamp | besuyvyfmt | bes3plane | besreghup | bescorder | Reserved | beshzoomf | beshzoom | |--------------|-------|-----|----|----|----|-----|----|----|----|----|----|------|------|-------|-----|------|----------------|------|---|------------|------------|-----------|-----------|-----------|----------|-----------|----------| | 31 30 29 28 | 27 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | beshzoom <0> | | Bac | | | | | | | | | хΗ | oriz | zoni | tal 2 | Zoc | om ( | ena | ble. | M | ust | be 1 | use | d w | hen | the | e pi | xel | - 0: Accelerated 2x horizontal zoom is disabled 1: Accelerated 2x horizontal zoom is enabled - beshzoomf <1> Backend Scaler accelerated 2x Horizontal Zoom filtering enable. Enables the interpolation of the new pixels for the accelerated 2x mode. - 0: Accelerated 2x horizontal zoom filtering is disabled 1: Accelerated 2x horizontal zoom filtering is enabled - bescorder <3> Backend Scaler Chroma samples Order (4:2:0 mode only). - 0: Cb samples are in bytes 0, 2, 4, 6 of the slice and Cr in 1, 3, 5, 7 1: Cb samples are in bytes 1, 3, 5, 7 of the slice and Cr in 0, 2, 4, 6 - besreghup <4> Backend Scaler Register Update on Horizontal sync for test. When this bit is set, the backend scaler double buffer registers will take their new values at each horizontal sync. - **◆ Note:** Used for testing *only*. - 0: Registers update at the vertical count programmed in **besvent** - 1: Registers update at each horizontal sync bes3plane <5> Backend Scaler 4:2:0 3-Plane format. - 0: The source data is in 4:2:0 2-plane format1: The source data is in 4:2:0 3-plane format - besuyvyfmt <6> Backend Scaler uyvy format (4:2:2 mode only) 0: YUY2 format is used1: UYVY format is used besprocamp <7> Backend Scaler Proc. Amp. control enable. Enables changes in contrast and brightness. - 0: proc. amp. control is disabled - 1: proc. amp. control is enabled ## besrgbmode <9:8> Backend Scaler RGB mode. Enables the composition of an RGB surface by the backend scaler. To use the backend scaler in RGB mode, it must first be programmed in 4:2:2. The mirroring function is not available. - '00': RGB disable - '01': RGB15 enable (1:5:5:5), 1 msb unused, scaling available with no filtering - '10': RGB16 enable (5:6:5), scaling available with no filtering - '11': RGB32 enable (8:8:8:8), 8 msb unused, hiscale must be programmed to 2.0 and no scaling available. Source width is limited to 512. ### bes vcbcrsingle <10> Backend Scaler Vertical CBCR Single. Disables the repetition of a cbcr for 2 luma lines. - 0: Each cbcr line is used for 2 luma lines in 4:2:0 mode - 1: each cbcr line is used for a single luma line in 4:2:0 mode # besvcnt <27:16> Backend Scaler Vertical Counter registers update. All backend scaler registers will take effect with their new programmed values when the CRTC vertical counter equals this register. ### Reserved <31:28> <15:11> <2> Address MGABASE1 + 3D28h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD | | Re | ser | vec | ł | | | | | be | esle | eft | | | | | ļ | Res | ser | vec | k | | | | | be | sriç | ght | : | | | | |----|-----------|-------------|-----|----|----|-----|-----|------|----|------|------|----|----|----|----|----|-----|-----|-----|----|--------------------|---|------|-----|-----|--------|------|-------|------|----|---| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | bes<br><1 | srig<br>0:0 | • | | , | win | | v ii | th | e de | eskt | | _ | | | | | | | • | | | | | | of the | | | | | 1 | | | be<br><20 | sle<br>6:1 | | | | | | | | | | | _ | | | | | | | • | xel<br>i <b>gh</b> | | ordi | nat | e o | f the | e de | estir | nati | on | | | | Res | er۱ | /ed | | | <3 | 1:2 | 7> | <1 | 5:1° | 1> | | | | | | | | | | | | | | | | | | | | | Address MGABASE1 + 3D30h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved beshiscal | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | **beshiscal** Backend Scaler Horizontal Inverse Scaling factor. This is a 5.14 value. (For information on calculating this field, see Chapter 4: Programmer's Specification). Reserved <31:21> <1:0> èd Address MGABASE1 + 3D3Ch (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown | | R | ese | erve | ed | | | | | | | | | | | | bes | shs | rce | end | | | | | | | | | | | Door | | |----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|-----|-----|----|----|---|---|---|---|---|---|---|---|------|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | beshsrcend <25:2> Backend Scaler Horizontal Ending source position. Ending position in the source of the last pixel that will contribute to the last right destination pixel. This is a 10.14 value. (For information on calculating this field, see Chapter 4: Programmer's Specification). Reserved <31:26> <1:0> Address MGABASE1 + 3D50h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown | | F | Res | erv | ed | | | | | be | sh | src | Ist | | | | | | | | | | R | ese | erve | ed | | | | | | | |---|-------|-----|-----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|---|-----|------|----|---|---|---|---|---|---| | 3 | 31 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | beshsrclst <25:16> Backend Scaler Horizontal Source Last position. Position in the source of the last pixel of the complete image. This field must be programmed with horizontal source width - 1. Reserved <31:26> <15:0> Address MGABASE1 + 3D38h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved beshsrcst | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | beshsrcst <25:2> Backend Scaler horizontal starting source position. Starting position in the source of the first pixel that will contribute to the left first destination pixel. This is a 10.14 value. Must be '0' when no left cropping is necessary. The cropping can be on the source, because a part of the destination is not visible or is on both. Reserved <31:26> <1:0> Address MGABASE1 + 3D40h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown | | | R | ese | erve | ed | | | | b | esk | orig | jhti | nes | S | | | | R | ese | erve | ed | | | | | bes | SCO | ntr | ast | | | | |----|----|----|-----|------|----|----|----|----|----|-----|------|------|-----|----|----|----|----|----|-----|------|----|---|---|---|---|-----|-----|-----|-----|---|---|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bes brightness <23:16> Backend Scaler Brightness value. This is an 8-bit two's complement value ranging from -128 to 127. '00'h has no effect. bescontrast Backend Scaler Contrast value. This is a 1.7 value ranging from 0 to 1.99. '80'h has **<7:0>** no effect. Reserved <31:24> <15:8> **BES Pitch BESPITCH** **Address** MGABASE1 + 3D24h (MEM) **Attributes** WO, STATIC, BYTE, WORD, DWORD **Reset Value** unknown > Reserved bespitch | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| bespitch <11:0> Backend Scaler Pitch. Offset from the beginning of one line to the next from the field currently read for the source data window (in number of pixels). Must be a multiple of 8 in 4:2:2 format and multiple of 32 in 4:2:0 planar format. Reserved Reserved. When writing to this register, the bits in this field *must* be set to '0'. <31:12> BESSTATUS BES Status Address MGABASE1 + 3DC4h (MEM) Attributes RO, DYNAMIC, BYTE, WORD, DWORD Reset Value unknown ### Reserved | 3 | 1 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| besstat <1:0> Backend Scaler Status. '00': window is currently displaying buffer A field 1 '01': window is currently displaying buffer A field 2 • '10': window is currently displaying buffer B field 1 • '11': window is currently displaying buffer B field 2 Reserved Reserved. When reading this register, the bits in this field will return unknown, '0', or **<31:2>** '1'. Address MGABASE1 + 3D54h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown Reserved besv1srclast | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| besv1 Backend Scaler field 1 vertical source last position. The position of the last line (of the srclast complete image) in the source, in reference to the line pointed to by the window field **<9:0>** 1 origin. **Reserved**. When writing to this register, the bits in this field *must* be set to 0. <31:10> Address MGABASE1 + 3D58h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown | src | S | t | |-----|-----|-------| | | src | srcis | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| besv2srclst <9:0> Backend Scaler field 2 Vertical Source Last position. The position of the last line (of the complete image) in the source, in reference to the line pointed to by the window field 2 origin. Reserved <31:10> **Address** MGABASE1 + 3D48h (MEM) **Attributes** WO, STATIC, BYTE, WORD, DWORD **Reset Value** unknown Reserved Reserved besv1wght 19 18 17 16 15 14 13 12 11 30 29 28 27 26 | 25 | 24 | 23 21 20 10 9 8 7 6 5 4 3 2 22 1 0 besv1wght <15:2> Backend Scaler field 1 Vertical Weight starting value. This field contains only the 14 bits of the fractional part. Used for a window starting with vertical subpixel positioning and to adjust the positioning of the frame based on the field 1 in de- interlacing mode. bes1wghts Backend Scaler field 1 vertical Weight starting sign. Used for a window starting with a <16> vertical subpixel position and to adjust the positioning of the frame on the field 1 in de-interlacing mode. Reserved <31:17> <1:0> Address MGABASE1 + 3D4Ch (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown | | | | | | ! | Res | ser | ved | d | | | | | | bes2wghts | | | | | | be | sv2 | 2wç | ght | | | | | | Posory | אבים יפר | | |----|----|----|----|----|----|-----|-----|-----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|-----|-----|-----|---|---|---|---|---|--------|----------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | besv2wght <15:2> Backend Scaler field 2 Vertical Weight starting value. This field contains only the 14 bits of the fractional part. Used for a window starting with vertical subpixel positioning and to adjust the positioning of the frame based on the field 2 in deinterlacing mode. bes2wghts <16> Backend Scaler field 2 vertical Weight starting sign. Used for a window starting with vertical subpixel positioning and to adjust the positioning of the frame based on the field 2 in de-interlacing mode. Reserved <31:17> <1:0> Address MGABASE1 + 3D2Ch (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown | Reserved | bestop | Reserved | | k | esbo | ot | | | | |-------------------|------------------------------------------------------------------------------|-------------------|--------|----------|--------|--------|-------|---|----| | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 | 16 15 14 13 12 11 | 10 9 8 | 8 7 6 | 5 5 | 4 3 | 2 | 1 | 0 | | besbot<br><10:0> | Backend Scaler Bottom edge c window in the desktop. Must b vertical desktop. | | | | | | | | on | | bestop<br><26:16> | Backend Scaler Top edge coord window in the desktop. Must be | | | dinate o | of the | destii | natio | n | | | Reserved | <31:27> <15:11> | | | | | | | | | Address MGABASE1 + 3D34h (MEM) Attributes WO, STATIC, BYTE, WORD, DWORD Reset Value unknown | | | | | Re | ser | vec | t | | | | | | | | | | | I | bes | vis | scal | | | | | | | | | 7000 | ה<br>ט | |----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|------|---|---|---|---|---|---|---|---|------|--------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | **besviscal Color:** Backend Scaler Vertical Inverse Scaling. This is a 5.14 value. (For information on calculating this field, see Chapter 4: Programmer's Specification). Reserved <31:21> <1:0> CRTC2 Control C2CT Address MGABASE1 + 3C10h (MEM) Attributes R/W, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 | c2vploaden | c2hploaden | c2vidretmod | Z V [G] | c2fieldpol | c2fieldlength | c2interlace | c2vcbcrsingle | <b>c2</b> | dep | oth | crtcdacsel | | | ı | Res | ser | ved | ı | | | | c2maxhipri | | Reserved | | c2hiprilvl | | c2pixcIkdis | losyloxiaco | 2 | c2en | |------------|------------|-------------|---------|------------|---------------|-------------|---------------|-----------|-----|-----|------------|----|----|----|-----|-----|-----|----|----|----|----|------------|---|----------|---|------------|---|-------------|-------------|---|------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | c2en <0> Second CRTC Enable. Stops the address generator. No new request addresses are generated. It does not affect the programming registers. - 0: Second CRTC disabled - 1: Second CTRC enabled c2pixclksel <2:1> CRTC2 Pixel Clock Selection. This field selects the source of the second CRTC pixel clock. - '00': PCI clock selected - '01': External clock selected (from the VDOCLK pin) - '10': Pixel PLL selected - '11': System PLL selected c2pixclkdis CRTC2 Pixel Clock Disable <3> - 0: Enable the pixel clock oscillations - 1: Disable the pixel clock oscillations c2hiprilvl <6:4> CRTC2 High Priority Request Level. This field indicates the number of requests accumulated in the second CRTC request FIFO when the requests to the memory controller change from low to high priority. c2maxhipri <10:8> CRTC2 Maximum High Priority requests. This field indicates the number of high priority requests to be performed before switching back to low priority. crtcdacsel <20> CRTC DAC source Select. This field selects the DAC source. 0: CRTC1 is output to the DAC1: CRTC2 is output to the DAC c2depth <23:21> CRTC2 Color Depth. The following table shows the color depths available with the C2CTL CRTC2 Control second CRTC and their properties. | c2depth | Color Depth selected | |--------------|-----------------------------------------------------------------| | ,000, | Reserved | | '001' | 15 bits/pixel (15 bpp direct, 1 bit alpha-bit or unused) | | '010' | 16 bits/pixel (16 bpp direct) | | '011' | Reserved | | '100' | 32 bits/pixel (24 bpp direct, 8 bpp of alpha data unused) | | '101' | YCbCr422 (4 Y-samples, 2 Cb-samples, and 2 Cr-samples) | | <b>'110'</b> | Reserved | | <b>'111'</b> | YCbCr420 (4 Y-samples, 1 Cb-sample, and 1 Cr-sample) (3 planes) | c2vcbcr single CRTC2 Vertical CbCr Single. Disables the repetition of a chroma line for 2 luma lines. <24> - '0': Each CbCr line is used for two luma lines in 4:2:0 mode - '1': Each CbCr line is used for a *single* luma line in 4:2:0 mode c2interlace <25> CRTC2 Interlace mode. Enable all the field #1 registers. c2fieldlength <26> CRTC2 Field Length polarity. Selects the polarity of the field length signal according to the VIDRST pin after a video reset. | c2fieldlength | VIDRST Pin State | Field length | |---------------|------------------|--------------| | 0 | 0 | c2vtotal | | U | 1 | c2vtotal + 1 | | 1 | 0 | c2vtotal + 1 | | 1 | 1 | c2vtotal | c2fieldpol <27> Field identification Polarity. Selects the polarity of the field identification (field value in the video timing codes) signal according to the VIDRST pin after video reset. | c2fieldpol | VIDRST Pin State | Field Identification<br>Sate | |------------|------------------|------------------------------| | 0 | 0 | 0 | | U | 1 | 1 | | 1 | 0 | 1 | | 1 | 1 | 0 | CRTC2 Control C2CTL c2vidrstmod <29:28> CRTC2 VIDRST Detection Mode. These bits select the preload detection mode on the VIDRST pin. | c2vidrstmod | VIDRST<br>Detection Mode | |-------------|---------------------------------------------| | '00' | A falling edge is detected. | | '01' | A rising edge is detected | | '10' | Both falling and rising edges are detected. | | <b>'11'</b> | Reserved | c2hploaden <30> CRTC2 Horizontal Counter Preload Enable. This bit enables the preloading capability of the horizontal counter with the VIDRST pin. c2vploaden <31> CRTC2 Vertical Counter Preload Enable. This bit enables the preloading capability of the vertical counter with the VIDRST pin. Reserved <7> <19:11> Address MGABASE1 + 3C4Ch (MEM) Attributes R/W, BYTE/WORD/DWORD, DYNAMIC | | Reserved | | С | 2st | atio | cke | <sub>'</sub> y | | c | 2bp | p <b>1</b> | 5la | lph | na | | | c2 | 2bp | p1 | 5ha | ılph | na | | c2uyvyfmt | c2offsetdiven | c2statickeyer | c2ntscen | c2subpicen | c2cbcrfilten | c2yfilten | c2dithen | | |----|----------|----|----|-----|------|-----|----------------|----|----|-----|------------|-----|-----|----|----|----|----|-----|----|-----|------|----|---|-----------|---------------|---------------|----------|------------|--------------|-----------|----------|--| | | | | | | | I | | | | | I I | | | T | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | c2dithen <0> CRTC2 Dither Enable. Dithering is applied on the luma component to smooth out non-linearities caused by the RGB to YCbCr color space converter. - 0: Dithering is disabled1: Dithering is enabled - c2yfilten <1> CRTC2 Y Filter Enable. Filtering is applied on the luma generated by the color space converter. 1/4: 1/2: 1/4 filtering scheme is used. - 0: Luma filtering is disabled - 1: Luma filtering is enabled c2cbcrfilten <2> CRTC2 CbCr Filter Enable. Filtering is applied before subsampling on the chroma generated by the color space converter. 1/4: 1/2: 1/4 filtering scheme is used. - 0: Subsample Cb and Cr - 1: Filter Cb and Cr before subsampling c2subpicen <3> CRTC2 Sub-picture Enable. Sub-picture data is applied on the output of the second CRTC. - 0: Sub-picture blender is disabled - 1: Sub-picture blender is enabled c2ntscen <4> CRTC2 NTSC Enable. This bit controls a clock killer circuit used to generate the exact horizontal pixel count in NTSC (*not* divisible by 8). - 0: NTSC clock killer circuitry is disabled - 1: NTSC clock killer circuitry is enabled c2static keyen <5> CRTC2 Static sub-picture mixing Key Enable. Static sub-picture mixing key (**c2statickey**) is applied on the sub-picture blender of the second CRTC. - 0: Sub-picture key from the frame buffer is used by the sub-picture blender - 1: Static sub-picture mixing key is used by the sub-picture blender c2offsetdiven <6> CRTC2 Sub-picture Offset Division. Selects the offset of the sub-picture data in the frame buffer. - 0: Use the **c2offset** field directly - 1: Use the **c2offset** field divided by two c2uyvyfmt <7> CRTC2 YCbCr422 memory Format. Selects the YCbCr422 data format in the frame buffer. | | <ul><li>0: YUV2 format is used</li><li>1: UYVY format is used</li></ul> | |------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | c2bpp15h<br>alpha<br><15:8> | CRTC2 15 bpp High Alpha value. In 15 bpp, the value in this field corresponds to the high alpha bit. | | c2bpp15l<br>alpha<br><23:16> | CRTC2 15 bpp Low Alpha Value. In 15 bpp, the value in this field corresponds to a low alpha bit. | | c2statickey<br><28:24> | CRTC2 Static sub-picture mixing Key. Sub-picture mixing key applied to the second CRTC sub-picture blender when <b>c2statickeyen</b> is enabled; it controls the opacity of the sub-picture. Only binary values between 0 and 16 (between '00000' and '10000') are valid. | | Reserved | Reserved. When writing to this register, the bits in this field <i>must</i> be set to 0. | <31:29> Address MGABASE1 + 3C14h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 | R | ese | erve | ed | | | | | c2l | ndi | spe | end | | | | | R | ese | rve | ed | | | | | С | 2ht | tota | ıl | | | | | | |----|-----|------|----|----|----|----|----|-----|-----|-----|-----|----|----|----|----|----|-----|-----|----|----|----|---|---|---|-----|------|----|---|---|---|---|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | **c2htotal** CRTC2 Horizontal Total. This field defines the total horizontal scan period in pixels. **<11:0>** The 3 LSBs of this field *must* be set to '000' (a multiple of 8 pixels). Programmed with the total number of pixels per line, minus 8. **c2hdispend** CRTC2 Horizontal Display Enable End. This field determines the number of displayed pixels per line. The display enable signal becomes inactive when the horizontal pixel counter reaches this value. The 3 LSBs of this field value *must* be set to '000' (a multiple of 8 pixels). Programmed with the number of displayed pixels per line, minus 8. Reserved <15:12> <31:28> Address MGABASE1 + 3C18h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 | R | ese | erve | ed | | | | | c2h | ısy | nce | end | | | | | R | ese | rve | ed | | | | | c2 | hsy | 'nc | str | | | | | |----|-----|------|----|----|----|----|----|-----|-----|-----|-----|----|----|----|----|----|-----|-----|----|----|----|---|---|----|-----|-----|-----|---|---|---|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | c2hsyncstr <11:0> CRTC2 Start Horizontal Sync pulse. The horizontal sync signal becomes active when the horizontal pixel counter reaches this value. The 3 LSBs of this field value *must* be set to '000' (a multiple of 8 pixels). Programmed with the number of pixels before the beginning of the horizontal sync pulse minus 8 beginning of the horizontal sync. pulse, minus 8. c2hsyncend <27:16> CRTC2 End Horizontal Sync pulse. The horizontal sync signal becomes inactive when the horizontal pixel counter reaches this value. The 3 LSBs of this field value *must* be set to '000' (a multiple of 8 pixels). Programmed with the number of pixels before the end of the horizontal sync. pulse, minus 8. Reserved <15:12> <31:28> | Address | MGABASE1 + | 3C44h | (MEM) | |---------|------------|-------|-------| |---------|------------|-------|-------| Attributes R/W, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 | Reserved | c2vlinecomp | Reserved | c2vsyncpol | c2hsyncpol | Keserved | c2fieldline1 | Reserved | c2fieldline0 | |------------------------|----------------------------------------------------------------------------------------------|-------------------------|------------|------------|----------|--------------|----------|--------------| | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 1 | 6 15 14 13 12 11 10 | 9 | 8 | 7 | 6 5 | 4 3 | 2 1 0 | | c2fieldline0<br><2:0> | CRTC2 656 toggling Field Line the vertical blank, before the fie (656 output mode), minus 1. | | | | | | | | | c2fieldline1<br><6:4> | CRTC2 656 toggling Field Line the vertical blank, before the fie (656 output mode), minus 1. | | | | | | | | | c2hsyncpol<br><8> | CRTC2 Horizontal Sync pulse l signal. | Polarity. Selects the p | olaı | rity c | f tl | he horiz | zontal | sync | | | <ul><li>0: Horizontal sync is active hi</li><li>1: Horizontal sync is active lo</li></ul> | • | | | | | | | | c2vsyncpol | CRTC2 Vertical Sync pulse Pol | arity. Selects the pol | arity | of tl | ne v | vertical | sync | signal. | | <9> | <ul><li>0: Vertical sync is active high</li><li>1: Vertical sync is active low</li></ul> | | | | | | | | | c2vlinecomp<br><27:16> | CRTC2 Vertical Line Compare value the <b>c2vlinepen</b> bit is set | | | | | | as rea | ched this | Reserved. When writing to this register, the bits in this field *must* be set to 0. Reserved <3> <7> <15:10> <28:31> Address MGABASE1 + 3C40h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 Reserved c2offset 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 c2offset <14:0> Logical line width of the screen. This field stores the offset between the current line start address and the next line start address. The value is the number of 8 quadwords in one line. The 6 LSBs of this value *must* be set to '000000' in YCbCr422 and RGB. The 7 LSBs of this value must be set to '0000000' in YCbCr420. The 8 LSBs of this value must be set to '00000000' in YCbCr420 with **c2vcbcrsingle** set to '1'. Reserved <31:15> Address MGABASE1 + 3C30h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 Reserved c2pl2startadd0 | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| c2pl2start add0 <24:0> CRTC2 Plane #2 Start Address of field #0. In 3-plane YCbCr420 mode, this register holds the address of the first Cb data after the vertical retrace of each screen refresh in non-interlace mode or each field #0 screen refresh. This address *must* be aligned on an 8 quadword boundary (the 6 LSBs set to '000000'). It becomes effective after the beginning of the next vertical blank (double-buffered register). Reserved <31:25> Address MGABASE1 + 3C34h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 Reserved c2pl2startadd1 | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| c2pl2start add1 <24:0> CRTC2 Plane #2 Start Address of field #1. In 3-plane YCbCr420 mode, this register holds the address of the first Cb data after the vertical retrace of each field #1 screen refresh. This address *must* be aligned on an 8 quadword boundary (the 6 LSBs set to '000000'). It becomes effective after the beginning of the next vertical blank (double- buffered register). Reserved <31:25> Address MGABASE1 + 3C38h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 Reserved c2pl3startadd0 | ( | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| c2pl3start add0 <24:0> CRTC2 Plane #3 Start Address of field #0. In 3-plane YCbCr420 mode, this register holds the address of the first Cr data after the vertical retrace of each screen refresh in non-interlace mode or each field #0 screen refresh. This address *must* be aligned on an 8 quadword boundary (the 6 LSBs set to '000000'). It becomes effective during the next vertical blank (double-buffered register). Reserved <31:25> Address MGABASE1 + 3C3Ch (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 Reserved c2pl3startadd0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|-----|----|----|-----|----|----|----|----|----|----|----|----|----|----|-----|----|----|---|---|---|---|---|---|---|---|---|-------| | ٠. | 00 | 20 | 20 | _' | 120 | 20 | | 120 | | | 20 | | .0 | | | .0 | | .0 | 1 - | | | U | _ | • | _ | " | • | 0 | _ | • | , , , | c2pl3start add0 <24:0> Plane #3 Start Address of field #1. In 3-plane YCbCr420 mode, this register holds the address of the first Cr data after the vertical retrace for each field #1 screen refresh. This address *must* be aligned on an 8 quadword boundary (the 6 LSBs set to '000000'). It becomes effective during the next vertical blank (double-buffered register). Reserved <31:25> Address MGABASE1 + 3C24h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC | R | ese | erve | ed | | | | | c2 | vpr | elc | ad | | | | | R | ese | rve | ed | | | | | c2l | hpr | elo | ad | | | | | | |----|-----|------|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|-----|-----|----|----|----|---|---|-----|-----|-----|----|---|---|---|---|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | c2hpreload <11:0> CRTC2 Horizontal counter Preload. This field defines the starting count value (in pixels) of the horizontal counter after a video reset. The 3 LSBs of this field value *must* be set to '000' (a multiple of 8 pixels). Programmed in the number of pixels, minus 8. c2vpreload <27:16> CRTC2 Vertical counter Preload. This field defines the starting count value of the vertical counter in lines after a video reset. Programmed in number of pixels minus 1. The preload values are used to synchronize the second CRTC with MGA-TVO. They are loaded in their respective counter with the VIDRST pin during the synchronization process. Reserved <15:12> <31:28> Address MGABASE1 + 3C54h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 Reserved c2spicstartadd0 | , | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| c2spicstart add0 <24:0> CRTC2 Start Address of the Field #0 Sub-Picture data. This register holds the address of the first pixel of each sub-picture field #0. This address *must* be aligned on an 8 quadword boundary (the 6 LSBs set to '000000'). It becomes effective after the beginning of the next vertical blank (double-buffered register). Reserved <31:25> Address MGABASE1 + 3C58h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 Reserved c2spicstartadd1 | 3 | 1 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| c2spicstart add1 <24:0> CRTC2 Start Address of the Field #1 Sub-Picture data. This register holds the address of the first pixel of each sub-picture field #1. This address *must* be aligned on an 8 quadword boundary (the 6 LSBs set to '000000'). It becomes effective after the beginning of the next vertical blank (double-buffered register). Reserved <31:25> Address MGABASE1 + 3C28h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 Reserved c2startadd0 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 c2startadd0 <24:0> CRTC2 Start Address of field #0. This register holds the address of the first pixel after the vertical retrace of each screen refresh in non-interlace mode or each field #0 screen refresh in interlace mode. This address *must* be aligned on an 8 quadword boundary (the 6 LSBs set to '000000'). It becomes effective after the beginning of the next vertical blank (double-buffered register). Reserved <31:25> Address MGABASE1 + 3C2Ch (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 Reserved c2startadd1 | ш | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |---|-----|----|----|----|----|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|-----| | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 12 | 12 | 11 | 10 | a | 8 | 7 | 6 | 5 | 1 | 2 | 2 | 1 1 | I 0 | | | J I | 50 | 23 | 20 | ~1 | 20 | 20 | | 20 | ~~ | ~ ' | 20 | 13 | 10 | 1 / | 10 | 10 | 17 | 13 | 12 | | 10 | 9 | U | ' | U | J | _ | J | _ | , , | U | c2startadd1 <24:0> CRTC2 Start Address of field #1. This register holds the address of the first pixel after the vertical retrace of each field #1 screen refresh in interlace mode. This address *must* be aligned on an 8 quadword boundary (the 6 LSBs set to '0000000'). It becomes effective after the beginning of the next vertical blank (double-buffered register). Reserved <31:25> Address MGABASE1 + 3C50h (MEM) WO, BYTE/WORD/DWORD, STATIC Attributes | Reset Value | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 000 | 0b | | | | | | |------------------------------|---------------------|----------|----------|-----------|-----------|-----------|-----------|--------------|-------------|--------------|---------|------|--------------|------| | c2subpiccrl | lut | c2sı | ubpicc | blut | | c2sub | picylu | t | Re | ese | rved | | c2subpiclutx | • | | 31 30 29 28 27 26 | 6 25 24 23 | 3 22 21 | 20 19 | 18 17 1 | 6 15 14 | 13 12 | 11 10 | 9 8 | 7 | 6 | 5 4 | 3 | 2 | 1 0 | | c2subpiclutx<br><3:0> | CRTC2 Spicture c | olor reg | ister wl | here dat | a is to b | e writte | en wher | the <b>c</b> | | | | | the s | sub- | | c2subpicylut<br><15:8> | CRTC2 register p | | | - | | | | Z-value | e wr | itte | n in th | e co | lor | | | c2subpic<br>cblut<br><23:16> | CRTC2 or register p | | | | | | | Cb-va | lue | wri | tten in | the | col | or | | c2subpic<br>crlut<br><31:24> | CRTC2 oregister p | | | | | | | Cr-val | ue v | vrit | ten in | the | colo | r | | Reserved <7:4> | Reserved | l. When | writing | g to this | register | r, the bi | ts in thi | is field | l <i>mu</i> | <i>ist</i> ł | oe set | to 0 | • | | Address MGABASE1 + 3C48h (MEM) Attributes RO, BYTE/WORD/DWORD, DYNAMIC Reset Value 0000 0000 0000 0000 0000 0000 0000 c2field Reserved S Reserved c2vcount 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 c2vcount <11:0> CRTC2 Vertical Counter value. Reading this field gives the current vertical count value. ◆ *Note:* This register *must* be read using a word or dword access, because the value may change between two byte accesses. A sample and hold circuit will ensure a stable value for the duration of one PCI read access. c2field <24> CRTC2 Field value. Reading this field gives the current field value. Reserved <31:25> <23:12> Address MGABASE1 + 3C1Ch (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 | F | Res | erv | ed | | | | | c2\ | /dis | spe | end | | | | | Re | ese | rve | ed | | | | | С | 2vt | ota | al | | | | | |---|------|-----|----|----|----|----|----|-----|------|-----|-----|----|----|----|----|----|-----|-----|----|----|----|---|---|---|-----|-----|----|---|---|---|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 3 | 1 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | c2vtotal <11:0> CRTC2 Vertical Total. Determines the total number of lines per frame in non-interlace mode or per field 0 in interlace mode. The vertical counter is reset when it reaches this value. Programmed with the total number of lines in the frame or in field 0, minus 1. c2vdispend <27:16> CRTC2 Vertical Display Enable End. Determines the total number of displayed lines per frame in non-interlace mode or per field in interlace mode. The display enable signal becomes inactive when the vertical line counter reaches this value. Programmed with the number of displayed lines in the frame or in the field, minus 1. Reserved <15:12> <31:28> **Address** MGABASE1 + 3C20h (MEM) **Attributes** WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0000 0000 0000 0000 | Neset value | 0000 0000 0000 0000 0 | | 00 00000 | | |-----------------------|-------------------------------------------------------------------------------------------------------|-----------------|----------------------------------|---| | Reserved | c2vsyncend | Reserved | c2vsyncstr | | | 31 30 29 28 27 26 | 3 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 | 10 9 8 7 6 5 4 3 2 1 | 0 | | c2vsyncstr<br><11:0> | CRTC2 Start Vertical Sync Pulse vertical line counter reaches this the beginning of the vertical sync | value. Programm | ed with the number of lines befo | | | c2vsyncend<br><27:16> | CRTC2 End Vertical Sync Pulse. vertical line counter reaches this the end of the vertical sync. pulse | value. Programm | 9 | | | Reserved | <15:12> <31:28> | | | | Address MGABASE1 + 1E4Ch (MEM) Attributes R/W, STATIC, BYTE/WORD/DWORD Reset Value 0000 0000 0000 0000 0000 0000 0000 Trq\_or | September Septembe comp\_or • 0: internal compensation logic is used • 1: the AGP compensated output buffer uses comporup and compordn as the compensation value. **compfreq** Compensation Frequency. Determines the rate at which the compensation calibration will be made. | compfreq | refresh rate | |----------|--------------| | '0000' | 16 msec | | '0001' | 31 msec | | '0010' | 63 msec | | '0011' | 0.125 sec | | '0100' | 0.25 sec | | '0101' | 0.5 sec | | '0110' | 1 sec | | '0111' | 2 sec | | 1XXX | Reserved | comporup <11:8> Determines the compensation value applied to the AGP output buffer drive high side when comp or is '1'. •• Note: Bit 11 is reserved for future expansion. Writing to this field has no effect. compordn <15:12> Determines the compensation value applied to the AGP output buffer drive low side when comp or is '1'. •• *Note:* Bit 15 is reserved for future expansion. Writing to this field has *no* effect. e2pq RO <16> Value of the SEEPROM Serial data output. •• *Note:* When the EEPROM is in bypass mode: bit 20 (**E2PBYP**) = 1, else 0. e2pbypcsn WO <17> SEEPROM Bypass Chip Select. When E2PBYP = '1', the value written to this register is driven on the E2PCSN pin. e2pbypd WO<18> SEEPROM Bypass Data. When E2PBYP = '1', the value written to this register is driven on the E2PD pin. e2pbypclk WO<19> SEEPROM Bypass Clock. When E2PBYP = '1', the value written to this register is driven on the E2PCLK pin. | e2pbyp | SEEPROM state machine Bypass. | |---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WO <20> | <ul> <li>0: normal seeprom use</li> <li>1: write access to the serial eeprom is done through the use of the e2pbyclk,</li> <li>e2pbypd, and e2pbypcsn bits and is controlled by software programming.</li> </ul> | | rate_cap_or<br>WO <23:21> | When writing to these register bits, the default value of the <b>rate_cap</b> reported in the <b>AGP_STS</b> register will be overwritten with the <b>rate_cap_or</b> value. Reading will return 0. | | rq_or<br>WO <28:24> | When writing to these register bits, the default value of the <b>rq</b> reported in the <b>AGP_STS</b> register will be overwritten with the <b>rq_or</b> value. Reading will return 0. | | Reserved | <31:29> <2:1> | | | Reserved. When writing to this register, the bits in this field <i>must</i> be set to '0'. | Address MGABASE1 + 3E44h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value unknown Reserved codecstart 21 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 codecbufsize Codec Buffer Size <0> 0: 128K byte1: 256K byte codecstart <24:2> Codec Buffer Start Address. The Codec Interface's buffer start address in the frame buffer is specified on a 1KB boundary (bits <9:2> must be loaded with '0'). Reserved <1> <31:25> **CODEC Control** CODECCTL **Address** MGABASE1 + 3E40h (MEM)**Attributes** WO, BYTE/WORD/DWORD, STATIC **Reset Value** 0000 0000 0000 0000 0000 0000 0000 000b codecfifoaddı codectransen codecrwidth prefetchen stopcodec /mimode miscctl Reserved 22 21 20 19 18 17 16 15 14 13 12 11 10 9 31 30 29 28 27 26 25 24 23 codecen Codec Enable. This bit resets the Codec Interface engine, the **CODECHARDPTR** <0> register, the Codec Interface interrupts, and the Codec Interface interrupt enables. **◆ Warning:** See Programmer's Guide for correct reset procedures. • 0: disable (default) • 1: enable codecmode Codec Mode. <1> • 0: VMI mode • 1: I33 mode cmdexectrig **Command Execution Trigger** <2> • 0: do *not* execute commands in memory • 1: execute register commands in memory •• *Note:* If this bit is written while data transfers are in progress the codec interface will automatically stop data transfers, trash its fifo contents and execute the commands in the command buffer. codecdatain Codec Data In. <3> • 0: decompression (off Screen Frame buffer to CODEC) • 1: compression (CODEC to off screen Frame buffer) vmimode VMI mode valid only when **codecmode** = '0'. <4> • 0: Mode A • 1: Mode B stopcodec Stop Codec (either compression or decompression). During transfers, this bit <5> determines whether or not more than 1 field will be transferred. • 0: do *not* stop after current field • 1: stop after current field codec Codec Transfer Enable. This field enables transfers to begin. After transfers are transen underway, this bit suspends the transfers to allow software to either fill the frame <6> buffer with more data (during decompression) or empty the frame buffer of data (during compression). CODEC Control CODECCTL ### prefetchen <7> CODEC decompression frame buffer Prefetch Enable. When set to '1', this bit allows the CODEC interface to prefetch data from the frame buffer when in decompression mode. ### codecfifo addr <11:8> Compression/Decompression Fifo Address of the Codec. When in VMI mode, the address output is **codecfifoaddr** <11:8>. When in I33 mode, only 3 bits are output, **codecfifoaddr** <10:8>. ## codecrwidth <13:12> Pulse recovery width. This bit determines the number of **codclkbuf** clock cycles between the rising edge of a strobe and the falling edge of the next strobe of consecutive bytes when performing compression or decompression. I33 mode and VMI mode B: - '00': 4 **codclkbuf** cycles between read/write strobes - '01': 5 codclkbuf cycles between read/write strobes - '10': 6 codclkbuf cycles between read/write strobes #### VMI mode A: - '00': 5 **codclkbuf** cycles between data strobes - '01': 6 **codclkbuf** cycles between data strobes - '10': 7 **codclkbuf** cycles between data strobes ## miscctl <31:24> Miscellaneous control. This byte is used to program an 8 bit flip-flop on the board for controlling the chip selects and other functions (SLEEP, START, etc.) of the CODEC chips. The Codec interface must be enabled for the programming sequence to be executed. #### Reserved <23:14> Address MGABASE1 + 3E4Ch (MEM) Attributes RO, BYTE/WORD/DWORD, DYNAMIC **Reset Value** 0000 0000 0000 0000 <u>0000</u> <u>0000</u> <u>0000</u> <u>0000</u> <u>0000</u> <u>0</u> Reserved codechardptr | 21 | 20 | 20 | 20 | 27 | 2 | 25 | 24 | 22 | 22 | 21 | 20 | 10 | 10 | 17 | 1.0 | 1.5 | 1.4 | 10 | 10 | 11 | 10 | | 0 | 1 | | ٦ | 4 | 2 | _ | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 1/ | 10 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | / | 6 | ) | 4 | 3 | 2 | 1 | U | ## codechardptr <15:0> CODEC hardware pointer. The function of this register changes depending on whether the CODEC interface is in compression or decompression mode. The value of this register is incremented by the CODEC interface so that it always points to the next frame buffer location in the to be accessed Additional Reset condition: codecen - When *compressing* video data, this register will point to the offset of the next dword to be written to the codec interface's circular buffer. - When *decompressing* video data, this register will point to the offset of the next dword to be read from the codec interface's circular buffer. # Reserved <31:16> Address MGABASE1 + 3E48h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value unknown Reserved codechostptr | Г | | • | , | • | 27 | | | | | | | • | 4.0 | 4.0 | | | | | | | | 4.0 | | 0 | | , | | | • | _ | _ | _ | |---|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|-----|---|-----|---|---|---|---|---|---|---|-----| | ı | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | - 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | i I | codechostptr <15:0> CODEC Host Pointer. An interrupt is generated (if enabled) when the dword offset pointed to by this register is accessed by the Codec Interface in its circular buffer (when **codechardptr** is equal to **codechostptr**). **Note:** This register should always be programmed to an even value (bit <0> should be '0'). Reserved <31:16> Address MGABASE1 + 3E50h (MEM) Attributes RO, BYTE/WORD/DWORD, DYNAMIC Reserved codeclcode 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 codeclcode <15:0> Used only in compression. It will point to the DWORD offset in the CODEC circular buffer following the last DWORD of the field. This register will be updated after the CODEC asserts its EOI (LCODE) pin. Reserved <31:16> Address MGABASE1 + 1C80h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown | | R | ese | erve | ed | | | | | ( | cxri | igh | t | | | | | R | ese | rve | ed | | | | | | CX | left | | | | | | |---|----|-----|------|----|----|----|----|----|----|------|-----|----|----|----|----|----|----|-----|-----|----|----|----|---|---|---|----|------|---|---|---|---|---| | ı | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | The **CXBNDRY** register is *not* a physical register; it is a more efficient way to load the **CXRIGHT** and **CXLEFT** registers. **cxleft** Clipper x left boundary. See the **CXLEFT register on page 3-108.** <11:0> **cxright** Clipper x right boundary. See the **CXRIGHT register on page 3-109.** <27:16> Reserved <31:28> <15:12> Address MGABASE1 + 1CA0h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved cxleft | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| # cxleft <11:0> Clipper x left boundary. The **cxleft** field contains an unsigned 12-bit value which is interpreted as a positive pixel address and compared with the current **xdst** (see **YDST** on page 3-283). The value of **xdst** must be greater than or equal to **cxleft** to be inside the drawing window. - •• *Note:* Since the **cxleft** value is interpreted as positive, any negative **xdst** value is automatically outside the clipping window. - Note: Clipping can be disabled by the **clipdis** bit in **DWGCTL** without changing **cxleft**. ## Reserved <31:12> Address MGABASE1 + 1CA4h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved cxright | 3 | 1 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| cxright <11:0> Clipper x right boundary. The **cxright** field contains an unsigned 12-bit value which is interpreted as a positive pixel address and compared with the current **xdst** (see **YDST on page 3-283**). The value of **xdst** must be less than or equal to **cxright** to be inside the drawing window. • Note: Clipping can be disabled by the **clipdis** bit in **DWGCTL** without changing **cxright**. Reserved <31:12> Address MGABASE1 + 1E30h (MEM) Attributes R/W, STATIC, BYTE/WORD/DWORD Reset Value unknown | r | nap | _re | g3 | | | | | m | ap_ | _re | g2 | | | | | m | ap_ | _re | g1 | | | | | m | ap_ | _re | g0 | | | |----------|-----|-----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|-----|-----|----|---|---|---|---|---|-----|-----|----|---|---| | | | | | | | | | | _ | _ | | | | | | | | | | | | | | _ | | | _ | | | | 31 30 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ## map\_regN <31:0> Map Register N. The 16-8-bit map registers form a look-up table used when addressing through the range of **MGABASE1** + 1E80h to **MGABASE1** + 1EBFh. The **DMAMAP30** register contains entries 0h to 3h of this lookup table. Refer to **DWG\_INDIR\_WT** for more information. ``` if ( address is within the DWGREGO range ) map_reg? = ( drawing_reg byte address >> 2 ) & 0 x 7F else if ( address is within DWGREG1 range ) map_reg? = (drawing byte address >> 2) & 0 x 7F | 0 x 80 else error, can't use indirect mapping ``` Address MGABASE1 + 1E34h (MEM) Attributes R/W, STATIC, BYTE/WORD/DWORD Reset Value unknown | | | m | ap_ | _re | g7 | | | | | m | ap_ | _re | g6 | | | | | m | ap_ | _re | g5 | | | | | m | ap_ | _re | g4 | | | |---|----|----|-----|-----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|-----|-----|----|---|---|---|---|---|-----|-----|----|---|---| | 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ## map\_regN <31:0> Map Register NMap Register N. The 16-8-bit map registers form a look-up table used when addressing through the range of **MGABASE1** + 1E80h to **MGABASE1** + 1EBFh. The **DMAMAP74** register contains entries 4h to 7h of this lookup table. Refer to **DWG\_INDIR\_WT** for more information. ``` if ( address is within the DWGREGO range ) map_reg? = ( drawing_reg byte address >> 2 ) & 0 x 7F else if (address is within DWGREG1 range) map_reg? = ( drawing byte address >> 2 ) & 0 x 7F | 0 x 80 else error, can't use indirect mapping ``` Address MGABASE1 + 1E38h (MEM) Attributes R/W, STATIC, BYTE/WORD/DWORD Reset Value unknown | m | nap_ | _re | gb | | | | | m | ap_ | _re | ga | | | | | m | ap_ | _re | <b>g</b> 9 | | | | | m | ap_ | _re | g8 | | | |----------|------|-----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|-----|-----|------------|---|---|---|---|---|-----|-----|----|---|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 30 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ## map\_regN <31:0> Map Register N. The 16-8-bit map registers form a look-up table used when addressing through the range of **MGABASE1** + 1E80h to **MGABASE1** + 1EBFh. The **DMAMAPB8** register contains entries 8h to Bh of this lookup table. Refer to **DWG\_INDIR\_WT** for more information. ``` if ( address is within the DWGREGO range ) map_reg? = ( drawing_reg byte address >> 2 ) & 0 x 7F else if ( address is within DWGREG1 range ) map_reg? = ( drawing byte address >> 2 ) & 0 x 7F | 0 x 80 else error, can't use indirect mapping ``` Address MGABASE1 + 1E3Ch (MEM) Attributes R/W, STATIC, BYTE/WORD/DWORD Reset Value unknown | | n | nap | _re | gf | | | | | m | ap_ | _re | ge | | | | | m | $ap_{\scriptscriptstyle{-}}$ | _re | gd | | | | | m | ap_ | _re | gc | | | |------|-------|-----|-----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|------------------------------|-----|----|---|---|---|---|---|-----|-----|----|---|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 3 | 30 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | map\_regN <31:0> Map Register N. The 16-8-bit map registers form a look-up table used when addressing through the range of **MGABASE1** + 1E80h to **MGABASE1** + 1EBFh. The **DMAMAPFC** register contains entries Ch to Fh of this lookup table. Refer to **DWG\_INDIR\_WT** for more information. ``` if ( address is within the DWGREGO range ) map_reg? = ( drawing_reg byte address >> 2 ) & 0 x 7F else if ( address is within DWGREG1 range ) map_reg? = ( drawing byte address >> 2 ) & 0 x 7F | 0 x 80 else error, can't use indirect mapping ``` DMAPAD DMA Padding Address MGABASE1 + 1C54h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown ### dmapad | 13 | 3 1 L | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 10 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | Q | 8 | 7 | 6 | - 5 | 4 | 3 | 2 | 1 | $\cap$ | |----|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|---|--------| | - | , 1 | 50 | 2) | 20 | 21 | 20 | 23 | 27 | 23 | 22 | 21 | 20 | 1) | 10 | 1/ | 10 | 15 | 17 | 13 | 12 | 11 | 10 | | O | , | U | 9 | | 5 | _ | 1 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | dmapad <31:0> DMA Padding. Writes to this register, which have no effect on the drawing engine, can be used to pad display lists. Padding should be used only when necessary, since it may impact drawing performance. Address MGABASE1 + 2C50h MGABASE1 + 2C54h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved dr0\_z32 | 6 | 3 | | | | 48 | 47 | | | | | | | | | | | 0 | |---|---|--|--|--|----|----|--|--|--|--|--|--|--|--|--|--|---| dr0\_z32 Data ALU 0 <47:0> - For TRAP or TEXTURE\_TRAP with z, the DR0\_Z32 register is used to scan the left edge of the trapezoid and must be initialized with its starting z value. In this case, DR0\_Z32 is signed 33.15 in two's complement notation. - For LINE with z, the DR0\_Z32 register holds the z value for the current drawn pixel and must be initialized with the starting z value. In this case, DR0\_Z32 is a signed 33.15 value in two's complement notation. - **►►** *Note:* The field **dr0\_z32** is part of two registers: - $dr0_z32[47:32] = DR0_z32MSB[15:0]$ - $dr0_z32[31:0] = DR0_z32LSB[31:0]$ Reserved <63:48> Reserved. When writing to this register, bits 63 to 48 are completely ignored. - **Note:** The Reserved field is part of one register: - $dr0_z32[63:48] = DR0_z32MSB[31:16]$ Address MGABASE1 + 2C60h MGABASE1 + 2C64h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved dr2\_z32 | 6. | 3 | | | | 48 | 47 | | | | | | | | | | | 0 | |----|---|--|--|--|----|----|--|--|--|--|--|--|--|--|--|--|---| dr2\_z32 <47:0> Data ALU 2 - For TRAP or TEXTURE\_TRAP with z, the **DR2** register holds the z increment value along the x-axis. In this case, **DR2** is a signed 33.15 value in two's complement notation. - For LINE with z, the **DR2** register holds the z increment value along the major axis. In this case, **DR2** is a signed 33.15 value in two's complement notation. - **◆** *Note:* The field **dr2\_z32** is part of two registers: - $dr2_z32[63:32] = DR2_z32MSB[31:0]$ - $dr2_z32[31:0] = DR2_z32LSB[31:0]$ Reserved <63:48> Reserved. When writing to this register, bits 63 to 48 are completely ignored. Reading will return '0's. - •• *Note:* The Reserved field is part of one register: - $dr2_z32[63:48] = DR2_z32MSB[31:16]$ Address MGABASE1 + 2C68h MGABASE1 + 2C6Ch (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved dr3\_z32 | 63 | | | | 48 | 47 | | | | | | | | | | | 0 | |----|--|--|--|----|----|--|--|--|--|--|--|--|--|--|--|---| dr3\_z32 <47:0> Data ALU 3. - For TRAP or TEXTURE\_TRAP with z, **DR3** register holds the z increment value along the y-axis. In this case, **DR3** is a signed 33.15 value in two's complement notation. - For LINE with z, **DR3** register holds the z increment value along the diagonal axis. In this case, **DR3** is a signed 33.15 value in two's complement notation. - **►►•** *Note:* The field **dr3\_z32** is part of two registers: - $dr3_z32[63:32] = DR3_z32MSB[31:0]$ - $dr3_z32[31:0] = DR3_z32LSB[31:0]$ Reserved <63:48> Reserved. When writing to this register, bits 63 to 48 are completely ignored. Reading will return '0's. - ◆ *Note:* The Reserved field is part of one register: - $dr3_z32[63:48] = DR3_z32MSB[31:16]$ DR0 Data ALU 0 Address MGABASE1 + 1CC0h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown dr0 | 9 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| dr0 <31:0> Data ALU register 0. - For TRAP or TEXTURE\_TRAP with z, the **DR0** register is used to scan the left edge of the trapezoid and must be initialized with its starting z value. In this case, **DR0** is a signed 17.15 value in two's complement notation. - For LINE with z, the **DR0** register holds the z value for the current drawn pixel and must be initialized with the starting z value. In this case, **DR0** is a signed 17.15 value in two's complement notation. - •• Note: Bits 31 to 16 of DR0 map to bits 15 to 0 of DR0\_32MSB; bits 15 to 0 of DR0 map to bits 31 to 16 of DR0\_32LSB. Writing to this register clears bits 15 to 0 of DR0\_32LSB. Data ALU 2 DR2 Address MGABASE1 + 1CC8h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown dr2 | L | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | dr2 <31:0> Data ALU register 2. • For TRAP or TEXTURE\_TRAP with z, the **DR2** register holds the z increment value along the x-axis. In this case, **DR2** is a signed 17.15 value in two's complement notation. - For LINE with z, the **DR2** register holds the z increment value along the major axis. In this case, **DR2** is a signed 17.15 value in two's complement notation. - •• Note: Bits 31 to 16 of DR2 map to bits 15 to 0 of DR2\_32MSB; bits 15 to 0 of DR2 map to bits 31 to 16 of DR2\_32LSB. Writing to this register clears bits 15 to 0 of DR2\_32LSB. DR3 Data ALU 3 Address MGABASE1 + 1CCCh (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown dr3 | 3 | 1 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| dr3 <31:0> Data ALU register 3. - For TRAP or TEXTURE\_TRAP with z, **DR3** register holds the z increment value along the y-axis. In this case, **DR3** is a signed 17.15 value in two's complement notation. - For LINE with z, **DR3** register holds the z increment value along the diagonal axis. In this case, **DR3** is a signed 17.15 value in two's complement notation. - ◆ *Note:* Bits 31 to 16 of DR3 map to bits 15 to 0 of DR3\_32MSB; bits 15 to 0 of DR3 map to bits 31 to 16 of DR3\_32LSB. Writing to this register clears bits 15 to 0 of DR3\_32LSB. Data ALU 4 DR4 Address MGABASE1 + 1CD0h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved dr4 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| dr4 <23:0> Data ALU register 4. This field holds a signed 9.15 value in two's complement notation. - For TRAP with z, the **DR4** register is used to scan the left edge of the trapezoid for the red color (Gouraud shading). This register must be initialized with its starting red color value. - For LINE with z, the **DR4** register holds the current red color value for the currently drawn pixel. This register must be initialized with the starting red color. - For TEXTURE\_TRAP with texture modulation (**tmodulate** = '1', see **TEXCTL**), the **DR4** register is used to scan the left edge of the trapezoid for the red modulation factor. This register must be initialized with its starting red modulation factor value. - For TEXTURE\_TRAP using the decal feature (**tmodulate** = '0'), the **DR4** register is used to scan the left edge of the trapezoid for the red (Gouraud shaded surface) color. This register must be initialized with its starting red color value. Reserved <31:24> DR6 Data ALU 6 Address MGABASE1 + 1CD8h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved dr6 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| dr6 <23:0> Data ALU register 6. This field holds a signed 9.15 value in two's complement notation. - For TRAP with z, the **DR6** register holds the red increment value along the x-axis. - For LINE with z, the **DR6** register holds the red increment value along the major axis. - For TEXTURE\_TRAP with modulation or decal, the **DR6** register holds the red increment value along the x-axis. Reserved <31:24> Data ALU 7 DR7 Address MGABASE1 + 1CDCh (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved dr7 | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| dr7 <23:0> Data ALU register 7. This field holds a signed 9.15 value in two's complement notation. - For TRAP with z, the **DR7** register holds the red increment value along the y-axis. - For LINE with z, the **DR7** register holds the red increment value along the diagonal axis. - For TEXTURE\_TRAP with modulation or decal, the **DR7** register holds the red increment value along the y-axis. Reserved <31:24> DR8 Data ALU 8 Address MGABASE1 + 1CE0h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved dr8 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| dr8 <23:0> Data ALU register 8. This field holds a signed 9.15 value in two's complement notation. - For TRAP with z, the **DR8** register is used to scan the left edge of the trapezoid for the green color (Gouraud shading). This register must be initialized with its starting green color value. - For LINE with z, the **DR8** register holds the current green color value for the currently drawn pixel. This register must be initialized with the starting green color. - For TEXTURE\_TRAP with texture modulation (**tmodulate** = '1', see **TEXCTL**), the **DR8** register is used to scan the left edge of the trapezoid for the green modulation factor. This register must be initialized with its starting green modulation factor value. - For TEXTURE\_TRAP using the decal feature (**tmodulate** = '0'), the **DR8** register is used to scan the left edge of the trapezoid for the green (Gouraud shaded surface) color. This register must be initialized with its starting green color value. Reserved <31:24> Data ALU 10 DR10 Address MGABASE1 + 1CE8h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved dr10 | 3 | 1 30 | 0 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| dr10 <23:0> Data ALU register 10. This field holds a signed 9.15 value in two's complement notation. - For TRAP with z, the **DR10** register holds the green increment value along the x-axis. - For LINE with z, the **DR10** register holds the green increment value along the major axis. - For TEXTURE\_TRAP with modulation or decal, the **DR10** register holds the green increment value along the x-axis. Reserved <31:24> DR11 Data ALU 11 Address MGABASE1 + 1CECh (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved dr11 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| dr11 <23:0> Data ALU register 11. This field holds a signed 9.15 value in two's complement notation. - For TRAP with z, the **DR11** register holds the green increment value along the y-axis. - For LINE with z, the **DR11** register holds the green increment value along the diagonal axis. - For TEXTURE\_TRAP with modulation or decal, the **DR11** register holds the green increment value along the y-axis. Reserved <31:24> Data ALU 12 DR12 Address MGABASE1 + 1CF0h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved dr12 | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| dr12 <23:0> Data ALU register 12. This field holds a signed 9.15 value in two's complement notation. - For TRAP with z, the **DR12** register is used to scan the left edge of the trapezoid for the blue color (Gouraud shading). This register must be initialized with its starting blue color value. - For LINE with z, the **DR12** register holds the blue color value for the currently drawn pixel. This register must be initialized with the starting blue color. - For TEXTURE\_TRAP with texture modulation (**tmodulate** = '1', see **TEXCTL**), the **DR12** register is used to scan the left edge of the trapezoid for the blue modulation factor. This register must be initialized with its starting blue modulation factor value. - For TEXTURE\_TRAP using the decal feature (**tmodulate** = '0'), the **DR12** register is used to scan the left edge of the trapezoid for the blue (Gouraud shaded surface) color. This register must be initialized with its starting blue color value. Reserved <31:24> DR14 Data ALU 14 Address MGABASE1 + 1CF8h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved dr14 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| dr14 <23:0> Data ALU register 14. This field holds a signed 9.15 value in two's complement notation. - For TRAP with z, the **DR14** register holds the blue increment value along the x-axis. - For LINE with z, the **DR14** register holds the blue increment value along the major axis. - For TEXTURE\_TRAP with modulation or decal, the **DR14** register holds the blue increment value along the x-axis. Reserved <31:24> Data ALU 15 DR15 Address MGABASE1 + 1CFCh (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved dr15 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| dr15 <23:0> Data ALU register 15. This field holds a signed 9.15 value in two's complement notation. - For TRAP with z, the **DR15** register holds the blue increment value along the y-axis. - For LINE with z, the **DR15** register holds the blue increment value along the diagonal axis. - For TEXTURE\_TRAP with modulation or decal, the **DR15** register holds the blue increment value along the y-axis. Reserved <31:24> Address MGABASE1 + 2CB8h (MEM) Attributes WO, FIFO, STATIC, DWORD | | | | | | | | | | | | | dst | orç | 3 | | | | | | | | | | | | R | ese | erve | ed | dstacc | dstmap | |----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|------|----|--------|--------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | dstmap <0> Destination Map. A memory space indicator, this field indicates the map location. • 0: the destination is in the frame buffer memory. • 1: the destination is in the system memory. dstacc <1> Destination Access type. This field specifies the mode used to access the map. • 0: PCI access. • 1: AGP access. •• *Note:* This field is *not* considered if the destination resides in the frame buffer source. dstorg <31:6> Destination Origin. This field provides an offset value for the position of the first pixel of a destination surface. The **dstorg** field corresponds to a 64-byte address in memory. •• *Note:* Due to a limitation of the CRTC in PW24, the **DSTORG** register must be loaded with a multiple of three 64-bytes. Reserved <5:2> **Address** MGABASE1 + 1E80h (MEM) (entry 0) ••• MGABASE1 + 1EBCh (MEM) (entry 15) Attributes WO, DWORD Reset Value N/A ### lut entry N | , | | | - | | | | L . | | | | | | | | | - 1 | | | | | | - | - | | _ | _ | | - | | | _ | |----|----|----|----|----|----|----|-----|-----|----|----|-----|----|----|----|----|-----|----|----|-----|-----|----|---|-----|-----|---|---|-----|-----|-----|-----|----| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 123 | 22 | 21 | 120 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 112 | 111 | 10 | 9 | - 8 | 1 7 | 6 | 5 | I 4 | - 3 | 1 2 | 11' | () | | | | | | | | | | | | | | | | | | | | | | | | _ | _ | | - | _ | | _ | _ | - ' | | # lutentry N <31:0> These 16 registers are a lookup table that can be used in conjunction with the **DMAMAP** registers. Writing to these locations address the register that is programmed in the Nth byte of the **DMAMAP**. This indirect write register provides a means to access non-sequential drawing registers sequentially. | Address | DWG_INDIR_WT Register | |---------------------------------------------------------------------------------------|-----------------------| | MGABASE1 + 1C00h + map_reg0 | DWG_INDIR_WT<0> | | MGABASE1 + 1C00h + map_reg1 | DWG_INDIR_WT<1> | | MGABASE1 + 1C00h + map_reg2 | DWG_INDIR_WT<2> | | MGABASE1 + 1C00h + map_reg3 | DWG_INDIR_WT<3> | | MGABASE1 + 1C00h + map_reg4 | DWG_INDIR_WT<4> | | MGABASE1 + 1C00h + map_reg5 | DWG_INDIR_WT<5> | | MGABASE1 + 1C00h + map_reg6 | DWG_INDIR_WT<6> | | MGABASE1 + 1C00h + map_reg7 | DWG_INDIR_WT<7> | | MGABASE1 + 1C00h + map_reg8 | DWG_INDIR_WT<8> | | $\begin{tabular}{ll} MGABASE1 + 1C00h + map\_reg9 \\ \end{tabular}$ | DWG_INDIR_WT<9> | | MGABASE1 + 1C00h + map_rega | DWG_INDIR_WT<10> | | MGABASE1 + 1C00h + map_regb | DWG_INDIR_WT<11> | | MGABASE1 + 1C00h + map_regc | DWG_INDIR_WT<12> | | $\begin{tabular}{ll} \textbf{MGABASE1} + 1C00h + \textbf{map\_regd} \\ \end{tabular}$ | DWG_INDIR_WT<13> | | MGABASE1 + 1C00h + map_rege | DWG_INDIR_WT<14> | | MGABASE1 + 1C00h + map_regf | DWG_INDIR_WT<15> | Address MGABASE1 + 1C00h (MEM) Attributes WO, FIFO, STATIC, DWORD **Reset Value** $0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 00000 \ 00000 \ 00000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 00000 \ 00000 \ 0000 \ 00$ | clipdis | transc | pattern | ı | oltn | noc | k | Reserved | tra | ns | | bo | р | Reserved | shftzero | sgnzero | arzero | solid | zn | noc | de | linear | atype | ( | opo | od | | |---------|--------|---------|---|------|-----|---|----------|-----|----|--|----|---|----------|----------|---------|--------|-------|----|-----|----|--------|-------|------|-----|----|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <br> | | | | opcod <3:0> Operation code. The **opcod** field defines the operation that is selected by the drawing engine. | | | | opcod | |-----------|------------------------|--------|----------------| | Function | Sub-Function | Value | Mnemonic | | Lines | | '0000' | LINE_OPEN | | | AUTO | '0001' | AUTOLINE_OPEN | | | WRITE LAST | '0010' | LINE_CLOSE | | | AUTO, WRITE LAST | '0011' | AUTOLINE_CLOSE | | Transpoid | | '0100' | TRAP | | Trapezoid | Texture mapping | '0110' | TEXTURE_TRAP | | Blit | $RAM \rightarrow RAM$ | '1000' | BITBLT | | | $HOST \rightarrow RAM$ | '1001' | ILOAD | | | | '0101' | | | | | '0111' | | | | | '1010' | | | | D d | '1011' | | | | Reserved | '1100' | | | | | '1101' | | | | | '1110' | | | | | '1111' | | ## atype <6:4> Access type. The **atype** field is used to define the type of access performed to the RAM. | aty | ре | | |---------------|----------|------------------------------------------------| | Value | Mnemonic | RAM Access | | '000' | RPL | Write (replace) <sup>(1)</sup> | | '001' | RSTR | Read-modify-write (raster)(1) | | <b>'</b> 010' | | Reserved | | <b>'</b> 011' | ZI | Depth mode with Gouraud <sup>(2)</sup> | | <b>'100'</b> | BLK | Block write mode (3) | | <b>'101'</b> | | Reserved | | <b>'110'</b> | | Reserved | | <b>'111'</b> | I | Gouraud (with depth compare) <sup>(2)(4)</sup> | <sup>(1)</sup> The Read-Modify-Write sequence depends on the value of the bop field even if **atype** equals RPL, RSTR, ZI, or I. The Read will be performed according to the table in the **bop** field (see page 3-135). - (2) The raster operation also supports ZI and I operations (see page 3-135). - (3) When block mode is selected, only RPL operations can be performed. Even if the **bop** field is programmed to a different value, RPL will be used. - (4) Depth comparison works according to the **zmode** setting (same as 'ZI'); however, the depth is never updated. # linear <7> Linear mode. Specifies whether the blit is linear or xy. - 0: xy blit - 1: linear blit ## zmode <10:8> The z drawing mode. This field must be valid for drawing using depth. This field specifies the type of comparison to use. | zmo | de | | |---------------|----------|------------------| | Value | Mnemonic | Pixel Update | | '000' | NOZCMP | Always | | '001' | | Reserved | | <b>'</b> 010' | ZE | When depth is = | | <b>'</b> 011' | ZNE | When depth is <> | | <b>'100'</b> | ZLT | When depth is < | | <b>'101'</b> | ZLTE | When depth is <= | | <b>'110'</b> | ZGT | When depth is > | | '111' | ZGTE | When depth is >= | ## solid <11> Solid line or constant trapezoid. The solid register is *not* a physical register. It provides an alternate way to load the **SRC** registers (see page 3-186). - 0: No effect - 1: SRC0 <= FFFFFFFFh SRC1 <= FFFFFFFFh SRC2 <= FFFFFFFFh SRC3 <= FFFFFFFF Setting solid is useful for line drawing with no linestyle, or for trapezoid drawing with no patterning. It forces the color expansion circuitry to provide the foreground color during a line or a trapezoid drawing. ## arzero <12> **AR** register at zero. The **arzero** field provides an alternate way to set all **AR** registers (see descriptions starting on page 3-39). - 0: No effect - 1: **AR0** $\leq$ 0h - $AR1 \le 0h$ - $AR2 \le 0h$ - $AR4 \le 0h$ - AR5 <= 0h - $AR6 \le 0h$ Setting **arzero** is useful when drawing rectangles, and also for certain blit operations. In the case of rectangles (TRAP **opcod**): $$\begin{split} & dYl <= 0 \text{ (AR0)} \\ & errl <= 0 \text{ (AR1)} \\ & -|dXl| <= 0 \text{ (AR2)} \\ & errr <= 0 \text{ (AR4)} \\ & -|dXr| <= 0 \text{ (AR5)} \\ & dYr <= 0 \text{ (AR6)} \end{split}$$ ### sgnzero <13> Sign register at zero. The **sgnzero** bit provides an alternate way to set all the fields in the **SGN** register. - 0: No effect - 1: **SGN** $\leq$ = 0h Setting **sgnzero** is useful during TRAP and some blit operations. For TRAP: brkleft (see SGN on page 3-172) **scanleft** = 0 Horizontal scan right **sdxl** = 0 Left edge in increment mode **sdxr** = 0 Right edge in increment mode sdy = 0 Vertical scan down For BLIT: **scanleft** = 0 Horizontal scan right $\mathbf{sdxl} = 0$ Left edge in increment mode $\mathbf{sdxr} = 0$ Right edge in increment mode sdy = 0 Vertical scan down shftzero <14> Shift register at zero. The **shftzero** bit provides an alternate way to set all the fields of the **SHIFT** register. • 0: No effect • 1: **SHIFT** <= 0h bop <19:16> Boolean operation between a source and a destination slice. The table below shows the various functions performed by the Boolean ALU for 8, 16, 24 and, 32 bits/pixel. During block mode operations, bop must be set to Ch. A raster operation is performed when atype = ZI, I, RPL or RSTR. | bop | Function | Destination read | |--------|----------|------------------| | '0000' | 0 | No | | '0001' | ~(D S) | Yes | | '0010' | D & ~S | Yes | | '0011' | ~S | No | | '0100' | (~D) & S | Yes | | '0101' | ~D | Yes | | '0110' | D ^ S | Yes | | '0111' | ~(D & S) | Yes | | '1000' | D&S | Yes | | '1001' | ~(D ^ S) | Yes | | '1010' | D | Yes | | '1011' | D ~S | Yes | | '1100' | S | No | | '1101' | (~D) S | Yes | | '1110' | D S | Yes | | '1111' | 1 | No | trans <23:20> Translucency. Specify the percentage of opaqueness of the object. The opaqueness is realized by writing one of 'n' pixels. The **trans** field specifies the following transparency pattern (where black squares are opaque and white squares are transparent): bltmod <28:25> Blit mode selection. This field is defined as used during BLIT and ILOAD operations. | blt | mod | | |--------|----------|-----------------------------------------------------------------------------------------------| | Value | Mnemonic | Usage | | '0000' | BMONOLEF | Source operand is monochrome in 1 bpp. For ILOAD, the source data is in Little-Endian format. | | '0100' | BMONOWF | Source operand is monochrome in 1 bpp. For ILOAD, the source data is in Windows format. | | '0001' | BPLAN | Source operand is monochrome from one plane. | | '0010' | BFCOL | Source operand is color. Source is formatted when it comes from host. | | '0011' | BU32BGR | Source operand is color. For ILOAD, the source data is in 32 bpp, BGR format. | | '0111' | BU32RGB | Source operand is color. For ILOAD, the source data is in 32 bpp, RGB format. | | '1011' | BU24BGR | Source operand is color. For ILOAD, the source data is in 24 bpp, BGR format. | | '1111' | BU24RGB | Source operand is color. For ILOAD, the source data is in 24 bpp, RGB format. | | '0101' | | Reserved | | '0110' | | " | | '1000' | | " | | '1001' | | ", | | '1010' | | ,, | | '1100' | | ,, | | '1101' | | " | • For line drawing with line style, this field must have the value BFCOL in order to handle the line style properly. Refer to the subsections contained in 'Drawing in Power Graphic Mode' on page 4-29 for more information on how to use this field. That section also presents the definition of the various pixel formats. # pattern <29> Patterning enable. This bit specifies if the patterning is enabled when performing BITBLT operations. - 0: Patterning is disabled. - 1: Patterning is enabled. ## transc <30> Transparency color enabled. This field can be enabled for blits, vectors that have a linestyle, and trapezoids with patterning. For operations with color expansion, this bit specifies if the background color is used. - 0: Background color is opaque. - 1: Background color is transparent. For other types of blit, this field enables the transparent blit feature, based on a comparison with a transparent color key. This transparency is defined by the following equation: ``` if ( transc==1 && (source & bltcmsk==bltckey) ) do not update the destination else update the destination with the source ``` Refer to the **FCOL** and **BCOL** register descriptions for the definitions of the **bltckey** and **bltcmsk** fields, respectively. #### clipdis <31> Clipping Disable. This bit has the following effect on the value of CXLEFT, CXRIGHT, CYBOT, and CYTOP: | | <b>'</b> 0' | <b>'1'</b> | |---------|----------------------------------|------------------------| | CXLEFT | last value programmed in CXLEFT | 0h (minimum value) | | CXRIGHT | last value programmed in CXRIGHT | FFFh (maximum value) | | CYBOT | last value programmed in CYBOT | FFFFFh (maximum value) | | CYTOP | last value programmed in CYTOP | 0h (minimum value) | #### Reserved #### <15> <24> Address MGABASE1 + 2C4C Attributes R/W, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved ### dwgsyncaddr | 31 | 31 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| dwgsyncaddr <31:2> This register serves as a synchronisation pointer. The value of **dwgsyncaddr** is updated with the value programmed in **dwgsyncaddr** *only* when the drawing engine has completed the primitive sent before **DWGSYNC** was programmed. When the **primptren1** bit is set, this register is written by a PCI access in the location pointed to by **PRIMPTR**. The write is triggered when the drawing engine updates **dwgsyncaddr**. Reserved <1:0> Address MGABASE1 + 1C24h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown #### forcol | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |---------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | #### bltckey ## forcol <31:0> Foreground color. The **forcol** field is used by the color expansion module to generate the source pixels when the foreground is selected. For 2D operation: - In 8 bits/pixel, only **forcol**<7:0> is used. - In 16 bits/pixel, only **forcol**<15:0> is used. - In 24 bits/pixel, when *not* in block mode, **forcol**<31:24> is *not* used. - In 24 bits/pixel, when in block mode, all **forcol** bits are used. For 3D operation: • All **forcol** bits are used. Refer to 'Pixel Format' on page 4-21 for the definition of the slice in each mode. Part of the **forcol** register is also used for Gouraud shading to generate the alpha bits. In 32 bpp (bits/pixel), bits 31 to 24 originate from **forcol**<31:24>. In 16 bpp, when 5:5:5 mode is selected, bit 15 originates from **forcol**<15>. # bltckey <31:0> Blit color key. This field specifies the value of the color that is defined as the 'transparent' color. Planes that are *not* used must be set to '0'. Refer to the description of the **transc** field of **DWGCTL** for the transparency equation - In 8 bits/pixel, only **bltckey**<7:0> is used. - In 16 bits/pixel, only **bltckey**<15:0> is used. Bus FIFO Status FIFOSTATUS Address MGABASE1 + 1E10h (MEM) Attributes RO, DYNAMIC, BYTE/WORD/DWORD **Reset Value** 0000 0000 0000 0000 00<u>10</u> 0<u>001</u> 0000b | | | | | | | | | | | R | ese | erv | ed | | | | | | | | | | bempty | pfull | | Reserved | | , | fifo | CO | unt | | |---|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|--------|-------|---|----------|---|---|------|----|-----|---| | ı | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | fifocount Indicates the number of free locations in the Bus FIFO. On soft or hard reset, the <4:0> contents of the Bus FIFO are flushed and the FIFO count is set to 16. bfull <8> Bus FIFO full flag. When set to '1', indicates that the Bus FIFO is full. bempty <9> Bus FIFO empty flag. When set to '1', indicates that the Bus FIFO is empty. This bit is identical to **fifocount**<4>. There is no need to poll the **bfull** or **fifocount** values before writing to the BFIFO: circuitry in the MGA watches the BFIFO level and generates target retries until a free location becomes available, or until a retry limit has been exceeded (in which case, it might indicate an abnormal engine lock-up). Even if the machine that reads the Bus FIFO is asynchronous with the PCI interface, a sample and hold circuit has been added to provide a correct, non-changing value during the full PCI read cycle (the **fifocount** value, **bfull**, and **bempty** flag states are sampled at the start of the PCI access). #### Reserved <7:5> <31:10> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. Reading will return '0's. FOGCOL Fog Color Address MGABASE1 + 1CF4h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown #### fogcol | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| fogcol <23:0> Fog Color. When fogging is enabled, the fog field represents the color that is blended, using the fog blending factor, with the current rasterized fragment's color. **►►** *Note:* **FOGCOL** is in true color (RGB: 888) format. Reserved <31:24> Fog Start FOGSTART Address MGABASE1 + 1CC4h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved fogstart | 13 | 1 I | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 111 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 13 | 1 2 | 1 | 0 | |----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|----|----|-----|---|---| | - | * | 50 | | 20 | -, | 20 | 20 | | | | | 20 | 1, | 10 | 1, | 10 | 10 | 1. | 13 | 12 | | 10 | _ | 0 | , | 0 | | ٠. | | _ | | 0 | fogstart <23:0> Fog Start. This field holds a signed 9.15 value in two's complement notation. For 3D primitives, the **FOGSTART** register is used to scan the left edge of the trapezoid for the fog blending factor (when fogging is enabled). •• *Note:* This register must be initialized with its starting fog factor value. Reserved <31:24> FOGXINC Fog X Inc Address MGABASE1 + 1CD4h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved fogxinc | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| fogxinc Fog X Increment register. This field holds a signed 9.15 value in two's complement **<23:0>** notation. For 3D primitives, the **FOGXINC** register holds the fog blending factor increment along the x (or major) axis. Reserved <31:24> Fog Y Inc FOGYING Address MGABASE1 + 1CE4h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved fogyinc | 3 | 1 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| fogyinc <23:0> Fog Y Increment register. This field holds a signed 9.15 value in two's complement > notation. For 3D primitives, the **FOGYINC** register holds the fog blending factor increment along the y (or diagonal) axis. Reserved <31:24> Address MGABASE1 + 1C84h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown fxright fxleft | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| The **FXBNDRY** register is *not* a physical register; it is a more efficient way to load the **FXRIGHT** and **FXLEFT** registers. fxleft <15:0> Filled object x left-coordinate. Refer to the **FXLEFT** register for a detailed description. Carant and a **fxright** Filled object x right-coordinate. See the **FXRIGHT register on page 3-148.** <31:16> X Address (Left) FXLEF Address MGABASE1 + 1CA8h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved fxleft | 31 | 30 | 20 | 28 | 77 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 10 | 10 | 17 | 16 | 15 | 1.4 | 13 | 12 | 11 | 10 | ٥ | 0 | 7 | 6 | 7 | 1 | 2 | 2 | 1 | Λ | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | 31 | 30 | 29 | 20 | 21 | 20 | 23 | | 23 | 22 | 21 | 20 | 19 | 10 | 1/ | 10 | 13 | 14 | 13 | 12 | 11 | 10 | 9 | 0 | / | U | ) | 4 | 3 | | 1 | U | fxleft <15:0> Filled object x left-coordinate. The **fxleft** field contains the x-coordinate (in pixels) of the left boundary of any filled object being drawn. It is a 16-bit signed value in two's complement notation. - The **fxleft** field is **not** used for line drawing. - During filled trapezoid drawing, **fxleft** is updated during the left edge scan. - During a BLIT operation, **fxleft** is static, and specifies the left pixel boundary of the area being written to. - For sub-pixel trapezoids, it is a signed 16.4 value in two's complement notation. Reserved <31:16> Address MGABASE1 + 1CACh (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved fxright | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| # fxright <15:0> Filled object x right-coordinate. The **fxright** field contains the x-coordinate (in pixels) of the right boundary of any filled object being drawn. It is a 16-bit signed value in two's complement notation. - The **fxright** field is *not* used for line drawing. - During filled trapezoid drawing, **fxright** is updated during the right edge scan. - During a BLIT operation, **fxright** is static, and specifies the right pixel boundary of the area being written to. - For sub-pixel trapezoids, it is a signed 16.4 value in two's complement notation. # Reserved <31:16> Interrupt Clear **Address** MGABASE1 + 1E18h (MEM) **Attributes** WO, BYTE/WORD/DWORD, STATIC **Reset Value** 0000 0000 0000 0000 0000 0000 0000 0000b | 1 | | | | | | | | | R | ese | ervo | ed | | | | | | | | | wciclr1 | wiclr1 | c2vlineiclr | wciclr | wiclr | Reserved | vlineiclr | | n | pickiclr | Reserved | softrapicIr | | |---|----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|---------|--------|-------------|--------|-------|----------|-----------|---|---|----------|----------|-------------|--| | Ī | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | softrapicIr Soft Trap Interrupt Clear. When a '1' is written to this bit, the soft trap interrupt <0> pending flag is cleared. pickiclr Pick Interrupt Clear. When a '1' is written to this bit, the pick interrupt pending flag is <2> cleared. vlineiclr Vertical Line Interrupt Clear. When a '1' is written to this bit, the vertical line interrupt <5> pending flag is cleared. wiclr WARP Interrupt Clear. When a '1' is written to this bit, the WARP interrupt pending <7> flag is cleared. wciclr WARP Cache interrupt Clear. When a '1' is written to this bit, the WARP cache <8> interrupt pending flag is cleared. c2vlineiclr Second CRTC Vertical Line Clear. When a '1' is written to this bit, the vertical line <9> interrupt pending flag (c2vlinepen) is cleared. wiclr1 WARP Interrupt Clear. When a '1' is written to this bit, the WARP1 interrupt pending <10> flag is cleared. wciclr1 WARP Cache interrupt Clear. When a '1' is written to this bit, the WARP1 cache interrupt pending flag is cleared. Reserved <1> <4:3> <6> <31:12> <11> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. Reading will return '0's. **Address** MGABASE1 + 1E1Ch (MEM) **Attributes** R/W, BYTE/WORD/DWORD, STATIC **Reset Value** 0000 0000 0000 0000 0000 0000 0000 0000ь | | | | | | | | | R | ese | erve | ed | | | | | | | | | wcien1 | wien1 | c2vlineien | wcien | wien | extien | vlineien | ( | บ | pickien | Reserved | softrapien | |---|------|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|--------|-------|------------|-------|------|--------|----------|---|---|---------|----------|------------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 3 | 1 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | softrapien Soft trap interrupt enable. When this field is set to '1', the PCI interrupt is enabled on <0> the PINTA/ line when the **SOFTRAP** register is written to. pickien Picking Interrupt Enable. When set to '1', enables interrupts if a picking interrupt <2> occurs. vlineien Vertical Line Interrupt Enable. When set to '1', an interrupt will be generated when <5> the vertical line counter equals the vertical line interrupt count. extien External Interrupt Enable. When set to '1', an external interrupt will contribute to the <6> generation of a PCI interrupt on the PINTA/ line. wien WARP Interrupt Enable. When set to '1', a WARP interrupt will contribute to the <7> generation of a PCI interrupt on the PINTA/ line. wcien WARP Cache interrupt enable. When set to '1' a WARP CACHE miss will contribute <8> to the generation of a PCI interrupt on the PINTA/ line. c2vlineien Second CRTC Vertical Line Interrupt Enable. When set to '1', an interrupt will be <9> generated when the CRTC2 vertical line counter equals the **c2linecomp** value (see MISC). WARP Interrupt Enable. When set to '1', a WARP1 interrupt will contribute to the wien1 <10> generation of a PCI interrupt on the PINTA/ line. wcien1 WARP Cache interrupt enable. When set to '1' a WARP1 CACHE miss will <11> contribute to the generation of a PCI interrupt on the PINTA/ line. Reserved <1> <4:3> <31:12> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. Reading will return '0's. Length LEN Address MGABASE1 + 1C5Ch (MEM) Attributes WO, FIFO, STATIC, DWORD oggle | | ت | | | | | | | Res | ser | vec | 1 | | | | | | | | | | | | | en | gtn | • | | | | | | | |---|----|----|----|----|----|----|----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|-----|---|---|---|---|---|---|---| | [ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | length <15:0> Length. The length field is a 16-bit unsigned value. - The **length** field does *not* require initialization for auto-init vectors, *but if* programmed, it *must* be other than zero. - For a vector draw, **length** is programmed with the number of pixels to be drawn. - For blits and trapezoid fills, **length** is programmed with the number of lines to be filled or blitted. - To load the texture color palette, **length** is programmed with the number of locations in the LUT to be filled. toggle <31> Toggle. Toggles to the other set of Double Registers. When this bit is set to '1', the drawing engine will toggle to the other set of double *buffers*. ◆ *Note:* For ILOAD operations, this bit *must* always be set to '0'. Reserved <30:16> Address MGABASE1 + 1C04h (MEM) Attributes WO, FIFO, STATIC, DWORD Rev A: | dit555 | nodither | tlutload | Ċ | nesei ved | fogen | | | | Re | ese | erve | ed | | | | memreset | | | ı | Res | serv | vec | i | | | | 4 | = | Reserved | A#Ciwic | D MICH | |--------|----------|----------|----|-----------|-------|----|----|----|----|-----|------|----|----|----|----|----------|----|----|----|-----|------|-----|---|---|---|---|---|---|----------|---------|--------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Rev. B and later | dit555 | 8 | tlutload | bypass332 | - | fogen | | | | Re | ese | erve | ed | | | | memreset | | | ı | Res | ser | vec | ł | | | | 410:45 | ZWIGUI | Reserved | 4+0;3,4 | | |--------|----|----------|-----------|----|-------|----|----|----|----|-----|------|----|----|----|----|----------|----|----|----|-----|-----|-----|---|---|---|---|--------|--------|----------|---------|---| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | pwidth <1:0> Pixel width. Specifies the normal pixel width for drawing | pwic | dth | | |-------------|----------|--------| | Value | Mnemonic | Mode | | '00' | PW8 | 8 bpp | | '01' | PW16 | 16 bpp | | '10' | PW32 | 32 bpp | | <b>'11'</b> | PW24 | 24 bpp | *Note:* In 4:2:0 mode, **pwidth** *must* be set to PW8. zwidth <4:3> Z depth width. Specifies the size of Z values: | zwic | lth | | |-------------|----------|--------------------------------------------| | Value | Mnemonic | Mode | | '00' | ZW16 | 16 bit Zdepth buffer, No Stencil buffer | | '01' | ZW32 | 32 bit Zdepth buffer, No Stencil buffer | | '10' | ZW15 | 15 bit Zdepth buffer, 1 bit Stencil buffer | | <b>'11'</b> | ZW24 | 24 bit Zdepth buffer, 8 bit Stencil buffer | memreset <15> Resets the RAM. When this bit is set to '1', the memory sequencer will generate a reset cycle to the RAMs. •• Caution: Refer to Section 4.3.3 on page 4-24 for instructions on when to use this field. The **memreset** field must always be set to '0' except under specific conditions which occur during the reset sequence. fogen <26> Fogging Enable. Fogging can be performed on any 3D operation. Memory Access MACCESS bypass332 <28> This bit enables a bypass of the 332 format conversion in PW8 mode. - 0: Disable bypass1: Enable bypass - •• Note: In 4:2:0 mode, this bit must be set to '1'. tlutload <29> Texture LUT load. When this bit is set to '1' during an ILOAD or BITBLT operation, the destination becomes the texture LUT rather than the frame buffer. nodither <30> Enable/disable dithering. - 0: Dithering is performed on unformatted ILOAD, ZI, and I trapezoids. - 1: Dithering is disabled. - **Note:** In 4:2:0 mode, **nodither** must be set to '1'. dit555 <31> Dither 5:5:5 mode. This field should normally be set to '0', except for 16 bit/pixel configurations, when it affects dithering and shading. - 0: The pixel format is 5:6:51: The pixel format is 5:5:5 - Reserved For Rev. A only <2> <14:5> <25:16> <28:27> Reserved <2> <14:4> <25:16> <27> Address MGABASE1 + 1C08h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value 1000 0100 1010 0100 1001 1001 0010 0001b | | bpldelay | | Reserved | - | pwcdelay | Reserved | | smraeiay | Reserved | rddelay | Reserved | Yolo barr | widelay | Postrada | עפאפו אפר | yelobar | - paciay | Reserved | | rasmin | | | | ıcuuelay | | 7000 | rrageiay | | | casitncy | | |----|----------|----|----------|----|----------|----------|----|----------|----------|---------|----------|-----------|---------|----------|-----------|---------|----------|----------|----|--------|----|---|---|----------|---|------|----------|---|---|----------|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | casltncy <2:0> CAS Latency. This field *must* be programmed prior to executing the memory power-up sequence. This field *must* be loaded before initiating a memory test. | casltncy | CAS Latency (mclk) | |----------|--------------------| | '000' | 2 cycles | | '001' | 3 cycles | | '010' | 4 cycles | | '011' | Reserved | | '1XX' | Reserved | rrddelay <5:4> Minimum RAS to RAS Delay. This field *must* be loaded before attempting to read or write to the frame buffer. | rrddelay | RAS to RAS Delay (mclk) | |-------------|-------------------------| | '00' | 1 cycle | | '01' | 2 cycles | | '10' | 3 cycles | | <b>'11'</b> | Reserved | rcddelay <8:7> Minimum RAS to CAS Delay. This field *must* be loaded before attempting to read or write to the frame buffer. | rcddelay | RAS to CAS Delay (mclk) | |-------------|-------------------------| | '00' | 2 cycles | | '01' | 3 cycles | | '10' | 4 cycles | | <b>'11'</b> | Reserved | rasmin <12:10> RAS Minimum active time. This field *must* be loaded before initiating a memory reset. | rasmin | RAS Minimum (mclk) | |--------|--------------------| | '000' | 3 cycles | | '001' | 4 cycles | | '010' | 5 cycles | | '011' | 6 cycles | | '100' | 7 cycles | | '101' | 8 cycles | | '11X' | Reserved | rpdelay <15:14> Minimum RAS precharge Delay. This field *must* be loaded before initiating a memory reset. | rpdelay | Precharge to Activate Delay (mclk) | |-------------|------------------------------------| | '00' | 2 cycles | | '01' | 3 cycles | | '10' | 4 cycles | | <b>'11'</b> | 5 cycles | wrdelay <19:18> Minimum Write Recovery Delay. This field *must* be loaded before attempting to read or write to the frame buffer. | wrdelay | Write to Precharge Delay (mclk) | |---------|---------------------------------| | '00' | 1 cycle | | '01' | 2 cycles | | '1X' | Reserved | rddelay <21> Minimum Read to Precharge Delay. This field *must* be loaded before attempting to read or write to the frame buffer. | rddelay | Read to Precharge Delay | |------------|-------------------------------------| | '0' | n cycles | | <b>'1'</b> | $n + (CL - 2) \text{ cycles}^{(1)}$ | Where n = the amount of data to be read and CL = CAS latency (2, 3, 4, 5). # smrdelay <24:23> Minimum Special Mode Register Delay. This field *must* be loaded before attempting to read or write to the frame buffer. | smrdelay | SMR to Command Delay (mclk) | |----------|-----------------------------| | '00' | 1 cycle | | '01' | 2 cycles | | '1X' | Reserved | # bwcdelay <27:26> Minimum Block Write Cycle Delay. This field *must* be loaded before attempting to read or write to the frame buffer. | bwcdelay | Block Write Cycle Delay (mclk) | |----------|--------------------------------| | '00' | 1 cycle | | '01' | 2 cycles | | '1X' | Reserved | # bpldelay <31:29> Minimum Block write to Precharge Delay. This field *must* be loaded before attempting to read or write to the frame buffer. | bpldelay | Block Write to Precharge Delay (mclk) | |----------|---------------------------------------| | '000' | 1 cycle | | '001' | 2 cycles | | '010' | 3 cycles | | '011' | 4 cycles | | '100' | 5 cycles | | '101' | Reserved | | '11X' | Reserved | #### Reserved <3> <6> <9> <13> <17:16> <20> <22> <25> <28> Address MGABASE1 + 1E44h (MEM) Attributes R/W, FIFO, STATIC, BYTE/WORD/DWORD Reset Value 0000 0000 0000 0000 0001 0000 1000b | | Reserved | n | nrs | юр | cod | d | Reserved | 140900340 | | | | | | ı | Res | ser | vec | ı | | | | | m | clk | bro | <b>d1</b> | Reserved | m | clk | brc | 10 | |----|----------|----|-----|----|-----|----|----------|-----------|----|----|----|----|----|----|-----|-----|-----|----|----|----|----|---|---|-----|-----|-----------|----------|---|-----|-----|----| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | #### mclkbrd0 <3:0> Memory Clock Base Read Delay 0. This field *must* be loaded after initiating a memory reset and before attempting any other access to the frame buffer. This field is used to adjust the delay on the clock/strobe used to register/latch the read-back data, MDQ(63:0), from the two banks on the base board. The pointer, **mclkbrd0**, determines where the delay-line for the read-back clock will be tapped. Each increment of **mclkbrd0** adds approximately 0.1ns to the delay on the read-back clock. - '0000': minimum delay added - '1111': maximum delay added - •• *Note:* This field should be *INVISIBLE* to the user. Software will set the field using read/write trails (which vary the field). # mclkbrd1 <8:5> Memory Clock Base Read Delay 1. This field must be loaded after initiating a memory reset and before attempting another access to the frame buffer. This field is used to adjust the delay on the clock/strobe used to register/latch the read-back data, MDQ2(63:0), from the two banks on the base board. The pointer, **mclkbrd1**, determines where the delay-line for the read-back clock will be tapped. Each increment of **mclkbrd1** adds approximately 0.1ns to the delay on the read-back clock. - '0000': minimum delay added - '1111': maximum delay added - **Note:** This field should be *INVISIBLE* to the user. Software will set the field using read/write trails (which vary the field) # strmfctl <23:22> Streamer Flow Control. This field is used to ensure that CRTC latencies are respected. | strmfctl | description | |-------------|---------------------------------| | '00' | Do not block access to streamer | | 00 | pipe. | | | A maximum of TWO non- | | '01' | CRTC commands can be in the | | | streamer pipe at any time. | | | A maximum of ONE non- | | <b>'10'</b> | CRTC commands can be in the | | | streamer pipe at any time. | | <b>'11'</b> | Reserved | # mrsopcod <29:25> Mode Register Set command OPCODe. This field *must* be loaded before initializing a memory reset or attempting to read or write to the frame buffer. This field is used to fill in the 5 MSB (MA(11:7)) of the Mode register set command's opcode. This field *must* be programmed with '0000' during normal operation. #### Reserved #### <4> <21:9> <24> <31:30> Operating Mode OPMODE Address MGABASE1 + 1E54h (MEM) Attributes R/W, STATIC, WORD/DWORD **Reset Value** 0000 0000 0000 00<u>00</u> 0000 00<u>00</u> 0000 <u>00</u>00b Reserved F dmamod <3:2> Select the Pseudo-DMA transfer mode. | dmamod<1:0> | DMA Transfer Mode Description | |-------------|-------------------------------| | '00' | DMA General Purpose Write | | '01' | DMA BLIT Write | | '10' | DMA Vector Write | | <b>'11'</b> | DMA Vertex Write | •• Note: Writing to byte 0 of this register will terminate the current DMA sequence and initialize the machine for the new mode (even if the value did *not* change). This effect should be used to break an incomplete packet. dmadatasiz <9:8> DMAWIN data size. Controls a hardware swapper for Big-Endian processor support during access to the DMAWIN space or to the 8 MByte Pseudo-DMA window. Normally, **dmadatasiz** is '00' for any DMA mode except DMA BLIT WRITE. | dmadatasiz <1:0> | Endian<br>Format | | | <i>Written to Regist</i> reg<23:16> | | reg<7:0> | |------------------|------------------|----------|-------------|-------------------------------------|------------|------------| | '00' | little | any | DAD <21.24> | PAD<23:16> | DAD <15.9> | PAD<7:0> | | 00 | big | 8 bpp | TAD<31.24> | FAD<23.10> | FAD<13.6> | FAD< 7.0> | | <b>'</b> 01' | big | 16 bpp | PAD<23:16> | PAD<31:24> | PAD<7:0> | PAD<15:8> | | <b>'10'</b> | big | 32 bpp | PAD<7:0> | PAD<15:8> | PAD<23:16> | PAD<31:24> | | <b>'11'</b> | big | Reserved | | | | | dirdatasiz <17:16> Direct frame buffer access data size. Controls a hardware swapper for Big-Endian processor support during access to the full frame buffer aperture or the VGA frame buffer aperture. | dirdatasiz <1:0> | Endian<br>Format | Data<br>Size | | Written to Register whem < 23:16 > | ter mem<15:8> | mem<7:0> | |------------------|------------------|--------------|-------------|------------------------------------|---------------|------------| | '00' | little | any | DAD <21.24> | PAD<23:16> | DAD <15.0> | PAD<7:0> | | '00' | big | 8 bpp | PAD<31:24> | PAD<23:10> | PAD<15:8> | PAD< 7:0> | | <b>'</b> 01' | big | 16 bpp | PAD<23:16> | PAD<31:24> | PAD<7:0> | PAD<15:8> | | <b>'10'</b> | big | 32 bpp | PAD<7:0> | PAD<15:8> | PAD<23:16> | PAD<31:24> | | <b>'11'</b> | big | Reserved | | | | | ◆ *Note*: **dirdatasiz** must be modified *only* when there are *no* frame buffer reads pending. #### Reserved <1:0> <1:0> <7:4> <15:10> <31:18> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. Reading will return '0's. Pattern PAT0, PAT1 Address MGABASE1 + 1C10h MGABASE1 + 1C14h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown | | | | | oati | eg | 1 | | | | | | | F | atr | eg | U | | | | |----|--|--|--|------|----|---|--|--|----|----|--|--|---|-----|----|---|------|--|---| | | | | | | | | | | | | | | | | | | <br> | | | | 63 | | | | | | | | | 32 | 31 | | | | | | | | | 0 | patreg <63:0> Pattern register. The **PAT** registers are *not* physical registers. They simply provide an alternate way to load the **SRC** registers with a Windows format 8 x 8 pattern. The following illustration shows how the data written to the **PAT** registers is mapped into the frame buffer. The screen representation is shown below: The pattern-pixel pinning can be changed using the **x\_off** and **y\_off** fields of the **SHIFT** register. See the **SRC0**, **SRC1**, **SRC2**, **SRC3** register on page 3-186. PITCH Memory Pitch Address MGABASE1 + 1C8Ch (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown | | | | | | | _ | | | | | | | | | | <u>li</u> | 70%1000 | יפספו אפת | | | | | | | | | | | | | | |---|------|----------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|---------|-----------|----|----|----|----|---|---|---|---|---|---|---|---|---| | _ | | Reserved $\stackrel{:=}{\sim}$ $\stackrel{\omega}{\sim}$ | | | | | | | | | | | | | | | | | | | | ıy | | | | | | | | | | | | | | | | | _ | | | - | - | - | | | | | | | | | | | _ | | | _ | | 1 | 1 | 1 | | | | 3 | 1 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | iy <12:0> The y-increment. This field is a 13-bit unsigned value. The y-increment value is measured in pixel unit and must be a multiple of 32 (the five LSB = 0). It must be less than or equal to 4096. The **iy** field specifies the increment to be added to or subtracted from **ydst** (see **YDST** on page 3-283) between two destination lines. The **iy** field is also used as the multiplication factor for linearizing the **ydst** register. •• *Note:* Every pitch that is a multiple of 32 (within the range of 32 to 4096 inclusive) is supported for linearization by the hardware. This register must be loaded with a value that is a multiple of 32 or 64 due to a restriction involving block mode, according to the table below. See 'Constant Shaded Trapezoids / Rectangle Fills' on page 4-38. See page 3-133 for additional restrictions that apply to block mode (atype = BLK). | pwidth | value | |--------|-------| | PW8 | 64 | | PW16 | 32 | | PW24 | 64 | | PW32 | 32 | ylin <15> The y-linearization. This bit specifies whether the address must be linearized or not. - 0: The address is an xy address, so it must be linearized by the hardware - 1: The address is already linear Reserved <14:13> <31:16> Plane Write Mask PLNW1 Address MGABASE1 + 1C1Ch (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown #### plnwrmsk | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| # plnwrmsk <31:0> Plane write mask. Plane(s) to be protected during any write operations. The plane write mask is *not* used for z cycles, or for direct write access (all planes are written in this case). • 0 = inhibit write • 1 = permit write The bits from the **plnwrmsk**<31:0> register are output on the MDQ<31:0> signal and also on MDQ<63:32>. In 8 and 16 bit/pixel configurations, all bits in **plnwrmsk**<31:0> are used, so the mask information must be replicated on all bytes. In 24 bits/pixel, the plane masking feature is limited to the case of all three colors having the same mask. The four bytes of **plnwrmsk** must be identical. Refer to 'Pixel Format' on page 4-21 for the definition of the slice in each mode. Address MGABASE1 + 1E58h (MEM) Attributes R/W, DYNAMIC, BYTE/WORD/DWORD ### primaddress | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| #### primod <1:0> Primary Pseudo-DMA mode. This static field indicates the Pseudo-DMA mode to be used to transfer data from system memory to the MGA in mastering mode through the primary DMA channel. | primod | DMA Transfer Mode | |-------------|---------------------------| | '00' | DMA General Purpose Write | | '01' | DMA Blit Write | | '10' | DMA Vector Write | | <b>'11'</b> | DMA Vertex Write | # primaddress <31:2> Primary current address. This field indicates the address to be used to access the primary DMA channel in the system memory when the Matrox G400 is performing bus mastering. The start address value of the primary display list must be written to this register before **PRIMEND** is written to. The primaddress field is increased by one every time the Matrox G400 terminates a read access at primaddress in the system memory. If, when increased, **primaddress** becomes equal to **primend**, the primary channel is empty. Bus mastering stops, and **endprdmasts** is set (refer to the **STATUS** register description). Refer to 'Programming Bus Mastering for DMA Transfers' on page 4-12 for more details. Address MGABASE1 + 1E5Ch (MEM) Attributes R/W, STATIC, BYTE/WORD/DWORD > pagpxfer primnostart | primend | | | | | | | | | |---------|---|---|---|---|---|----|---|--| | | 1 | r | n | Δ | m | rı | n | | | P | 4 | v | | C | | | μ | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| primnostart <0> Primary No Start. Writing the **PRIMEND** register with this bit set to '1' will *not* restart the primary DMA Channel while a Softrap Interrupt is pending. pagpxfer <1> Primary AGP Transfer. When '1', the AGP bus cycle will be used for primary DMA data transfer, otherwise, the PCI cycle will be used. primend <31:2> Primary end address. The primend field holds the end address $+\ 1$ of the primary display list in the system memory, when doing bus mastering. Writing to this field will *start* the transfers from the primary DMA channel in the Matrox G400 (unless primnostart = 0), therefore, PRIMEND is the last register to be written to (unless primnostart = 0). Refer to 'Programming Bus Mastering for DMA Transfers' on page 4-12 for more details. Z 0 Address MGABASE1 + 1E50h (MEM) Attributes R/W, STATIC, BYTE/WORD/DWORD **Reset Value** ???? ???? ???? ???? ???? 0000b | ī | | | | | | | | | | | | | pr | im | ptr | | | | | | | | | | | | | | Reserved | | primptren | primptren | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|----|----|----|-------|----|----|---|---|---|---|---|---|----------|---|-----------|-----------| | İ | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | l In | 15 | 14 | 13 | 1 / 1 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ### primptren0 <0> Primary list status fetch Pointer Enable 0. When set to '1', a double-qword of status data information is written to the system memory (using PCI cycle) at the address corresponding to **primptr** every time a Softrap or Secend or Setupend register write occurs. Status data information: 1st dword: PRIMADDRESS register 2nd dword: DWGSYNC register • 3<sup>rd</sup> dword: Reserved • 4<sup>th</sup> dword: Reserved #### primptren1 <1> Primary list status fetch Pointer Enable 1. When set to '1', a qword of status data information is written to the system memory (using PCI cycle) at the address corresponding to **primptr** every time a **DWGSYNC** register write occurs. # primptr <31:4> Primary list status fetch Pointer. This is the paragraph address where the status data will be placed in system memory. ◆ *Note:* This address *must* be in a PCI accessible range ### Reserved <4:2> Reset RST Address MGABASE1 + 1E40h (MEM) Attributes R/W, STATIC, BYTE/WORD/DWORD > softextrst softreset #### Reserved | 3 | 1 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| # softreset <0> Soft reset. When set to '1', this resets all bits that allow software resets. This has the effect of flushing the BFIFO and the direct access read cache, and aborting the current drawing instruction. A soft reset will *not* generate invalid memory cycles; memory contents are preserved. The **softreset** signal takes place at the end of the PCI write cycle. The reset bit must be maintained at '1' for a minimum of 10 µs to ensure correct reset. After that period, a '0' must be programmed to remove the soft reset. This will: - reset the set-up engine and set-up engine fifo - terminate any bus mastering or pseudo-dma transfer - return some register bits to their soft-reset values (see individual registers). Refer to Section 4.3.3 on page 4-24 for instructions on when to use this field. ◆ WARNING! A soft reset will not re-read the chip strapping. ### softextrst <1> External Software Reset. When set to '1', this will activate the external reset pin (EXTRSTN). The external reset will remain active until this bit is reset to '0'. #### Reserved Reserved. When writing to this register, the bits in this field *must* be set to '0'. **<31:2>** Reading will return '0's. Address MGABASE1 + 2C40h (MEM) Attributes R/W, FIFO, DYNAMIC, DWORD Secmod #### secaddress | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| # secmod <1:0> Secondary Pseudo-DMA mode. This static field indicates the Pseudo-DMA mode to be used to transfer data from system memory to the MGA in mastering mode through the secondary DMA channel. | secmod | DMA Transfer Mode | |-------------|---------------------------| | '00' | DMA General Purpose Write | | '01' | DMA Blit Write | | '10' | DMA Vector Write | | <b>'11'</b> | DMA Vertex Write | # secaddress <31:2> Secondary DMA Address. This field indicates the address to be used to access the secondary DMA channel in the system memory when the Matrox G400 is performing bus mastering. The start address value of the secondary DMA channel must be written to this register before **SECEND** is written to. The field secaddress is increased by one every time the Matrox G400 terminates a read access at **secaddress** in the system memory. If, when incremented, **secaddress** becomes equal to **secend**, the secondary channel is empty. Bus mastering then continues, using the primary channel. The data that is written to the **SOFTRAP** register will also be loaded into the **secaddress** field. Note: It is not possible to write to this register directly. Write access must absolutely be performed through mastering mode. That is, a primary display list must be programmed. Refer to 'Programming Bus Mastering for DMA Transfers' on page 4-12 for more details. Address MGABASE1 + 2C44h (MEM) Attributes R/W, FIFO, STATIC, DWORD > sagpxfer Reserved #### secend | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| Secondary AGP Transfer. When '1', the AGP bus cycle will be used for secondaryDMA data transfer, otherwise, the PCI cycle will be used. secend Secondary End address. The **secend** field holds the end address + 1 of the secondary **Secondary** DMA channel in the system memory, when doing bus mastering. Writing to this field will *start* the secondary DMA transfers by the Matrox G400 using bus mastering. The **SECEND** register must always be written to after **SECADDRESS**. Note: It is not possible to write to this register directly. Write access must absolutely be performed through mastering mode. That is, a primary display list must be programmed. Refer to 'Programming Bus Mastering for DMA Transfers' on page 4-12 for more details. Reserved Reserved. When writing to this register, the bit in this field *must* be set to'0'. Reading will give '0's. Address MGABASE1 + 2CD0h (MEM) Attributes R/W, FIFO, DYNAMIC, DWORD setupmod #### setupaddress | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 4 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 10 | 10 | 17 | 16 | 15 | 1.4 | 13 | 12 | 11 | 10 | a | 8 | 7 | 6 | 5 | 1 | 3 | 2 | 1 | Λ | | | 31 | 30 | 29 | 20 | 21 | 20 | 23 | 24 | 23 | 22 | 21 | 20 | 19 | 10 | 1 / | 10 | 13 | 14 | 13 | 12 | 11 | 10 | 9 | 0 | / | 6 | 5 | 4 | 3 | | 1 | U | | ### setupmod <1:0> Setup Pseudo-DMA mode. This static field indicates the Pseudo-Dma mode to be used to transfer data from system memory to the MGA in mastering mode through the setup DMA channel. | setupmod | Setup DMA Transfer Mode | |-------------|-------------------------| | '00' | DMA Vertex Fixed Length | | | Setup List | | '01' | Reserved | | '10' | Reserved | | <b>'11'</b> | Reserved | #### setup address <31:2> Setup DMA Address. This field indicates the addresses to be used to access the setup DMA channel in system memory when the Matrox G400 is performing bus mastering. The start address value of the setup DMA channel must be written to this register before **setupend** is written to. The **setupaddress** increases by one every time the Matrox G400 terminates a read access at **setupaddress** in the system memory. If, after being incremented, **setupaddress** becomes equal to **setupend**, the setup channel is empty. When the last setup DMA generated by the current setup list is complete, bus mastering continues using the primary channel. Note: It is not possible to write to this register directly. Write access must absolutely be performed through mastering mode. That is, a primary display list must be programmed. Refer to 'Programming Bus Mastering for DMA Transfers' on page 4-12 for more details. Address MGABASE1 + 2CD4h (MEM) Attributes R/W, FIFO, STATIC, DWORD > setupagpxfer Reserved #### setupend | 31 30 | 0 29 | 28 | 27 2 | 6 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|------|----|------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| setupagpxfer <1> Setup AGP transfer. When '1', the AGP bus cycle will be used for setup DMA data transfer, otherwise, the PCI cycle will be used. setupend <31:2> Setup End address. The **setupend** field holds the end address + 1 of the setup DMA channel in the system memory, when bus mastering. Writing to this field will start the setup DMA transfer by the Matrox G400 using bus mastering. The **SETUPEND** register must always be written to after **SETUPADDRESS**. Note: It is not possible to write to this register directly. Write access must absolutely be performed through mastering mode. That is, a primary display list must be programmed. Refer to 'Programming Bus Mastering for DMA Transfers' on page 4-12 for more details. Reserved <0> Reserved. When writing to this register, the bit in this field *must* be set to '0'. Reading will give '0's. SGN Sign Address MGABASE1 + 1C58h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD **Reset Value** 0??? ???? ???? ???? ???? ???? ????b | errorinit | | | Res | ser | vec | i | | | | | brkrighttop | subpixen | centersnap | sn | sse | spe | PI | fastcrop | brklefttop | brkleft | 000000 | Pesei ved | sdxr | Course | บ | sdy | sdxl | scanleft | |-----------|-------|----|-----|-----|-----|----|----|----|----|----|-------------|----------|------------|----|-----|-----|----|----------|------------|---------|--------|-----------|------|--------|---|-----|------|----------| | | | ļ. | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 30 29 | 28 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | dydxl sdydxl <0> Sign of delta y minus delta x. This bit is shared with **scanleft**. It is defined for LINE drawing only and specifies the major axis. This bit is automatically initialized during AUTOLINE operations. 0: major axis is y1: major axis is x scanleft <0> Horizontal scan direction left (1) vs. right (0). This bit is shared with **sdydxl** and affects TRAPs and BLITs; **scanleft** is set according to the x scanning direction in a BLIT. Normally, this bit is always programmed to zero except for BITBLT when **bltmod** = BFCOL (see **DWGCTL** on page 3-132). For TRAP drawing, this bit must be set to '0' (scan right). sdxl <1> Sign of delta x (line draw or left trapezoid edge). The **sdxl** field specifies the x direction for a line draw (**opcod** = LINE) or the x direction when plotting the left edge in a filled trapezoid draw. This bit is automatically initialized during AUTOLINE operations. - 0: delta x is positive - 1: delta x is negative sdy <2> Sign of delta y. The **sdy** field specifies the y direction of the destination address. This bit is automatically initialized during AUTOLINE operations. This bit should be programmed to zero for TRAP. - 0: delta y is positive - 1: delta y is negative Sign SGN #### sdxr <5> Sign of delta x (right trapezoid edge). The **sdxr** field specifies the x direction of the right edge of a filled trapezoid. - 0: delta x is positive - 1: delta x is negative #### brkleft <8> Broken left. For trapezoid with subpixel positioning, the start value of the bottom-trap must be adjusted due to the change of the left slope. - 0: No pixel adjustment - 1: Adjust the left edge with the new FXLEFT value #### brklefttop <9> Broken Left Top. When this bit is set to '1', the drawing engine will **not** adjust the left edge on the last line when **opcod** = TRAP or TEXTURE\_TRAP. When **brklefttop** and **brkrighttop** are set to '1', the drawing engine will **not** adjust the left edge vertical scan on the last line. #### fastcrop <10> Fast Cropping. When this bit is set to '1', the drawing engine will **not** scan the left and right edge when **opcod** = TRAP or TEXTURE\_MAP **if** the current line is below the clipping window. bl <11> Broken Left triangle. This flag is used by the subpixel module. It specifies which edge is broken for a trap. $\mathbf{bl} = 0$ : for a broken *right* $\mathbf{bl} = 1$ : for a broken *left* sbe <12> Setup Broken Edge. This flag is used by the subpixel module. When set, the subpixel module will process the broken edge specified by SGN.BL. sse <13> Setup Shared Edge. This flag is used by the subpixel module. When this bit is set, the subpixel module will process the shared edge. us <14> Update Start value in subpixel. When this is set, a subpixel adjustment will be made on all start values. ### centersnap <15> Center Snap. This flag is used by the subpixel module. When set, the subpixel module will adjust the start value to the center of the integer pixel grid. ### subpixen <16> Subpixel Enable. This bit *must* be set to enable subpixel adjustment. This bit is reset after each primitive. ### brkrighttop <17> Broken Right Top. When this bit is set to '1', the drawing engine will *not* adjust the right edge on the last line when opcod = TRAP or TEXTURE\_TRAP. When **brklefttop** and **brkrighttop** are set to '1', the drawing engine will *not* adjust the left edge vertical scan on the last line. # errorinit <31> This bit is used when **opcod** = AUTOLINE\_OPEN or AUTOLINE\_CLOSE. It specifies the content of AR1 at the end of the initialization sequence. - 0: AR1 holds 2x'b'-'a'- sdy - 1: AR1 holds 2x'b'-'a'-MGAQuadrantError SGN Sign where MGAQuadrantError takes the following values: "1"- Indicates the quadrants in which the error term should be biased. The MGA's convention for numbering the quadrants is as follows, where 'sdydxl\_Major\_X' = 1, 'sdxl\_SUB' = 2, 'sdy\_SUB' = 4 then: $MGAQuadrantError (sdydx1 + (sdx1 << 1) + (sdy << 2)) = { 1,1,0,1,1,0,0,0 }$ Reserved #### <4:3> <7:6> <30:17> Address MGABASE1 + 1C50h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown | Reserve | ed | styl | lelen | | | Res | erve | funcnt | | | | | | | | | | | | |---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|----------|--------|------|-------|-------|--------|-----|------------|------|--------|-----|--------------|--|--|--|--|--| | 31 30 29 28 27 2 | 6 25 24 23 22 | 21 20 1 | 19 18 17 | 7 16 1 | 5 14 | 13 12 | 11 10 | 9 | 8 7 | 6 | 5 4 | 3 | 2 | 1 0 | | | | | | | Reser | ved | fı | unoff | | | Res | erve | b | | <b>y</b> . | _off | | x_o | ff | | | | | | | x_off<br><3:0> | Pattern x offset. This field is used for TRAP operations without depth, to specific offset in the pattern. This offset must be in the range 0-7 (bit 3 is always '0'). | | | | | | | | | | | | | the x | | | | | | | | This field will be modified during Blit operations. | | | | | | | | | | | | | | | | | | | | funcnt | | | | | | | | | | | | | | t selection. | | | | | | | <6:0> | • For LINE of initialized to | E operations, this is a countdown register. For 3D vectors, this field must d to '0'. | | | | | | | | | | ist be | | | | | | | | | | This field will be modified during Blit operations. | | | | | | | | | | | | | | | | | | | | y_off<br><6:4> | Pattern y offset. This field is used for TRAP operations without depth, to specify the y offset in the pattern. | | | | | | | | | | | | | | | | | | | | | This field will be modified during Blit operations. | | | | | | | | | | | | | | | | | | | | funoff<br><21:16> | Funnel shifter | | | - | | | | | | | • | | | in the | | | | | | | stylelen<br><22:16> | funnel shifter count. In this case <b>funoff</b> is interpreted as a 6-bit signed value. Line style length. For LINE operations, this field specifies the linestyle length indicates a location in the <b>SRC</b> registers (see page 3-186), so its value is the nu bits in the complete pattern minus one. For 3D vectors, this field must be initiation. | | | | | | | | | | | | | er of | | | | | | Reserved <15:7> <31:23/22> Address MGABASE1 + 2C48h (MEM) Attributes R/W, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved #### softraphand | 3 | 1 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| # softraphand <31:2> Soft trap handle. When this field is written, a soft trap interrupt is generated, and the primary DMA channel is stopped (the **softrapen** and **endprdmasts** fields of **STATUS** are set to '1'). To restart the primary DMA channel, **PRIMEND** must be written. **SOFTRAP** can only be written by the primary DMA channel. Data written to the **softraphand** field is actually loaded into the **secaddress** field of **SECADDRESS** (which is temporarily borrowed for use by this function). This same mechanism could be used by software to transfer information to the interrupt handler. Note: It is not possible to write to this register directly. Write access must absolutely be performed through mastering mode. That is, a primary display list must be programmed. Refer to 'Programming Bus Mastering for DMA Transfers' on page 4-12 for more details. # Reserved <1:0> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Reading will return '0's. Address MGABASE1 + 2C98h (MEM) Attributes R/W, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved specbstart | Γ | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| specbstart <23:0> Specular Lighting Blue Start value. This field holds a signed 9.15 value in two's complement notation. For TEXTURE\_TRAP primitives, the **SPECBSTART** register must be initialized with the starting specular light value for the blue component. Reserved <31:24> Address MGABASE1 + 2C9Ch (MEM) Attributes R/W, FIFO, STATIC, DWORD Reset Value unknown Reserved specbxinc | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| specbxinc <23:0> Specular Lighting Blue X Increment value. This field holds a signed 9.15 value in two's complement notation. For TEXTURE\_TRAP primitives, the **SPECBXINC** register holds the blue increment value along the x-axis. Reserved <31:24> Address MGABASE1 + 2CA0h (MEM) Attributes R/W, FIFO, STATIC, DWORD Reset Value unknown Reserved specbyinc specbyinc <23:0> Specular Lighting Blue Y Increment value. This field holds a signed 9.15 value in two's complement notation. For TEXTURE\_TRAP primitives, the **SPECBYINC** register holds the blue increment value along the y-axis. Reserved <31:24> Address MGABASE1 + 2C8Ch (MEM) Attributes R/W, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved specgstart | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| specgstart <23:0> Specular Lighting Green Start value. This field holds a signed 9.15 value in two's complement notation. For TEXTURE\_TRAP primitives, the **SPECGSTART** register must be initialized with the starting specular light value for the green component. Reserved <31:24> Reset Value unknown Reserved specgxinc | 9. | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| specgxinc <23:0> Specular Lighting Green X Increment value. This field holds a signed 9.15 value in two's complement notation. For TEXTURE\_TRAP primitives, the **SPECGXINC** register holds the green increment value along the x-axis. Reserved <31:24> Address MGABASE1 + 2C94h (MEM) Attributes R/W, FIFO, STATIC, DWORD Reset Value unknown Reserved specgyinc | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| specgyinc <23:0> Specular Lighting Green Y Increment value. This field holds a signed 9.15 value in two's complement notation. For TEXTURE\_TRAP primitives, the **SPECGYINC** register holds the green increment value along the y-axis. Reserved <31:24> Address MGABASE1 + 2C80h (MEM) Attributes R/W, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved specrstart | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| specrstart Specular Lighting Red Start value. This field holds a signed 9.15 value in two's **<23:0>** complement notation. For TEXTURE\_TRAP primitives, the **SPECRSTART** register must be initialized with the starting specular light value for the red component. Reserved <31:24> Address MGABASE1 + 2C84h (MEM) Attributes R/W, BYTE/WORD/DWORD, DYNAMIC Reset Value unknown Reserved specrxinc | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| specrxinc <23:0> Specular Lighting Red X Increment value. This field holds a signed 9.15 value in two's complement notation. For TEXTURE\_TRAP primitives, the **SPECRXINC** register holds the red increment value along the x-axis. Reserved <31:24> Address MGABASE1 + 2C88h (MEM) Attributes R/W, FIFO, STATIC, DWORD Reset Value unknown | specryinc | |-----------| | | | ı | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | specryinc <23:0> Specular Lighting Red X Increment value. This field holds a signed 9.15 value in two's complement notation. For TEXTURE\_TRAP primitives, the **SPECRYINC** register holds the red increment value along the y-axis. Reserved <31:24> **Address** MGABASE1 + 1C30h, + 1C34h, + 1C38h, + 1C3Ch (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown | | S | rcr | eg | 3 | | | S | rcr | eg | 2 | | | S | rcr | eg | 1 | | | S | rcr | eg | 0 | | |-----|---|-----|----|---|----|----|---|-----|----|---|----|----|---|-----|----|---|----|----|---|-----|----|---|---| | | | | | | | | | | | | | | | | | | | | | | | | | | 127 | | | | | 96 | 95 | | | | | 64 | 63 | | | | | 32 | 31 | | | | | 0 | ### srcreg <127:0> Source register. The source register is used as source data for all drawing operations. For LINE with the RPL or RSTR attribute, the source register is used to store the line style. The **funcnt** field of the **SHIFT** register points to the selected source register bit being used as the linestyle for the current pixel. Refer to Section 4.5.4.3 on page 4-32 for more details. For TRAP with the RPL or RSTR attribute, the source register is used to store an $8 \times 8$ pattern (the odd bytes of the SRC registers must be a copy of the even bytes). Refer to Section 4.5.5.3 on page 4-38 for more details. For all BLIT operations, and for TRAP or LINE using depth mode, the source register is used internally for intermediate data. A write to the **PAT** registers (see page 3-161) will load the **SRC** registers. Source Origin SRCORO Address MGABASE1 + 2CB4h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value 0000 0000 0000 0000 0000 0000 0000 srcacc srcmap | | | | | | | | | | | | | src | org | 3 | | | | | | | | | | | | R | ese | rve | þ | ร | S | |----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|-----|---|---|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | srcmap <0> Source Map. A memory space indicator, this field indicates the map location. • 0: the source surface is in the frame buffer memory. • 1: the source surface is in the system memory. srcacc <1> Source Access type. This field specifies the mode used to access the map. • 0: PCI access. • 1: AGP access. •• *Note:* This field is *not* considered if the source resides in the frame buffer space. srcorg <31:6> Source Origin. This field provides an offset value for the position of the first pixel for a source surface. The **srcorg** field is used during BitBlit operations. The **srcorg** field corresponds to a 64-byte address in memory. Reserved <5:2> STATUS Status Address MGABASE1 + 1E14h (MEM) Attributes R/W, DYNAMIC, BYTE/WORD/DWORD Reset Value 0000 0000 0000 0010 0000 0000 0?00 0000b | Reset Value | <b>e</b> 0000 | 0000 | 0000 | 001 | 0 ( | 000 | 0 00 | 000 | <u>0</u> : | 00 | 00 | <u>0</u> 0 <u>C</u> | <u>)</u> b | | | | | | | | |---------------------|-------------------------|--------------------|----------------------|----------------------|-----------|---------|---------------|------|------------|-------|------------|---------------------|------------|--------|----------|----------|--------------|---------|----------|-----------| | swflag | Reserved | wfopath<br>wfipath | warpbfpath<br>wbusy1 | wbusy<br>endprdmasts | dwgengsts | n<br>Re | eserv | red | wcpen1 | wpen1 | c2vlinepen | wcpen | wben | extpen | vlinepen | vsyncpen | vsyncsts | pickpen | Reserved | softrapen | | 31 30 29 28 2 | 7 26 25 24 23 | 3 22 21 | 20 19 | 18 17 | 16 | 15 | 14 13 | 12 | | 10 | | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | softrapen<br>RO <0> | Soft trap<br>has stopp | | | _ | | | | | | | l inc | lica | tes | tha | ıt th | ne N | <b>A</b> at: | rox | G4( | 00 | | | This field<br>through t | | | | | | | • | _ | | | | | | | | | | | | | pickpen | Pick inter | rrupt pe | ending. | When | set | to ' | 1', in | dica | ites | tha | t a p | oick | int | terr | upt | ha | s oc | ccur | red | • | | RO <2> | This bit is or hard re | | d throu | igh the | pic | ckic | <b>Ir</b> bit | (see | IC | LE | AR ( | on | paç | ge : | 3-1 | 49) | or | upo | n s | oft | vsyncsts VSYNC status. Set to '1' during the VSYNC period. This bit follows the VSYNC signal. vsyncpen VSYNC interrupt pending. When set to '1', indicates that a VSYNC interrupt has occurred. (This bit is a copy of the **crtcintCRT** field of the **INSTS0** VGA register). This bit is cleared through the **vintclr** bit of **CRTC11** or upon hard reset. Vertical line interrupt pending. When set to '1', indicates that the vertical line counter has reached the value of the vertical interrupt line count. See the CRTC18 register on page 3-328. This bit is cleared through the vlineiclr bit (see ICLEAR on page 3-149) or upon soft or hard reset. External interrupt pending. When set to '1', indicates that the external interrupt line is driven. This bit is cleared by conforming to the interrupt clear protocol of the external device that drive the EXTINT/ line. After a hard reset, the state of this bit is unknown (as indicated by the question mark in the 'Reset Value' above), as it depends on the state of the EXTINT/ pin during the hard reset. WARP interrupt Pending. When set to '1', indicates that a WARP interrupt has occurred. This bit is cleared through the wiclr bit (see ICLEAR) or upon soft or hard reset. WARP Cache interrupt Pending. When set to '1', indicates that a WARP cache interrupt has occurred. This bit is cleared through the wciclr bit (see ICLEAR) or upon soft or hard reset. **c2vlinepen**RO <9> Second CRTC Vertical Line interrupt Pending. When set to '1', this indicates that the vertical line counter has reached the value of **c2vlinecomp** (see **C2MISC**). This bit is cleared through the **c2vlineclr** bit (see **ICLEAR**) or upon a soft or hard reset. wpen1 WARP interrupt Pending. When set to '1', indicates that a WARP1 interrupt has occurred. This bit is cleared through the wiclr bit (see ICLEAR) or upon soft or hard Status STATUS reset. # wcpen1 <11> WARP Cache interrupt Pending. When set to '1', indicates that a WARP1 cache interrupt has occurred. This bit is cleared through the **wciclr** bit (see **ICLEAR**) or upon soft or hard reset. ### dwgengsts RO <16> Drawing engine status. Set to '1' when the drawing engine is busy. A busy condition will be maintained during any of these conditions: - bfifo is *not* empty - warpfifo is *not* empty - the drawing engine is still processing and sending commands - the memory has not completed the last memory access (from the drawing engine). - The AGP chipset has not completed the last memory access (from the drawing engine). #### endprdmasts RO <17> End of primary DMA channel status. When set to '1', this bit indicates that the Matrox G400 has completed its DMA transfers (**primaddress** = **primend** and **secaddress** = **secend** and **setupaddress** = **setupend**), or when a soft trap interrupt occurs. Restarting the primary DMA by accessing **PRIMEND** will reset **endprdmasts** to '0'. •• Note: Refer to 'Programming Bus Mastering for DMA Transfers' on page 4-12 for more details. #### wbusy RO <18> WARP Busy. When set to '1', indicates that the WARP is *not* idle; it may be RUNning, WAITing, STALLed or loading microcode (cachemiss). ### wbusy1 RO <19> WARP Busy. When set to '1', indicates that the WARP1 is *not* idle; it may be RUNning, WAITing, STALLed or loading microcode (cachemiss). ### warpbfpath RO <20> WARP BFIFO Path. This bit indicates which WARP (between the BFIFO and the two WARPs) has the data path. - 0: WARP0 - 1: WARP1 # wfipath RO <21> WARPFIFO Input Path. This bit indicates which WARPFIFO (between the BFIFO and the two WARPFIFOs) has the data path. - 0: WARPFIFO0 - 1: WARPFIFO1 # wfopath RO <22> WARPFIFO Output Path. This bit indicates which WARPFIFO can start the new drawing primitive. It also indicates from which WARPFIFO the DATA ILOAD or DATA IDCT is expected. - 0: WARPFIFO0 - 1: WARPFIFO1 #### swflag R/W <31:28> Software Flag. These bits have no effect on the chip. STATUS Status #### Reserved <1 #### <1> <15:12> <27:23> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. Reading will return '0's. •• Note: A sample and hold circuit has been added to provide a correct, non-changing value during the full PCI read cycle (the status values are sampled at the start of the PCI access). Stencil STENCI $\begin{tabular}{lll} \textbf{Address} & MGABASE1 + 2CC8h \ (MEM) \\ \textbf{Attributes} & WO, FIFO, STATIC, DWORD \\ \end{tabular}$ Reset Value unknown | Reserved | d swtmsk | smsk | sref | | |-------------------|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|-----------------------------------|--| | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0 | | | sref<br><7:0> | Stencil Reference. The reference zwidth=ZW15. | | • | | | smsk<br><15:8> | Mask value used in the stencil te | st. Only <b>smsk</b> (0) is used i | n zwidtn=∠w13. | | | swtmsk<br><23:16> | Write Mask applies to any value in zwidth=ZW15 | written to the stencil buffer | r. Only <b>swtmsk</b> (0) is used | | | | <ul><li>0: writing <i>not</i> permitted</li><li>1: writing permitted</li></ul> | | | | | | New_SBUF = (SBUF & ~SWTMSK) (SBUF_UPDATED & SWTMSK) Reserved. When writing to this register, the bits in these fields must be set to '0'. | | | | | Reserved <31:24> | Reserved. When writing to this r | register, the bits in these fie | elds must be set to '0'. | | STENCILCTL Stencil Control Address MGABASE1 + 2CCCH (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown | | | | | | | | | R | ese | erve | ed | | | | | | | | | | szpassop | | sz | fail | ор | sf | aild | р | sn | noc | le_ | |----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----------|---|----|------|----|----|------|---|----|-----|-----| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | smode <2:0> Stencil comparison Mode. | sn | node | | |--------------|----------|---------------------------------| | value | mnemonic | stencil test pass when: | | '000' | SALWAYS | ALWAYS | | '001' | SNEVER | NEVER | | '010' | SE | (SREF & SMSK) = = (SBUF & SMSK) | | '011' | SNE | (SREF & SMSK) < > (SBUF & SMSK) | | <b>'100'</b> | SLT | (SREF & SMSK) < (SBUF & SMSK) | | '101' | SLTE | (SREF & SMSK) < = (SBUF & SMSK) | | <b>'110'</b> | SGT | (SREF & SMSK) > (SBUF & SMSK) | | <b>'111'</b> | SGTE | (SREF & SMSK) > = (SBUF & SMSK) | •• *Note:* SBUF is the value of the stencil buffer. The Zdepth and the pixel are updated when both the Z test and the stencil test pass. sfailop <5:3> Operations done on the stencil when the stencil test fails. | sfa | ilop | | | |---------------|----------|------------------------|---------------| | value | mnemonic | 8 bit stencil | 1 bit stencil | | ,000, | KEEP | SBUF(7:0) | SBUF(0) | | '001' | ZERO | 0 x 00 | ,0, | | '010' | REPLACE | SREF(7:0) | SREF(0) | | '011' | INCRSAT | MAX (0 x FF, SBUF + 1) | <b>'</b> 1' | | '100' | DECRSAT | MIN(0 x 00, SBUF - 1) | <b>'</b> 0' | | '101' | INVERT | ~ SBUF | ~ SBUF | | '110' | INCR | SBUF + 1 | SBUF + 1 | | '111 <b>'</b> | DECR | SBUF - 1 | SBUF - 1 | •• *Note:* SBUF is the value of the stencil buffer. Stencil Control STENCILCTL szfailop <8:6> Operation done on the stencil buffer when the stencil test passes and the Z test fails. | szf | ailop | | | |--------------|----------|------------------------|---------------| | value | mnemonic | 8 bit stencil | 1 bit stencil | | '000' | KEEP | SBUF(7:0) | SBUF(0) | | '001' | ZERO | 0 x 00 | <b>'</b> 0' | | '010' | REPLACE | SREF(7:0) | SREF(0) | | '011' | INCRSAT | MAX (0 x FF, SBUF + 1) | <b>'1'</b> | | '100' | DECRSAT | MIN(0 x 00, SBUF - 1) | <b>'</b> 0' | | '101' | INVERT | ~ SBUF | ~ SBUF | | '110' | INCR | SBUF + 1 | SBUF + 1 | | <b>'111'</b> | DECR | SBUF - 1 | SBUF - 1 | <sup>••</sup> *Note:* SBUF is the value of the stencil buffer. szpassop <11:9> Operations done on the stencil buffer when the stencil test passes and the Z test passes. | szpa | assop | | | |--------------|----------|------------------------|---------------| | value | mnemonic | 8 bit stencil | 1 bit stencil | | '000' | KEEP | SBUF(7:0) | SBUF(0) | | '001' | ZERO | 0 x 00 | <b>'</b> 0' | | '010' | REPLACE | SREF(7:0) | SREF(0) | | '011' | INCRSAT | MAX (0 x FF, SBUF + 1) | <b>'</b> 1' | | '100' | DECRSAT | MIN(0 x 00, SBUF - 1) | <b>'</b> 0' | | '101' | INVERT | ~ SBUF | ~ SBUF | | <b>'110'</b> | INCR | SBUF + 1 | SBUF + 1 | | <b>'111'</b> | DECR | SBUF - 1 | SBUF - 1 | <sup>••</sup> *Note:* SBUF is the value of the stencil buffer. Reserved <31:12> Address MGABASE1 + 2CF0h (MEM) Attributes WO, FIFO, STATIC, DWORD **Reset Value** ???? ???? ???? ???? ???? ???? ????b | | | bu | mp | ma | t11 | | | | | buı | mp | ma | t10 | ) | | | | buı | mp | ma | t01 | | | | | buı | mp | ma | t00 | | | |---|-----|------|----|----|-----|----|----|----|----|-----|----|----|-----|----|----|----|----|-----|----|----|-----|---|---|---|---|-----|----|----|-----|---|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 3 | 1 3 | 0 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | bumpmat00 Bump Mapping Transform matrix 00. This can be used to scale or rotate the Du and <7:0> Dv values. The format is defined by **bumpmatfmt** field. bumpmat01 Bump Mapping Transform matrix 01. This can be used to scale or rotate the Du and <15:8> Dv values. The format is defined by **bumpmatfmt** field. bumpmat10 Bump Mapping Transform matrix 10. This can be used to scale or rotate the Du and <23:16> Dv values. The format is defined by **bumpmatfmt** field. bumpmat11 Bump Mapping Transform matrix 11. This can be used to scale or rotate the Du and <31:24> Dv values. The format is defined by **bumpmatfmt** field. **Note:** These fields are signed values in two's complement notation. The range is [-127, 127]. The value -128 is *not* supported. Address MGABASE1 + 2CF4h (MEM) Attributes WO, FIFO, STATIC, DWORD **Reset Value** ???? ???? ???? ???? ???? ???? ????b bumpmatfmt bumplsfmt | | | | | Re | ser | vec | b | | | | 2 | 2 | 2 | 2 | | | bı | ım | plo | ffs | et | | | | | buı | mp | lsc | ale | | | |----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|---|---|---|---|-----|----|-----|-----|---|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | bumplscale <7:0> Bump map Luminance Scale value. Scale value for the bump map luminance. Format is defined by **bumplsfmt.** This field is a signed value in two's complement notation. bumploffset <16:8> Bump map Luminance Offset value. Offset value for the bump map luminance. It is a 9-bit signed value in two's complement notation. bumplsfmt <18:17> Bump map Luminance scale Format. This is used to change the format of the **bumplscale** field. '00': 0.8'01': 1.7'10': 2.6'11': 3.5 bumpmatfmt <20:19> Bump map Matrix Format. This is used to change the format of the **bumpmatxx** fields. '00': 0.8'01': 1.7'10': 2.6'11': 3.5 Reserved <31:21> Reserved. Writing to this field has no effect. Address MGABASE1 + 2CF8h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value 0000 0000 0000 0000 0000 0000 0000 | | aipnausei | alpha0add2x | alpha0addbias | alpha0add | alpha0arg2inv | alnha0ard2cal | pilavai y£3 | alpha0arg1inv | color0sel | | color0blend | color0addbias | color0add2x | color0add | color0modbright | | color0arg2add | color0arg1add | color0arg2mul | color0arg1mul | color0alpha2inv | color0alpha1inv | color0arg2inv | color0arg2alpha | color0arg1inv | color0arg1alpha | | color0alphasel | | color0arg2sel | | |----|-----------|-------------|---------------|-----------|---------------|---------------|-------------|---------------|-----------|----|-------------|---------------|-------------|-----------|-----------------|----|---------------|---------------|---------------|---------------|-----------------|-----------------|---------------|-----------------|---------------|-----------------|---|----------------|---|---------------|--------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 ( | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | $\neg$ | alpha0modbright color0arg2 • '00': diffuse sel <1:0> • '01': specular • '10': FCOL • '11': output from the previous stage (texture1) color0 alphasel • '000': diffuse • '001': FCOL aipnase <4:2> • '010': current texture (texture0) • '011': previous texture (Bumpmapping Luminance 'L') • '100': output from previous stage (texture1) color0arg1 alpha <5> color0arg1 inv <6> color0arg2 alpha <7> color0arg2 inv <8> color0alpha1 inv <9> ``` color0alpha2 inv <10> color0arg1 • 0: ARG1 mul • 1: ALPHA1 <11> color0arg2 • 0: ARG2 mul • 1: ALPHA2 <12> color0arq1 • 0: ARG1 add • 1: MULOUT <13> color0arg2 • 0: ARG2 add • 1: MULOUT <14> color0mod Modulation brightness. bright • '00': no effect <16:15> • '01': shift the result of the multiplication one bit left • '10': shift the result of the multiplication two bits left color0add • 0: SUB <17> • 1: ADD color0add2x add and double the result <18> color0add add with -0.5 bias bias <19> color0blend Linear Blending mode. In this mode, the processing unit operates in two passes. On <20> the first pass, color0arg1mul and color0arg2mul will have their programmed values. The result is kept in TMP. On the second pass, the arguments are swapped: color0arg1mul and color0arg2mul will be forced to NOT(color0arg1mul) and NOT(color0arg2mul) respectively. TMP is used instead of the output of the multiplier when in linear mode. color0sel • '00': ARG1 <22:21> • '01': ARG2 • '10': ADDOUT • '11': MULOUT alpha0arg1 inv <23> alpha0arg2 • '00': diffuse sel • '01': FCOL ``` • '10': previous texture (0 x 00) • '11': output from previous stage (texture1) <25:24> alpha0arg2 inv <26> alpha0add • 0: SUB <27> • 1: ADD alpha0add add with -0.5 bias bias <28> alpha0add2x add and double the result <29> alpha0mod bright <29:28> Modulation brightness. Replaces **alpha0addbias**<28> and **alpha0add2x**<29> when multiplication is used instead of addition. 1 • '00': no effect • '01': shift the result of the multiplication *one* bit left • '10': shift the result of the multiplication two bits left alpha0sel <31:30> • '00': ARG1 • '01': ARG2 • '10': ADD • '11': MUL Figure 3-1: Alpha Processing Unit Outn-1, Diff, Spec, Fact Tn Outn-1, Diff, Fact, Tn-1, Tn colorNarg2sel colorNalphasel -8:8:8:8 argb 8:8:8:8 argb colorNarg1alpha colorNarg2alpha A to RGB A to RGB 8:8:8 rgb 8:8:8 rgb colorNalpha1inv colorNarg1inv colorNarg2inv 1 - RGB 1 - A 1 - RGB 1 - A 8:8:8 rgb 8:8:8 rgb colorNarg1mul colorNblend colorNmodbright mult (x2,x4) -16:16:16 rgb 16:16:16 rgb colorNblend TMP colorNarg1add colorNarg2add colorNadd colorNadd2x +/- (x2,bias) colorNaddbias -8:8:8 rgb -8:8:8 rgb colorNsel 8:8:8 rgb (saturate, rup) Outn Figure 3-2: Color Processing Unit **Address** MGABASE1 + 2CFCh (MEM)**Attributes** WO, FIFO, STATIC, DWORD Reset Value 0000 0000 0000 0000 0000 0000 0000 0000ь | | alpha1sel | | alpha1add2x | alpha1addbias | alpha1add | alpha1arg2inv | , 7 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | alpna largzsel | alpha1arg1inv | 7.00 | 5 | color1blend | color1addbias | color1add2x | color1add | 7 | color i modarigne | color1arg2add | color1arg1add | color1arg2mul | color1arg1mul | color1alpha2inv | color1alpha1inv | color1arg2inv | color1arg2alpha | color1arg1inv | color1arg1alpha | | color1alphasel | | color1arg2sel | 5<br>5<br>5 | |---|-----------|----|-------------|---------------|-----------|---------------|-----------------------------------------|----------------|---------------|------|----|-------------|---------------|-------------|-----------|----|-------------------|---------------|---------------|---------------|---------------|-----------------|-----------------|---------------|-----------------|---------------|-----------------|---|----------------|---|---------------|-------------| | 3 | 1 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | alpha1modbright color1arg2 • '00': diffuse sel <1:0> • '01': specular • '10': FCOL • '11': output from the previous stage (stage 0 output) color1 • '000': diffuse alphasel • '001': FCOL <4:2> • '010': current texture (texture1) • '011': previous texture (texture 0) • '100': output from previous stage (stage 0 output) color1arg1 alpha <5> color1arg1 inv <6> color1arg2 alpha <7> color1arg2 inv <8> color1alpha1 inv <9> ``` color1alpha2 inv <10> color1arg1 • 0: ARG1 mul • 1: ALPHA1 <11> color1arg2 • 0: ARG2 mul • 1: ALPHA2 <12> color1arq1 • 0: ARG1 add • 1: MULOUT <13> color1arg2 • 0: ARG2 add • 1: MULOUT <14> color1mod Modulation brightness bright • '00': no effect <16:15> • '01': shift the result of the multiplication one bit left • '10': shift the result of the multiplication two bits left color1add • 0: SUB <17> • 1: ADD color1add2x add and double the result <18> color1add add with -0.5 bias bias <19> color1blend Linear Blending mode. In this mode, the processing unit operates in two passes. On <20> the first pass, color1arg1mul and color1arg2mul will have their programmed values. The result is kept in TMP. On the second pass, the arguments are swapped: color1arg1mul and color1arg2mul will be forced to NOT(color1arg1mul) and NOT(color1arg2mul) respectively. TMP is used instead of the output of the multiplier when in linear mode. color1sel • '00': ARG1 <22:21> • '01': ARG2 • '10': ADDOUT • '11': MULOUT alpha0arg1 inv <23> alpha1arg2 • '00': diffuse sel • '01': FCOL <25:24> ``` • '10': previous texture (texture 0) • '11': output from previous stage (stage 0 output) alpha1arg2 inv <26> alpha1add • 0: SUB <27> • 1: ADD alpha1add Add with -0.5 bias bias <28> alpha1add2x Add and double the result <29> alpha1mod bright <29:28> Modulation brightness. Replaces alpha1addbias<28> and alpha1add2x<29> when multiplication is used instead of addition. • '00': no effect • '01': shift the result of the multiplication *one* bit left • '10': shift the result of the multiplication two bits left alpha1sel <31:30> • '00': ARG1 • '01': ARG2 • '10': ADD • '11': MUL •• *Note:* In dual texturing, use diffuse and specular values in dual blender stage 1 (TDUALSTAGE1) only when multiplication or addition (either color or alpha) is programmed for stage 0. When in dual texturing mode stage 1, do not program - TDUALSTAGE1.color1alphasel to '000' (diffuse) - TDUALSTAGE1.color1arg2sel to '00' (diffuse) or '01' (specular) - TDUALSTAGE1.alpha1arg2sel to 00 (diffuse) *unless* one of the following for stage 0 is programmed: • TDUALSTAGE0.color0sel is programmed to '10' (ADD) or '11' (MUL) or • TDUALSTAGE0.alpha0sel is programmed to '10' (ADD) or '11' (MUL) Diffuse and specular can be used in dual blender stage 0 (**TDUALSTAGE0**); they can also be used in single texturing. TEST0 Test0 Address MGABASE1 + 1E48h (MEM) Attributes R/W, DYNAMIC, WORD/DWORD Reset Value 0000 0000 0000 0000 0000 0000 0000 | | Reserved | | | | | r | ring | jcn | t | | | | | ringcnten | ringoscbyp | ringoscen | apllmode1 | aplls0 | aplls1 | aplitst | aclkdivrst | aplibyp | tclkdivrstn | | tclkdiv | | | tclksel | | gotstanal | tstobs | | |----|----------|----|----|----|----|----|------|-----|----|----|----|----|----|-----------|------------|-----------|-----------|--------|--------|---------|------------|---------|-------------|---|---------|---|---|---------|---|-----------|--------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | tstobs <0> Test Observation mode. When **tstobs** is '1', it puts the chip is observation mode. This mode configures DDC\_0 for the PLL test and outputs the ring oscillator clock on DDC\_1. gotstanal <1> Test Analog mode. When **gotstanal** is '1', it puts the chip in analog test mode. This mode configures the pins to give a direct access to the on-chip DAC and to test the Plls. | Pin name | DAC I/O | |----------|-----------------------------------| | VD_0 | DAC/DB0,DG0,DR0(in) | | VD_1 | DAC/DB1,DG1,DR1(in) | | VD_2 | DAC/DB2,DG2,DR2(in) | | VD_3 | DAC/DB3,DG3,DR3(in) | | VD_4 | DAC/DB4,DG4,DR4(in) | | VD_5 | DAC/DB5,DG5,DR5(in) | | VD_6 | DAC/DB6,DG6,DR6(in) | | VD_7 | DAC/DB7,DG7,DR7(in) | | VDOUT_0 | DAC/BLANKB,BLANKG,BLANKR(in) | | VDOUT_1 | DAC/SYNCB,SYNCG,SYNCR(in) | | VDOUT_2 | DAC/SYCENB,SYCENG,SYCENR(in) | | VDOUT_3 | DAC/SETUPB,SETUPG,SETUPR(in) | | VDOUT_4 | DAC/S6(in) | | VDOUT_5 | DAC/CPEN(in) | | VDOUT_6 | DAC/MA(in) | | VDOUT_7 | DAC/MB(in) | | VDOCLK | DAC/CLK | | DDC_1 | DAC/SR(out) | | DDC_2 | DAC/SG(out) | | DDC_3 | DAC/SB(out) | | IOR | same as normal mode | | IOG | same as normal mode | | IOB | same as normal mode | | REFD | DAC/REF(in) (same as normal mode) | | RSET | same as normal mode | | COMP | same as normal mode | Test0 TEST0 | Pin Name | PLL Test | |----------|---------------------------------------------------------------| | VIDRST | Reset of Test clock frequency divider (when gotstanal is '1') | | DDC_0 | Output of PLL test circuit | tclksel <4:2> Test Clock Select. **tclksel** is used to select the source of the test clock. The test clock can be the output of one PLL or the ring oscillator clock. | tclksel | test clock source | |---------|-------------------| | 000 | PIXPLL | | 001 | SYSPLL | | 010 | AGP PLL F0 | | 011 | AGP PLL TBO0 | | 100 | RING OSCILLATOR | | 101 | RESERVED | | 110 | RESERVED | | 111 | RESERVED | tclkdiv <7:5> Test Clock Frequency divider. **tclkdiv** selects the frequency dividing ration applied on the test clock before it is visible on DDC\_0. | tclkdiv | Division factor | |---------|-----------------| | 000 | 1 | | 001 | 2 | | 010 | 4 | | 011 | 8 | | 100 | Reserved | | 101 | Reserved | | 110 | Reserved | | 111 | 2048 | tclkdivrstn Test clock Frequency Divider Reset. When **tclkdivrstn** is '0', it resets the test clock <8> frequency divider. apllbyp AGP PLL Bypass. When **aplibyp** is '1', the AGP PLL is bypassed with VDCLK. <9> aclkdivrst AGP Frequency Divider Reset. When **aclkdivrst** is '1', it resets the frequency divider <10> used to generate the host clocks. aplitst AGP PLL Test mode. Programming **aplitst** to '1' puts the AGP PLL in test mode. <11> aplis1 AGP PLL S1 (Test mode only). When aplltst is '1', aplls1 is the value applied to the <12> S1 port of the AGP PLL. aplis0 AGP PLL S0 (Test mode only). When aplltst is '1', aplls0 is the value applied to the <13> S0 port of the AGP PLL apllmode1 AGP PLL MODE1 (Test mode only). When **aplitst** is '1', **aplimode1** is the value <14> applied to the MODE1 port of the AGP PLL. TEST0 Test0 | ringoscen<br><15> | Ring Oscillator Enable. When <b>ringoscen</b> is '1', the ring oscillator is activated. Otherwise, the ring oscillator is disabled. | |-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ringoscbyp<br><16> | Ring Oscillator Bypass. When <b>ringoscbyp</b> is '1', the ring oscillator clock is bypassed with PCLK. | | ringcnten<br><17> | Ring Oscillator Counter Enable. When <b>ringcnten</b> is '0', the counter clocked by the ring oscillator is reset. When <b>ringcnten</b> is '1', the counter is enabled and counts the number of clock cycles produced by the ring oscillator, during 2048 PIXCLK cycles. | | ringcnt<br>RO <29:18> | Ring Oscillator Counter Value. Value in the Ring Oscillator Counter. The value in this counter corresponds to the number of ring oscillator cycles during 2048 PIXCLK cycles. | | Reserved | <31:30> | | | Reserved. When writing to this register, the bits in this field <i>must</i> be set to '0'. Returns '0's when read. | Test1 TEST1 Address MGABASE1 + 1E0Ch (MEM) Attributes R/W, DYNAMIC, BYTE, WORD/DWORD | ı | Reserved | misr_rstn | misr_shift | misr_en | dftmode | | R | ese | erve | ed | | | | | | | | | rar | nts | tpa | ıss | | | | | | | | ramtstdone | ramtsten | tstmbist | | |---|----------|-----------|------------|---------|---------|----|----|-----|------|----|----|----|----|----|----|----|----|----|-----|-----|-----|-----|---|---|---|---|---|---|---|------------|----------|----------|--| | Ī | 31 | 30 | 29 | 28 | 2.7 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | tstmbist <0> Memory Built-In Self Test Mode. When **tstmbist** is '1', the MISC and DDC pins are configured to output diagnostic data about the RAM test. The outputs on the MISC and DDC pins can be monitored to make sure that the RAM test is fine. | RAM | PIN | |------------|--------| | WIMEM 0 | DDC_0 | | TCACHE 0 | DDC_1 | | BESLINEBUF | MISC_0 | | TCLUT | DDC_2 | | DAC LUT | DDC_3 | | WIMEM 1 | MISC_1 | | TCACHE 1 | MISC_2 | ramtsten <1> RAM Test Enable. When **ramtsten** is '0', the RAM BIST modules are reset. When **ramtsten** is '1', the RAM BIST modules are activated and the RAM test is performed. ramtstdone RO <2> RAM Test Done (valid only when ramtsten is '1'). When **ramtstdone** is '1', the RAM test is finished. Otherwise, the test is still in progress. ramtstpass <20:3> RAM Test Pass (valid only when **ramtstdone** is '1'). Each bit of **ramtstpass** corresponds to one main RAM in the chip. If one bit of **ramtstpass** is '1', it means that the corresponding RAM passed the test and is fine. If one bit of **ramtstpass** is '0', it means that the corresponding RAM contains a defect. | BIT | RAM | |-----|----------| | 0 | WIMEM 0 | | 1 | WIMEM 1 | | 2 | TCACHE 0 | TEST1 Test1 | BIT | RAM | |-----|------------| | 3 | TCACHE 1 | | 4 | DAC LUT | | 5 | TCLUT | | 6 | -not-used- | | 7 | BESLINEBUF | | 8 | -not used- | | 9 | -not used- | | 10 | -not used- | | 11 | -not used- | | 12 | -not used- | dftmode Design-For-Test Mode. When **dftmode** is '1', DDC\_1 is configured to be the serial <27> output of the internal MISR. misr en MISR Enable. When misr\_en is '1', the internal MISR is enabled. Otherwise, it is <28> disabled. When disabled, the MISR retain its internal state. misr\_shift MISR Shift. When misr\_shift is '0', the MISR is in capture mode. Otherwise, it is in <29> shift mode. misr\_rstn MISR Reset. When **misr\_rstn** is '0', the MISR is reset. Otherwise, it is not. <30> Reserved <26:21> <31> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Returns '0's when read. Attributes MGABASE1 + 2C5Ch (MEM) Reset Value WO, FIFO, STATIC, DWORD Reset Value unknown #### texbordercol | L | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |---|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | ( | 31 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | texbordercol <31:0> Texture Border Color. The texture's border color in 32-bit ARGB format. **Note:** This register can be set in broadcast mode. For more details see the definition of **TEXCTL2**.map1, **TEXWIDTH**.map1, or **TEXHEIGHT**.map1. Address MGABASE1 + 2C30h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown tpitch tformat <3:0> Texel Format. Specifies the texture's texel format. | tfc | ormat | | | | | | | | | |--------|-----------|--------------|------------------------|--|--|--|--|--|--| | Value | Mnemonic | Mode | Format | | | | | | | | '0000' | TW4 | 4 bits/texel | (Goes through the LUT) | | | | | | | | '0001' | TW8 | 8 bits/texel | (Goes through the LUT) | | | | | | | | '0010' | TW15 | 1:5:5:5 | (A:R:G:B) | | | | | | | | '0011' | TW16 | 5:6:5 | (R:G:B) | | | | | | | | '0100' | TW12 | 4:4:4:4 | (A:R:G:B) | | | | | | | | '0110' | TW32 | 8:8:8:8 | (A:R:G:B) | | | | | | | | '0111' | TW8A | 8 | (A) | | | | | | | | '1000' | TW8AL | 8:8 | (A:L) | | | | | | | | '1010' | TW422 | 4:2:2 | (VYUY) | | | | | | | | '1011' | TW422UYVY | 4:2:2 | (YVYU) | | | | | | | | '1110' | BMU8V8 | 8:8 | (Dv:Du) | | | | | | | | '1111' | BMU5V5L6 | 6:5:5 | (L:Dv:Du) | | | | | | | **Note:** In 4:2:0 mode, **tformat** *must* be set to TW8A. ### **Bump Map Formats** ### **BMU8V8** $$Du = Dv = [-128, +127] = [-1.0, +127/128]$$ $L = 63 = 1.0$ | 15 | | 8 | 7 | 0 | |----|----|---|----|---| | | Dv | | Du | | #### BMU5V5L6 $$Du = Dv = [-16, 15] = [-1.0, +15/16]$$ $L = [0,63] = [0.0, 1.0]$ | 15 | | 10 | 9 | 5 | 4 | | 0 | |----|---|----|----|---|---|----|---| | | L | | Dv | | | Du | | palsel <7:4> Palette Select. This field selects which of the 16 palettes to use for TW4. tpitchlin <8> Texture Pitch Linear. Indicates whether or not the value in the **tpitch** / **tpitchext** field is programmed with its linear value. - 0: bit <18:16> of register **TEXCTL** are used to set the pitch pitch = 8 << **TEXCTL** (18:16) - 1: bit <19:9> of register **TEXCTL** are used to set the pitch pitch = **TEXCTL** (19:9) tpitchext <19:9> Texture Pitch. If the **tpitchlin** bit is set to '1', the **tpitchext** field is programmed with the pitch of the texture which can vary from 1 to 2048 where a value of '0' represents a pitch of 2048. - •• *Note:* If **tformat** is set to TW422, **tpitchext** *must* be a multiple of 8. - •• *Note:* In repeat mode (**clampu** or **clampv** = '0' **tpitchext** *must* be programmed with a power of 2 value. - •• *Note:* When using a linear pitch with mip-mapping, **tpitchext** *must* be programmed with a multiple of 16 1 value. - •• *Note:* texture pitch must be greater or equal than the texture width (twmask + 1) tpitch <18:16> When the **tpitchlin** bit is set to '0', the **tpitch** is set according to the table below: | Pitch | tpitch | |-------|---------------| | 8 | '000' | | 16 | '001' | | 32 | <b>'</b> 010' | | 64 | '011' | | 128 | '100' | | 256 | '101' | | 512 | '110' | | 1024 | '111' | •• *Note:* texture pitch must be greater or equal than the texture width (twmask + 1) # owalpha <22> Over-Write Alpha. When this bit is set to '1', color keying can overwrite the alpha from the texture. # azeroextend <23> Alpha Zero Extend. Widen the alpha mask and key (**tamask** and **takey**) up to the actual texel alpha component size. - 0: Replicate the tamask and takey - 1: Zero extend # decalckey <24> Decal with color key. This bit indicates whether texel color keying or texel alpha keying will control the decal feature. - 0: Alpha keying controls the decal feature. The surface transparency feature is available (see **strans**, below), based on alpha keying. Color keying is used to prevent frame buffer updates for transparent texels (independent of **strans**). - 1: Alpha keying must be disabled. Color keying controls the decal feature (it does *not* automatically prevent frame buffer updates for transparent texels). The surface transparency feature is available (see **strans**), based on color keying. ### takey <25> Texture alpha key. This field indicates which polarity is defined as transparent. #### tamask <26> Texture alpha mask. This field enables alpha transparency. To disable transparency (that is, to make the texture opaque), set **takey** to '1' and **tamask** to '0'. #### clampv <27> Clamp mode enable for V. This bit specifies if the texture is clamped or repeated over the surface. - 0: repeat - 1: clamp ### clampu <28> Clamp mode enable for U. This bit specifies if the texture is clamped or repeated over the surface. - 0: repeat - 1: clamp # tmodulate <29> Texture modulate enable. This bit enables the multiplication of the texture with the I ALU on a color-by-color basis. When modulation is disabled, decal mode is used. The decal function selects between the texel and the surface color (I ALU), based on the **decalckey** field and the transparency information from the texture (the 'ctransp' and 'atransp' values - see **itrans**). ### strans <30> Surface transparency enable. When '1', this bit enables control of the frame buffer update on a per-pixel basis. Only opaque pixels are updated (when **itrans** = 0). Transparency is determined by either alpha keying or color keying, according to the setting of the **decalckey** field. ### itrans <31> Invert transparency enable. When '1', the transparency decision is inverted to allow two-pass algorithms when **strans** is active. Alpha test (D3D) Color Keying test Alpha Keying test Mux decalckey itrans invert invert invert idecal pixel transparent transparency decalsel modsel Figure 3-3 Transparency and Lighting Control Figure 3-4 Lighting Module (RGB) Table 3-1: Lighting Module (ALPHA) | alphasel | pixel(A) | |----------|-------------------------------| | 00 | pixel(A) | | 01 | Ialu(A) | | 10 | pixel(A) * Ialu(A) | | 11 | transparency ? 0x00 : Ialu(A) | # Reserved <21:20> Reserved. When writing to this register, the bits in this field *must* be set to '0'. - Note: This register can be set in broadcast mode. For more details see the definition of TEXCTL2.map1, TEXWIDTH.map1, or TEXHEIGHT.map1. - •• *Note:* In dual texturing, the transparency and lighting control bits (pixel transparent, transparency, decalsel, modsel) of each texture are ORed together (modsel = modsel0 OR modsel1,etc.) **Address** MGABASE1 + 2C3Ch (MEM)**Attributes** WO, FIFO, STATIC, DWORD **Reset Value** 0000 0000 0000 0000 0000 0000 0000 000b Rev A: | map1 | Reserved | | bumpmapping | g | dualtex<br>specen | borderen<br>ckstransdis | eserv | decaldis<br>idecal | ွိ | |----------------------|----------------------------|------------------|-------------|-----|-------------------|-------------------------|-------|--------------------|----| | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 1 | ) 9 | 8 7 | 7 6 | 5 4 | 3 | 2 1 | 0 | Rev. B and later: <2> | map1 | - | | | | | | | ı | Res | ser | vec | i | | | | | | | | | bumpmapping | tablefog | dualtex | specen | borderen | ckstransdis | Reserved | decaldis | idecal | decalblend | |------|------|------|------|----|----|----|----|----|-----|-----|-----|----|----|----|----|----|----|----|----|----|-------------|----------|---------|--------|----------|-------------|----------|----------|--------|------------| | 31 | 30 2 | 29 2 | 3 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | decalblend True Decal Enable. When enabled, with the decal function selected (tmodulate = '0'), <0> true decal will perform a blend between the texture (texel) and the surface RGB ALU. idecal Invert Decal information. <1> decaldis Decal Disable. • 0: decal is made between the texture and the surface color (RGB ALU). • 1: the texel is always chosen. ckstransdis Color Key Surface Transparency Disabled. Disables surface transparency from color <4> keying. borderen Border Enable. The constant border color (texbordercol) is used instead of <5> duplicating the texel. specen Specular Lighting Enable. Specular lighting can be performed on any 3D operation. <6> Dual Texture mode. dualtex <7> When set, the two tmaps will *independently* fetch the two textures. ◆ *Note:* This bit *must* be set to the same value in *both* tmaps. tablefog Table Fog enable. <8> When in Single Texturing mode this field *must* be set to '0' ## bump mapping <9> Bump Mapping mode. Puts the TEXTURE ENGINE in bump mapping mode. Dual texture mode *must* be enabled (**dualtex** = '1') because bump mapping is a multitexturing operation. - ◆ *Note:* This bit *must* be set to the same value in *both* tmaps. - Note: When this field is set to '1' to activate bump mapping, it must be reset to '0' to perform any other operation (other texturing modes and any 2D or 3D operations). The correct programming technique is to program **bumpmapping** to '1' when *entering* a function performing bump mapping, then reset to '0' before exiting the function. # map1 <31> Texture Map 1 addressing. the register of the two Texture map engines can be accessed in Broadcast mode or through Texture Map Engine 1 depending on the following equation: tmap0dis < = TEXCTL2.map1 or TEXWIDTH.map1 or TEXHEIGHT.map1; tmap0dis is effective on the next access. | Register | tmap0dis = 0 | tmap0dis = 1 | |--------------|-----------------|--------------| | TMR0-8 | TMAP0 and TMAP1 | TMAP1 only | | TEXORG | TMAP0 and TMAP1 | TMAP1 only | | TEXWIDTH | TMAP0 and TMAP1 | TMAP1 only | | TEXHEIGHT | TMAP0 and TMAP1 | TMAP1 only | | TEXCTL | TMAP0 and TMAP1 | TMAP1 only | | TEXTRANS | TMAP0 and TMAP1 | TMAP1 only | | TEXTRANSHIGH | TMAP0 and TMAP1 | TMAP1 only | | TEXCTL2 | TMAP0 and TMAP1 | TMAP1 only | | TEXFILTER | TMAP0 and TMAP1 | TMAP1 only | | TEXBORDERCOL | TMAP0 and TMAP1 | TMAP1 only | | TEXORG1 | TMAP0 and TMAP1 | TMAP1 only | | TEXORG2 | TMAP0 and TMAP1 | TMAP1 only | | TEXORG3 | TMAP0 and TMAP1 | TMAP1 only | | TEXORG4 | TMAP0 and TMAP1 | TMAP1 only | | ALPHACTRL | TMAP0 and TMAP1 | TMAP1 only | •• Note: When in Single Texturing mode, map1 of TEXCTL2, TEXWIDTH, and TEXHEIGHT must be set to '0'. ## Reserved <30:10> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Note: Since there is one register for each of the two texture mappers, the registers can be set in either of two ways. The following registers can be set at the same time (broadcast mode): ALPHACTRL, TEXBORDERCOL, TEXCTL, TEXCTL2, TEXFILTER, TEXHEIGHT, TEXORG, TEXORG1, TEXORG2, TEXORG3, TEXORG4, TMR0, TMR1,TMR2, TMR3, TMR4, TMR5, TMR6, TMR7, TMR8. Or, the register of the second mapper can be set alone. Address MGABASE1 + 2C58h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value 0000 0000 0000 0000 0000 0000 0000 mapnb fthres III gaph of the part minfilter <3:0> Minify Filtering Mode. If the texture is minified (based on the comparison between the stride and the 'fthres' value) the filter mode is selected by the minfilter value. | minfilter | mnemonic | filter mode | |---------------|----------|--------------------------------------------| | '0000' | NRST | Nearest | | '0001' | | RSVD | | '0010' | BILIN | Bi-linear | | '0011' | CNST | Constant Bi-linear (0.25) | | '0100' | | RSVD | | '0101' | | RSVD | | '0110' | | RSVD | | '0111' | | RSVD | | '1000' | MM1S | NEAREST_MIPMAP_NEAREST | | '1001' | MM2S | LINEAR_MIPMAP_NEAREST | | '1010' | MM4S | NEAREST_MIPMAP_LINEAR | | <b>'1011'</b> | | RSVD (5 sample) | | '1100' | MM8S | LINEAR_MIPMAP_LINEAR (trilinear filtering) | | '1101' | MM16S | ANISO | <sup>••</sup> Note: In 4:2:0 mode, minfilter must be set to BILIN. magfilter <7:4> Magnify Filtering Mode. If the texture is magnified (based on the comparison between the stride and the 'fthres' value) the filter mode is selected by the magfilter value. | magfilter | mnemonic | filter mode | |-----------|----------|---------------------------| | '0000' | NRST | Nearest | | '0001' | | RSVD | | '0010' | BILIN | Bi-linear | | '0011' | CNST | Constant Bi-linear (0.25) | | '0100' | | RSVD | | '0101' | | RSVD | | '0110' | | RSVD | | '0111' | | RSVD | **Note:** In 4:2:0 mode, **magfilter** *must* be set to BILIN. uvoffseten <17> UV Offset Enable. This bit indicates which texture sampling mode will be used. - 0: OpenGL - 1: DIRECT3D •• *Note:* When using DIRECT3D, the field **rfh** of **TEXHEIGHT** and the field **rfw** of **TEXWIDTH** are programmed with a value of 14. ## avgstride <19> Average Stride. Takes the average between the square of x and the square of y strides. ## filteralpha <20> Apply filtering on the alpha (texture alpha). •• Note: When TEXFILTER.minfilter = ANISO, TEXFILTER.filteralpha must be set to '1'. # fthres <28:21> Filter Threshold. The **fthres** field *must* be programmed with the square value of the step wanted as the threshold between minify and magnify. If the actual step in the texture is bigger than fthres, the engine will be minifying the texture and will apply the **minfilter** on the texture. Otherwise, the **magfilter** will be used. ◆ *Note:* This field holds an unsigned 4.4 value. # mapnb <31:29,18> Map Number. Specifies how many maps are used for mip-mapping. The valid range is 0 to 10. # Reserved <16:8> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Texture Height TEXHEIGH Address MGABASE1 + 2C2Ch (MEM) Attributes WO, FIFO, STATIC, DWORD **Reset Value** 0??? ???? ???? ???? ???? ???? ????b | | map1 | Recerved | ועפספו אפת | | | | | th | ma | sk | | | | | | Reserved | | | | rf | h | | | | Reserved | | | | t | h | | | |---|------|----------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---| | ŀ | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | th <5:0> Represents log2 of the texture height combined with an adjustment factor. This field holds a 6-bit signed value in two's complement notation, set as follows: $th = log2(texture height) + (4 - t_fractional_bits + q_fractional_bits)$ Typically, $\mathbf{th} = \log 2(\text{texture height}) + (4 - 20 + 16)$ . rfh <14:9> Height round-up factor. This factor is used to improve the generated image quality by assuring coherence in texel choice. This field holds a 6-bit signed value in two's complement notation, usually set to 8 - log2 (texture height) - (q\_fractional\_bits - 16). thmask <28:18> Height Mask. Determines the usable height of the texture (the select on which texel the repeat or clamping will be performed). This field holds a 11 bit unsigned value, usually set to (texture height) -1. - •• *Note:* The repeat mode (**clampv** = 0) will work properly if **thmask** is set to a value that is a power of two minus one. - Note: The minimum texture height supported (including maps in mipmapping) is 8. thmask must be >= 7. map1 <31> Texture Map 1 addressing. The register of the two texture map engines can be accessed in Broadcast mode or through Texture Map Engine 1 depending on the following equation: tmap0dis <= TEXCTL2.map1 or TEXWIDTH.map1 or TEXHEIGHT.map1';</pre> tmap0dis is effective on the next access. | Register | tmap0dis = 0 | tmap0dis = 1 | |--------------|-----------------|--------------| | TMR0-8 | TMAP0 and TMAP1 | TMAP1 only | | TEXORG | TMAP0 and TMAP1 | TMAP1 only | | TEXWIDTH | TMAP0 and TMAP1 | TMAP1 only | | TEXHEIGHT | TMAP0 and TMAP1 | TMAP1 only | | TEXCTL | TMAP0 and TMAP1 | TMAP1 only | | TEXTRANS | TMAP0 and TMAP1 | TMAP1 only | | TEXTRANSHIGH | TMAP0 and TMAP1 | TMAP1 only | | TEXCTL2 | TMAP0 and TMAP1 | TMAP1 only | | TEXFILTER | TMAP0 and TMAP1 | TMAP1 only | | TEXBORDERCOL | TMAP0 and TMAP1 | TMAP1 only | | TEXORG1 | TMAP0 and TMAP1 | TMAP1 only | | TEXORG2 | TMAP0 and TMAP1 | TMAP1 only | TEXHEIGHT Texture Height | Register | tmap0dis = 0 | tmap0dis = 1 | |-----------|-----------------|--------------| | TEXORG3 | TMAP0 and TMAP1 | TMAP1 only | | TEXORG4 | TMAP0 and TMAP1 | TMAP1 only | | ALPHACTRL | TMAP0 and TMAP1 | TMAP1 only | •• Note: When in Single Texturing mode, map1 of TEXCTL2, TEXWIDTH, and TEXHEIGHT must be set to '0'. ### Reserved <8:6> <17:15> <31:29> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. Note: Since there is one register for each of the two texture mappers, the registers can be set in either of two ways. The following registers can be set at the same time (broadcast mode): ALPHACTRL, TEXBORDERCOL, TEXCTL, TEXCTL2, TEXFILTER, TEXHEIGHT, TEXORG, TEXORG1, TEXORG2, TEXORG3, TEXORG4, TMR0, TMR1, TMR2, TMR3, TMR4, TMR5, TMR6, TMR7, TMR8. Or, the register of the second mapper can be set alone. Texture Origin TEXORO Address MGABASE1 + 2C24h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved offsetsel0 texorgacc texorgan #### texorg | 3 | 1 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| texorgmap <0> Memory Space indicator. This field indicates the map location. • 0: texture is in FB • 1: texture is in system memory texorgacc <1> Access Type. This field specifies the mode used to access the map. 0: PCI access1: AGP access •• *Note:* If the texture resides in the frame buffer space, this field is *not* considered. offsetsel0 <2> Offset Select 0. When this bit is set to '1', **TEXORG1** is used as an offset from **TEXORG**. Refer to 'Addressing for an 11-LOD Mip-Map' on page 4-46. texorg <31:5> Origin of map 0. The **texorg** field provides an offset value (the base address), to the position the first texel in the texture. The **texorg** field corresponds to a 256-bit aligned address in memory. This register *must* be set so that there is no overlap with either the frame buffer or the Z-depth buffer. Reserved <4:3> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Address MGABASE1 + 2CA4h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown | | | | | | | | | | | | | | te | xor | g1 | | | | | | | | | | | | | | nesei ved | offsetse11 | Docoryon | ָ<br>מ | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----------|------------|----------|--------| | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | offsetsel1 Offset Select 1. When this bit is set to '1', **TEXORG2** is used as an offset from **TEXORG1**. Refer to 'Addressing for an 11-LOD Mip-Map' on page 4-46. continuous texorg1 (the base address).continuous of address). The **texorg1** field corresponds to a 256-bit aligned address in memory. This register *must* be set so that there is no overlap with either the frame buffer or the Z-depth buffer. Reserved <4:3> <1:0> Reserved. When writing to this register, the bits in this field *must* be set to '0'. ► Note: Fields texorgmap and texorgacc, in the TEXORG register, apply to TEXORG1 (see page 3-221 for more information). Texture Origin 2 TEXORG2 Address MGABASE1 + 2CA8h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown texorg2 Reserved Reserved 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 offsetsel2 Offset Select 2. When this bit is set to '1', **TEXORG3** is used as an offset from **TEXORG2**. Refer to 'Addressing for an 11-LOD Mip-Map' on page 4-46. **texorg2** Origin of map 2. the **texorg2** filed provides an offset value (the base address), to the position of the first texel in the texture. The **tetxorg2** field corresponds to a 256-bit aligned address in memory. This register *must* be set so that there is no overlap with either the frame buffer or the Z-depth. Reserved <4:3> <1:0> Reserved. When writing to this register, the bits in this field *must* be set to '0'. •• *Note:* Fields **texorgmap** and **texorgacc**, in the **TEXORG** register, apply to **TEXORG1** (see page 3-221 for more information). Address MGABASE1 + 2CACh (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown texorg3 offsetse13 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| offsetsel3 Offset Select 3. When this bit is set to '1', **TEXORG4** is used as an offset from **TEXORG3**. Refer to 'Addressing for an 11-LOD Mip-Map' on page 4-46. **texorg3** Origin of map 3. the **texorg3** filed provides an offset value (the base address), to the position of the first texel in the texture. The **tetxorg3** field corresponds to a 256-bit aligned address in memory. This register *must* be set so that there is no overlap with either the frame buffer or the Z-depth. Reserved <4:3> <1:0> Reserved. When writing to this register, the bits in this field *must* be set to '0'. •• *Note:* Fields **texorgmap** and **texorgacc**, in the **TEXORG** register, apply to **TEXORG1** (see page 3-221 for more information). Address MGABASE1 + 2CB0h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown texorg4 Reserved | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| texorg4 <31:5> Origin of map 4. The **texorg4** field provides an offset value (the base address), to the position the first texel in the texture. The **texorg4** field corresponds to a 256-bit aligned address in memory. This register must be set so that there is no overlap with either the frame buffer or the Z-depth buffer. Reserved <4:0> Reserved. When writing to this register, the bits in this field *must* be set to '0'. •• *Note:* Fields **texorgmap** and **texorgacc**, in the **TEXORG** register, apply to **TEXORG4** (see page 3-221 for more information). Address MGABASE1 + 2C34h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown tkmask tckey | 3 | 1 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| tckey <15:0> Texture transparency color key. This field holds the 16-bit unsigned value of the color that is defined as the 'transparent' color. Planes that are *not* used must be set to '0'. tkmask <31:16> Texture color keying mask. This field enables texture transparency comparison on a planar basis ('0' indicates mask). The mask setting must be based on the **tformat** value, so that unused bits are masked as shown in the table below: | tformat | 15 | | | | | | tkı | ma | sk | | | | | | | 0 | |-----------|----|---|---|---|---|---|-----|----|----|---|---|---|---|---|---|---| | TW4 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | m | а | s | k | | TW8 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - | - | m | а | S | k | - | - | | TW8A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - | - | m | а | s | k | - | _ | | TW8AL | _ | _ | - | - | _ | - | m | а | s | k | _ | _ | _ | _ | - | _ | | TW12 | _ | _ | - | - | _ | _ | m | а | s | k | - | _ | - | _ | _ | - | | TW15 | _ | _ | - | - | _ | - | m | а | s | k | - | _ | - | - | - | ı | | TW16 | _ | _ | - | - | - | - | m | а | s | k | - | _ | - | - | - | _ | | BMU8V8 | _ | _ | - | - | - | - | m | а | S | k | - | - | - | - | - | - | | BMU5V5L6 | _ | _ | - | - | - | - | m | а | s | k | - | _ | - | - | - | _ | | TW32 | _ | _ | - | - | - | - | m | а | s | k | - | _ | - | - | - | _ | | TW422 | _ | _ | - | - | _ | _ | m | а | s | k | - | _ | - | _ | _ | - | | TW422UYVY | ı | _ | - | - | - | - | m | а | s | k | - | - | - | - | - | _ | Note: This register can be set in broadcast mode. For more details see the definition of TEXCTL2.map1, TEXWIDTH.map1, or TEXHEIGHT.map1. ◆ *Note:* The transparency *must* be *disabled* when **TEXTFILTER**.minfilter = ANISO. Address MGABASE1 + 2C38h (MEM) Attributes WO, FIFO, STATIC, DWORD tkmaskh tckeyh |--| tckeyh <15:0> Texture Color Key High. High portion (16 MSB) of the color key. tkmaskh <31:16> Texture Key Masking High. High portion (16 MSB) of the keying mask. | tformat | 31 | | | | | t | km | as | kh | | | | | | | 16 | |-----------|----|---|---|---|---|---|----|----|----|---|---|---|---|---|---|----| | TW4 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | TW8 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | TW8A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | TW8AL | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | TW12 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | TW15 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | TW16 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | BMU8V8 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | BMU5V5L6 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | TW32 | - | - | _ | - | - | - | m | a | s | k | - | - | - | - | - | 1 | | TW422 | _ | _ | _ | _ | _ | _ | m | а | S | k | _ | _ | _ | _ | _ | - | | TW422UYVY | _ | _ | _ | _ | _ | - | m | а | s | k | _ | _ | _ | _ | _ | _ | TEXWIDTH Texture Width Address MGABASE1 + 2C28h (MEM) Attributes WO, FIFO, STATIC, DWORD **Reset Value** 0??? ???? ???? ???? ???? ???? ????b | map1 | - O | ne sei ved | | | | | tw | ma | sk | | | | | | Reserved | | | | rf | w | | | | Reserved | | | | ť | w | | | |------|-----|------------|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | tw <5:0> Represents log2 of the texture width, combined with an adjustment factor. This field holds a 6-bit signed value in two's complement notation, set as follows: $tw = log2(texture width) + (4 - s_fractional_bits + q_fractional_bits)$ Typically, $\mathbf{tw} = \log 2(\text{texture width}) + (4 - 20 + 16)$ . rfw <14:9> Width round-up factor. This factor is used to improve the generated image quality by assuring coherence in texel choice. This field holds a 6-bit signed value in two's complement notation, usually set to 8 - log2 (texture width) - (q\_fractional\_bits - 16). twmask <28:18> Width Mask. Determining the usable width of the texture (select the texel that the repeat or clamping will be performed on). This field holds an 11-bit unsigned value usually set to: (texture width) - 1. - ► Note: The repeat mode (clampu = 0) will work properly *only* if the twmask is set to a value that is a power of two minus one. - •• *Note:* The minimum texture width supported (including maps in mipmapping) is 8. **twmask** *must* be >= 7. map1 <31> The register of the two Texture map engines can be accessed in Broadcast mode or through Texture Map Engine 1 depending on the following equation: tmap0dis <= TEXCT:2.map1 or TEXWIDTH.tmap1 or TEXHEIGHT.tmap1; tmap0dis is effective on the next access. | Register | tmap0dis = 0 | tmap0dis = 1 | |-----------|-----------------|--------------| | TMR0-8 | TMAP0 and TMAP1 | TMAP1 only | | TEXORG | TMAP0 and TMAP1 | TMAP1 only | | TEXWIDTH | TMAP0 and TMAP1 | TMAP1 only | | TEXHEIGHT | TMAP0 and TMAP1 | TMAP1 only | | TEXCTL | TMAP0 and TMAP1 | TMAP1 only | Texture Width TEXWIDTH | Register | tmap0dis = 0 | tmap0dis = 1 | |--------------|-----------------|--------------| | TEXTRANS | TMAP0 and TMAP1 | TMAP1 only | | TEXTRANSHIGH | TMAP0 and TMAP1 | TMAP1 only | | TEXCTL2 | TMAP0 and TMAP1 | TMAP1 only | | TEXFILTER | TMAP0 and TMAP1 | TMAP1 only | | TEXBORDERCOL | TMAP0 and TMAP1 | TMAP1 only | | TEXORG1 | TMAP0 and TMAP1 | TMAP1 only | | TEXORG2 | TMAP0 and TMAP1 | TMAP1 only | | TEXORG3 | TMAP0 and TMAP1 | TMAP1 only | | TEXORG4 | TMAP0 and TMAP1 | TMAP1 only | | ALPHACTRL | TMAP0 and TMAP1 | TMAP1 only | •• Note: When in Single Texturing mode, map1 of TEXCTL2, TEXWIDTH, and TEXHEIGHT must be set to '0'. ## Reserved <8:6> <17:15> <30:29> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. Note: Since there is one register for each of the two texture mappers, the registers can be set in either of two ways. The following registers can be set at the same time (broadcast mode): ALPHACTRL, TEXBORDERCOL, TEXCTL, TEXCTL2, TEXFILTER, TEXHEIGHT, TEXORG, TEXORG1, TEXORG2, TEXORG3, TEXORG4, TMR0, TMR1, TMR2, TMR3, TMR4, TMR5, TMR6, TMR7, TMR8. Or, the register of the second mapper can be set alone. Address MGABASE1 + 2C00h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown #### tmr0 | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| tmr0 <31:0> Texture mapping ALU register 0. This field holds a signed 12.20 value in two's complement notation. For texture mapping, the **TMR0** register holds the s/wc-increment value along the x-axis. Address MGABASE1 + 2C04h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown ### tmr1 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| tmr1 <31:0> Texture mapping ALU register 1. This field holds a signed 12.20 value in two's complement notation. For texture mapping, the **TMR1** register holds the s/wc-increment value along the y-axis. Address MGABASE1 + 2C08h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown #### tmr2 | 3 | 1 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| tmr2 <31:0> Texture mapping ALU register 2. This field holds a signed 12.20 value in two's complement notation. For texture mapping, the **TMR2** register holds the t/wc-increment value along the x-axis. Address MGABASE1 + 2C0Ch (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown #### tmr3 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 | 6 5 4 3 2 | 1 0 | |-------------------------------------------------------------------------|-----------|-----| tmr3 <31:0> Texture mapping ALU register 3. This field holds a signed 12.20 value in two's complement notation. For texture mapping, the **TMR3** register holds the t/wc-increment value along the y-axis. Address MGABASE1 + 2C10h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown #### tmr4 | 3 | 1 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| tmr4 <31:0> Texture mapping ALU register 4. This field holds a signed 16.16 value in two's complement notation. For texture mapping, the **TMR4** register holds the q/wc-increment value along the x-axis. Address MGABASE1 + 2C14h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown #### tmr5 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| tmr5 <31:0> Texture mapping ALU register 5. This field holds a signed 16.16 value in two's complement notation. For texture mapping, the $\mathsf{TMR5}$ register holds the q/wc-increment value along the y-axis. Address MGABASE1 + 2C18h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown tmr6 | 3 | 1 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| tmr6 <31:0> Texture mapping ALU register 6. This field holds a signed 12.20 value in two's complement notation. For texture mapping, the **TMR6** register is used to scan the left edge of the trapezoid for the s/wc parameter. This register must be initialized with the starting s/wc-value. Address MGABASE1 + 2C1Ch (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown #### tmr7 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| tmr7 <31:0> Texture mapping ALU register 7. This field holds a signed 12.20 value in two's complement notation. For texture mapping, the **TMR7** register is used to scan the left edge of the trapezoid for the t/wc parameter. This register must be initialized with the starting t/wc-value. Address MGABASE1 + 2C20h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown #### tmr8 | L | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | : | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | tmr8 <31:0> Texture mapping ALU register 8. This field holds a signed 16.16 value in two's complement notation. For texture mapping, the **TMR8** register is used to scan the left edge of the trapezoid for the q/wc parameter. This register must be initialized with the starting q/wc-value. - ◆ *Note*: Cases where q/wc is less than or equal to 0 will be processed as exceptions. Software should ensure that q remains positive to avoid an overflow. - ◆ *Note:* This register can be set in broadcast mode. For more details see the definition of **TEXCTL2**.map1, **TEXWIDTH**.map1, or **TEXHEIGHT**.map1. Address MGABASE1 + 3E08h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value unknown Reserved vbiaddr0 | | | | | | | | | | | | | | | | | | | | | | | | | _ | | | | l . | | | | | |-----|-------|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|------|----|---|---|---|---|-----|-----|----|----|-----|-----| | - 1 | 3 I I | 30 | 29 | 128 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 113 | 12 | l 11 | 10 | 9 | 8 | 7 | 6 | I 5 | 1 4 | 13 | 12 | l 1 | 1.0 | | Ι, | ' - | 50 | | | _ , | -0 | | | | | -1 | -0 | 1/ | 10 | 1, | 10 | 10 | | 13 | 12 | | 10 | _ | 0 | , | 0 | | | | _ | - | | | _ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | **vbiaddr0** VBI Data start Address window 0. Start address in bytes in the frame buffer of VBI data for Window 0. This field *must* be loaded with a multiple of 16 (the 4 LSBs = '0'). Reserved <31:25> Reserved. When writing to this register, the bits in this field *must* be set to 0. Address MGABASE1 + 3E0Ch (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value unknown Reserved vbiaddr1 | ı | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | vbiaddr1 <24:0> VBI Data start Address window 1. Start address in bytes in the frame buffer of VBI data for Window 1. This field *must* be loaded with a multiple of 16 (the 4 LSBs = '0'). Reserved <31:25> Reserved. When writing to this register, the bits in this field *must* be set to 0. Video In VBI Count VBICOUNT | Address<br>Attributes<br>Reset Value | WO, BYTE/W | + 3E18h (MEM<br>/ORD/DWORD<br>0001 0011 | , STATIC | 1 0001 01 | 00ь | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|------------------------------------------|----------------------------|---------------------------------|-------------------------|------------------------------------------------------------------| | Reserved<br>Applications of the second s | Reserved | vinvbcnt1 | Reserved | vbicnt0 | Reserved | vinvbcnt0 | | 31 30 29 28 27 2 | 26 25 24 23 22 21 | 20 19 18 17 16 | 5 15 14 13 1 | 2 11 10 9 8 | 3 7 6 | 5 4 3 2 1 0 | | vinvbcnt0<br><5:0> | of the vertical bl | anking interval (<br>st line of the nex | number of late active vide | ines between<br>eo). This field | the currer<br>is loaded | rmine the duration<br>nt v-bit rising edge<br>into the vin blank | | vbicnt0<br><13:8> | Video in VBI Corange for field 0 | | | | | irst line of the VBI with <b>vinvbcnt0</b> . | | vinvbcnt1<br><21:16> | of the vertical bl | anking interval (<br>nd the first line ( | (number of lof the next a | ines between ctive video). | a current<br>This field | rmine the duration v-bit rising edge is loaded into the = 1. | | vbicnt1 | Video In VBI Co | ount for field 1. T | This field is | used to detern | nine the fi | irst line of the VBI | <31:30> <23:22> <15:14> <7:6> Reserved. When writing to this register, the bits in this field *must* be set to 0. range for field 1 by comparing with the vin vblank counter loaded with vinvbcnt1. ◆ *Note:* Programmed values are *only* effective *after* the next vertical sync. <29:24> Reserved VCOUNT Vertical Count Address MGABASE1 + 1E20h (MEM) Attributes RO, WORD/DWORD, DYNAMIC Reset Value unknown Reserved vcount | 3 | 1 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| vcount <11:0> Vertical counter value. Writing has no effect. Reading will give the current vertical count value. Note: This register must be read using a word or dword access, because the value might change between two byte accesses. A sample and hold circuit will ensure a stable value for the duration of one PCI read access. Reserved Reserved. When writing to this register, the bits in this field *must* be set to '0'. Reading will return '0's. Address MGABASE1 + 3E34h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value unknown dcmpeoiiclr blvliclr cmdcmpliclr vinvsvnciclr | Reserved | |----------| |----------| | ı | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | vinvsyncicle Video Input Vsync Interrupt Clear. When writing a '1' to this bit, the input vsync **<0>** interrupt pending flag is cleared. **cmdcmpliclr** Command Complete Interrupt Clear. When writing a '1' to this bit, the command <1> complete interrupt pending flag is cleared. **blvliclr** Buffer Level Interrupt Clear. When writing a '1' to this bit, the buffer level interrupt **<2>** pending flag is cleared. **dcmpeoliclr** Codec decompression end of image interrupt clear. When writing a '1' to this bit, the <3> end of image interrupt pending flag is cleared. **Reserved** Reserved. Writing to this field has *no* effect. <31:4> **Address** MGABASE1 + 3E38h (MEM) **Attributes** R/W, BYTE/WORD/DWORD, STATIC Reset Value XXXX XXXX XXXX XXXX XXXX XXXX 0000b > cmdcmplien dcmpeoiien | Reserved | ł | |----------|---| |----------|---| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| Video Input Vsync Interrupt Enable. When set to '1', an interrupt will be generated vinvsyncien <0> when the **vinvsyncpen** bit in **VSTATUS** is asserted. cmdcmplien Codec Command Complete Interrupt Enable. When set to '1', an interrupt will be <1> generated when the command execution is complete. blylien Buffer Level Interrupt Enable. When set to '1' an interrupt will be generated when the <2> Codec Interface Read pointer for decompression (write pointer for compression) has reached the value set in the **CODECHOSTPTR** register. dcmpeoiien Codec Decompression End Of Image Interrupt Enable. When set to a '1', an interrupt will be generated when the Codec Interface is performing decompression and the end of image marker is detected in the stream. Reserved Reserved. Writing to this field has no effect. <31:4> <3> Address MGABASE1 + 3E10h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value unknown Reserved vinaddr0 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | |---------------------------------------------------------------------------------------|----|----|----|----|----|----|----|--|--|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | 31 | 30 | 29 | 28 | 27 | 26 | 43 | | | 19 | 18 | 17 | 16 | 15 | 13 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | **vinaddr0** Video write start Address for window 0. Start address in frame buffer of window 0. **<24:0>** This field *must* be loaded with a multiple of 16 (the 4 LSBs = '0'). Reserved <31:25> ◆ *Note:* This register is double-buffered. The buffer is updated on a Reserved. When writing to this register, the bits in this field *must* be set to 0. vinvsyncpen event. Address MGABASE1 + 3E14h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value unknown Reserved vinaddr1 | | 31 | 30 | 29 | 20 | 27 | 26 | 25 | 24 | 22 | 22 | 21 | 20 | 10 | 10 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | ۵ | 0 | 7 | 6 | 5 | 4 | 2 | 2 | 1 | Λ | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | ١ | 31 | 30 | 29 | 20 | 21 | 20 | 23 | 24 | 23 | 22 | 21 | 20 | 19 | 10 | 1/ | 10 | 13 | 14 | 13 | 12 | 11 | 10 | 9 | ð | / | 6 | 5 | 4 | 3 | | 1 | U | **vinaddr1** Video write start Address for window 1. Start address in frame buffer of window 1. **<24:0>** This field *must* be loaded with a multiple of 16 (the 4 LSBs = '0'). Reserved <31:25> Reserved. When writing to this register, the bits in this field *must* be set to 0. Address MGABASE1 + 3E20h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value unknown Reserved vinaddr2 | 1 3 | 0 2 | .9 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|------------|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|----|-----|-----|-----|---| | | nac<br>:24 | | | | | | | | | | Ad<br>e lo | | | | | | | | | | | | | | | | of | wii | ndo | w 2 | | Reserved <31:25> Reserved. When writing to this register, the bits in this field *must* be set to 0. Address MGABASE1 + 3E24h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value unknown Reserved vinaddr3 | ? | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| **vinaddr3** Video write start Address for window 3. Start address in frame buffer of window 3. **<24:0>** This field *must* be loaded with a multiple of 16 (the 4 LSBs = '0'). Reserved <31:25> Reserved. When writing to this register, the bits in this field *must* be set to 0. Address MGABASE1 + 3E1Ch (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0001 0000 0001 0000 0000 0011 0000b | | | R | es | ser <sup>,</sup> | vec | i | | rpvaliden | vininttsel | vinintentb | vinintenta | vinc2graben | vinvdclkoe | vinvdoe | vin2xen | vbitasken | | R | ese | erve | ed | | vingenfbinv | vinfimfixen | vinhdsen | vinautoen | vinintenf0 | vinintenf1 | vinuyvyfmt | Č | פאפו | vinen | |---|------|---------|----|------------------|-----|----|----|-----------|------------|------------|------------|-------------|------------|---------|---------|-----------|----|-----|-----|------|-----|----|-------------|-------------|----------|-----------|------------|------------|------------|---|------|-------| | - | 31 3 | 30 2 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | - | ,1 - | , U 2 | | 20 | 21 | 20 | 23 | | 23 | | 21 | 20 | 1, | 1.0 | 1 / | 10 | 13 | 1.7 | 13 | 12 | 111 | 10 | | 9 | · ' | ' | | -т | , | ~ | 1 | J | vinen <0> Video In Enable. When this bit is '0', the Video In module is disabled. The **vincap**, **vbicap**, and **vinvsyncien** fields are held at zero as long as **vinen** is '0'. • 0: reset/disabled • 1: video-in enabled vinuyvyfmt <3> Video In UYVY format enable. 0: active video captured in YUY2 format1: active video captured in UYVY format vinintenf1 <4> Video In Interrupt Enable Field 1. • 0: disable **vinvsyncpen** event during Field 1 video stream • 1: enable vinvsyncpen event during Field 1 video stream ◆ *Note:* This bit is only active when **vininttsel** is '0'. vinintenf0 <5> Video In Interrupt Enable Field 0. • 0: disable **vinvsyncpen** event during Field 0 video stream ullet 1: enable **vinvsyncpen** event during Field 0 video stream **Note:** This bit is only active when **vininttsel** is '0'. vinautoen <6> Video In Automatic mode Enable. Pointer selection is based on present field bit, for a transition from a field bit of 1 to 0, the msb bit in the pointer is toggled. vinhdsen <7> Video In Horizontal Down Scaler Enable. Enables a 2X horizontal downscaling on Video In input. This filter function applies a 1/4:1/2:1/4 second chrominance CbCr pair. The filter function applies a 1/4:1/2:1/4 on luminance samples and sub-samples every second chrominance CbCr pair. vinfimfixen <8> Video In Field Interleaved Mode Fix Enable. This Field bits in the streams's SAV/ EAV codes are used to determine which task is being captured. The task value is the inverted Field bit. A one bit line counter generates an internal field bit. The counter is sampled and reset to '0' on each V-bit rising edge. The sampled value is used to determine the field type being captured. vingenfbinv <9> Video In Field Bit Inverter. When set to '1', the generated internal field bit is inverted. #### vbitasken <16> VBI range Task bit Enable. Enables the task bit of SAV/EAV codes to be used to determine which lines of the Vertical Blanking Interval contain valid VBI data. - 0: IGNORE task bit and capture ALL data in VBI range in the manner programmed by the VINCTL0: vbicap0 and VINCTL1: vbicap1 fields - 1: only capture data within the VBI range if the Task bit is '0' (TASK B). #### vin2xen <17> Video In 2X mode. This bit enables 2X capture mode. Pointer selection in 2X mode is based on the active field and task bit being captured. The lsb of the pointer is equivalent to the present field bit. The msb is equivalent to the inverse of the present task bit #### vinvdoe <18> Video In VD Output Enable. When this bit is enabled, the VD[7:0] pins will *output* data from the CRTC2. - 0: Disable VD[7:0] output buffers (VD is in input mode) - 1: Enable VD[7:0] output buffers #### vinvdclkoe <19> Video In VDCLK Output Enable. When this bit is enabled, the VDCLK pin will *output* the clock generated for the CRTC2. - 0: Disable VDCLK output enable buffer (VDCLK is in input mode) - 1: Enable VDCLK output buffer ## vinc2graben <20> Video In 2nd CRTC Grab Enable. This bit enables redirection of the data and clock generated by the CRTC2 to the Video In module. This circumvents any external data on the VD[7:0] and VDCLK pins. - 0: Externally generated clock on VDCLK pin and data on VD[7:0] pins are sent to Video In module. - 1: The clock and data generated internally by the CRTC2 are sent to Video In module ## vinintenta <21> Video in Task A Interrupt Enable. This bit enables the generation of a **vinvsyncpen** event at the end of active video designated as Task A. - 0: Disable **vinvsyncpen** event during Task A video stream. - 1: Enable **vinvsyncpen** event during Task A video stream. - **Note:** This bit is only active when **vininttsel** is '1'. #### vinintentb <22> Video In Task B Interrupt enable. This bit enables the generation of a **vinvsyncpen** event at the end of active video designated as Task B. - 0: Disable **vinvsyncpen** event during Task B video stream. - 1: Enable **vinvsyncpen** event during Task B video stream. - **◆** *Note:* This bit is only active when **vininttsel** is '1'. ## vininttsel <23> Video In Task Interrupt Select. This bit selects between generating the **vinvsyncpen** event based on the video *field* bit or based on the video *task* bit. - 0: Enable **vinvsyncpen** event generation by *field*. This option enables the use of the **vinintenf0** and **vinintenf1** fields. - 1: Enable **vinvsyncpen** event generation by *task*. This option enables the use of the **vinintenta** and **vinintentb** fields. # rpvaliden <24> RP byte Validation Enable. Enables validation of the RP byte of the SAV/EAV codes. - 0: Do *not* check RP byte for valid hamming code. Process all tasks, fields, vertical and horizontal blanking bits in the RP byte of a SAV/EAV when encountered. - 1: Check RP byte for valid hamming code. #### Reserved #### <31:25><15:8><2:1> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. Address MGABASE1 + 3E00h (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC | | | | | | | | | R | ese | ervo | ed | | | | | | | | | | | , | vin | pite | ch( | ) | | | acoid. | VDICAD. | vincap | |----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|---|-----|------|-----|---|---|---|--------|---------|--------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | vincap0 <0> Video Input Capture for window 0. - 0: disable - 1: enable - **Note:** This parameter is reset and held at '0' when **vinen** is set to '0'. #### vbicap0 <2:1> VBI Capture for window 0. Enables and defines the type of VBI data to be captured for window 0. - '00': *no* VBI captured • '01': raw VBI captured - '10': Reserved - '11': sliced VBI captured - ◆ *Note:* This parameter is reset and held at '00' when **vinen** is set to '0'. ## vinpitch0 <11:3> Video Input Pitch for window 0. The pitch value is measured as the number of 16 byte slices per line. The incoming video in YCbCr 4:2:2 format generates 2 pixels for each 4 bytes of video. Thus 1 slice of data is equivalent to 8 pixels. When programmed to '000000000', vinpitch0 is set to 512 slices or 8192 bytes or 4096 pixels. # Reserved <31:12> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Address MGABASE1 + 3E04h (MEM) Attributes WO, BYTE/WORD/DWORD, DYNAMIC Reserved vinpitch1 vinpitch1 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 vincap1 <0> Video Input Capture for window 1. 0: disable1: enable ◆ *Note:* This parameter is reset and held at '0' when **vinen** is set to '0'. vbicap1 <2:1> VBI Capture for window 1. Enables and defines the type of VBI data to be captured for window 1. • '00': *no* VBI capture • '01': raw VBI captured • '10': Reserved • '11': sliced VBI captured ◆ *Note:* This parameter is reset and held at '00' when **vinen** is set to '0'. vinpitch1 <11:3> Video Input Pitch for window 1. The pitch value is measured as the number of 16 byte slices per line. The incoming video in YCbCr 4:2:2 format generates 2 pixels for each 4 bytes of video. Thus, 1 slice of data is equivalent to 8 pixels. When programmed to '000000000', vinpitch1 is set to 512 slices or 8192 bytes or 4096 pixels. Reserved <31:12> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Ō Address MGABASE1 + 3E28h (MEM) Attributes WO, BYTE/WORD/DWORD, DYNAMIC | | | | | | | | | | R | ese | erve | ed | | | | | | | | | | | , | vin | pite | ch2 | 2 | | | Docoryo | אבו א<br>מבו א | vincap2 | |---|----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|---|-----|------|-----|---|---|---|---------|----------------|---------| | ı | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | vincap2 <0> Video Input Capture for window 2. 0 : disable1 : enable ◆ *Note:* This parameter is reset and held at '0' when vinen is set to '0'. vinpitch2 <11:3> Video Input Pitch for window 2. The pitch value is measured as the number of 16 byte slices per line. The incoming video in YCbCr 4:2:2 format generates 2 pixels for each 4 bytes of video. Thus, 1 slice of data is equivalent to 8 pixels. When programmed to '000000000', **vinpitch2** is set to 512 slices or 8192 bytes or 4096 pixels. Reserved <2:1> <31:12> Reserved. When writing to this register, the bits in this field *must* be set to 0. Address MGABASE1 + 3E2Ch (MEM) Attributes WO, BYTE/WORD/DWORD, DYNAMIC Reset Value 0000 0000 0000 0000 0000 0000 0000 Reserved vinpitch3 | Solution vincap3 <0> Video Input Capture for window 3. 0 : disable1 : enable ◆ *Note:* This parameter is reset and held at '0' when **vinen** is set to '0'. vinpitch3 <11:3> Video Input Pitch for window 3. The pitch value is measured as the number of 16 byte slices per line. The incoming video in YCbCr 4:2:2 format generates 2 pixels for each 4 bytes of video. Thus, 1 slice of data is equivalent to 8 pixels. When programmed to '000000000', **vinpitch3** is set to 512 slices or 8192 bytes or 4096 pixels. Reserved <2:1> <31:12> Reserved. When writing to this register, the bits in this field *must* be set to 0. Address MGABASE1 + 3E3Ch (MEM) Attributes WO, BYTE/WORD/DWORD, STATIC Reset Value 0000 0000 0000 0000 0010 1101 0000b Reserved vinheight | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| vinheight <9:0> Maximum number of lines of active video captured per field. Reserved <31:10> Reserved. When writing to this register, the bits in this field *must* be set to 0. •• *Note:* The programmed value is *only* effective *after* the next vertical sync event in the input video stream. Video Status VSTATUS Address MGABASE1 + 3E30h (MEM) Attributes RO, BYTE/WORD/DWORD, DYNAMIC | Reserved | | | | | | 2 | viiigiabbii | vintaskdetd | codec_stalled | slcvbicapd | rawvbicapd | vincapd | vinfielddetd | Re | ese | erve | ed | dcmpeoipen | blvlpen | cmdcmplpen | vinvsyncpen | |-------------------------------|------|-------|----|----|----|----|-------------|-------------|---------------|------------|------------|---------|--------------|----|-----|------|----|------------|---------|------------|-------------| | 31 30 29 28 27 26 25 24 23 22 | 21 2 | 20 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | vinvsyncpen <0> Video Input Vsync interrupt Pending. When set to '1', indicates that an eligible v-bit transition from '0' to '1' on the input video stream has occurred. When this interrupt occurs the type of field and the data that were captured are set in fields **vinfielddetd**, **vincapd**, **rawvbicapd** and **slcvbicapd**. This bit is cleared through the **vinvsyncicIr** bit (see **VICLEAR on page 3-243)** or upon a Video In soft or a hard reset. •• *Note:* Eligible v-bit transitions are defined by the vinintenf0, vinintenf1, vinintenta, vinintentb, and vininttsel parameters in VINCTL. cmdcmplpen <1> Command Complete interrupt Pending. When set to '1', this bit indicates that the codec interface has completed command execution blvlpen <2> Buffer Level Interrupt Pending. When set to '1', this bit indicates that Codec Interface read pointer for decompression (write pointer for compression) has reached the value set in the **CODECHOSTPTR** register. dcmpeoipen <3> Codec Decompression End Of Image Interrupt Pending. When set to a '1', the Codec Interface has detected an end of image marker in the decompression stream. vinfielddetd <8> Video Input Field Detected. Indicates the previous field type. 0: odd field1: even field vincapd <9> Video Input Captured. Indicates whether the active video interval of the stream was reached in the field preceding the last vertical sync. This bit is cleared through the **vinvsynciclr** bit (see **VICLEAR on page 3-243)** or upon a video in soft or a hard reset. •• *Note:* The bit is set even if the data in the active video interval is invalid (0x00 or 0xFF). VSTATUS Video Status # rawvbicapd <10> Raw VBI Captured. Will be set if the previous field's respective **vbicap** parameter was set to capture RAW vbi and the vbi interval of the field was reached. This bit is cleared through the **vinvsynciclr** bit (see **VICLEAR on page 3-243)** or upon a video in soft or a hard reset. Note: The bit is set even if the data in the VBI interval is invalid (0x00 or 0xFF). ## slcvbicapd <11> Slice VBI Captured. Will be set if the previous field's respective vbicap parameter was set to capture RAW vbi and the vbi interval of the field was reached. This bit is cleared through the **vinvsynciclr** bit (see **VICLEAR on page 3-243)** or upon a video in soft or a hard reset. #### codec \_stalled <12> Codec Stalled. This bit is valid only during compression and decompression. When software sets the **codectransen** bit to '0' to suspend data transfer, and the internal DMA FIFO is completely empty, the Codec Interface will assert the **VSTATUS** register's **codec\_stalled** field. # vintaskdetd <13> Video Input Task Detected. Indicates the task bit selected in the previous field. # vingrabptr <15:14> Video Input Grab Pointer. Indicates which pointer was used to grab the previous field. The **vingrabptr** is a function of the grab mode selected and the task and field bits of the last field. | | | | (vinau | <i>1Xm</i><br>utoen = 0, v | | de = 0) | | | | |----------------|----------|-----------------------|------------------|----------------------------|------------------|------------------|------------------|------------------|------------------| | lsb: equivalen | t to fie | elddetd | | | | | | | | | msb: remains | at '0' | | | | | | | | | | Field | f0 | $\rightarrow f1$ $00$ | $\rightarrow$ f0 | → f0 | $\rightarrow$ f1 | $\rightarrow$ f0 | $\rightarrow$ f1 | $\rightarrow$ f0 | $\rightarrow$ xx | | vingrabptr | XX | <sub>7</sub> 00 | <sup>1</sup> 01 | <sub>7</sub> 00 | <sub>7</sub> 00 | <sup>1</sup> 01 | <sub>7</sub> 00 | <sup>1</sup> 01 | <sub>7</sub> 00 | | | | | (vina | 1Xauto<br>utoen = 1, | | de = 0) | | | | |----------------|----------------|------------------|------------------|----------------------|------|------------------|------------------|------------------|------------------| | lsb: equivalen | t to <b>fi</b> | elddetd | | | | | | | | | msb: toggles | on a fi | eld transiti | on from 1 | to 0 | | | | | | | Field | f0 | $\rightarrow f1$ | $\rightarrow$ f0 | $\rightarrow$ f1 | → f0 | $\rightarrow$ f1 | $\rightarrow$ f0 | $\rightarrow$ f1 | $\rightarrow$ xx | | vingrabptr | XX | <sub>7</sub> 00 | <sup>1</sup> 01 | 10 | 11 | <sub>7</sub> 00 | <sup>1</sup> 01 | 10 | 11 | Video Status VSTATUS Reserved <31:16> <7:4> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. Address MGABASE + 1DD4h (MEM) Attributes WO, FIFO, DWORD > wsametag wfirsttag seqlen seqdst2 Reserved segdst1 seqdst3 seqdst0 14 11 10 9 31 30 29 28 27 24 22 21 20 19 18 17 16 15 13 12 8 3 2 26 seqdst0 <5:0> see following note **<**3.0> see following note seqdst1 <11:6> and fallowing mate seqdst2 <17:12> see following note seqdst3 see following note <23:18> Note: These fields are used in conjunction with the sub-instruction .seq of the ACCEPT instruction. For the first .seq instruction executed by the ACCEPT sequencer none of these fields are used. For all other ACCEPT.seqs the ACCEPT sequencer will use one of the four seqdst values depending on the seqlen specification and the .seq pointer seqptr. The .seq pointer seqptr is under the control of the ACCEPT sequencer itself. See the following table for information on which seqdst is used. The first ACCEPT.seq can be generated by either WARP0 or WARP1 depending on the micro code. The **seqdst** selected will be used to replace the dst included with the instruction ACCEPT.seq until the register WACCPTSEQ is programmed. Each time the **WACCEPTSEQ** is programmed, the **seqptr** is reset to **seqdst0**. For all other ACCEPT.seq (except the first) the **seqptr** increases. When the **seqptr** reaches **seqlen** it is reset to **seqdst0**. seqlen <25:24> This field identifies how many seqdst values are used by the ACCEPT sequencer for the ACCEPT.seq instruction. | seqlen <25:24> | seqdst3<br><23:18> | seqdst2<br><17:12> | seqdst1<br><11:6> | seqdst0<br><5:0> | |----------------|--------------------|--------------------|-------------------|------------------| | <b>'</b> 00' | not used | not used | not used | used | | <b>'01'</b> | not used | not used | used | used | | <b>'10'</b> | not used | used | used | used | | <b>'11'</b> | used | used | used | used | # wfirsttag <26> When a START is programmed in the **WIADDR**, WARP0 is the current WARP and it is tagged first WARP by the ACCEPT sequencer, WARP1 is tagged second WARP. The ACCEPT sequencer will change the current WARP selection following the ACCEPT.toggle rules but the tagged first WARP and the tagged second WARP values do not change. When **WACCEPTSEQ** is programmed the current WARP selected by the ACCEPT sequencer is changed to be tagged first WARP and the other one tagged second WARP. The field **wfirsttag** is programmed in the flag Q of the first tagged WARP selected by the ACCEPT sequencer after that this first tagged WARP has executed an ACCEPT.w instruction. The second tagged WARP receives the same value if **wsametag** = 1, or the complement if **wsamemap** = 0, then executes an ACCEPT.w or ACCEPT.toggle.w instruction. For example, to correctly process a triangle strip each WARP must know how each triangle is culled, triangle CW or CCW. For a given strip, the first triangle can be CW the next can be CCW an so on. With this example, the WAPR0 must process the CW triangle and WARP1 CCW triangle. If a triangle strip ends with a CW triangle on WARP0 the next triangle will be sent to the WARP1. Here, the WARPs are not reSTARTed. If a new given triangle is proceeded, the first triangle is CW which is sent to WARP1. Normally, WARP1 expects the CCW triangle. In this situation, the culling is not executed correctly. Both **wfursttag** and **wsametag** are used to transmit information to the WARPs to identify which WARP culls the CW triangle and which culls the CCW triangle. The bit **wsametag** can be programmed to send the same information to both WARPs or complemental information to both WARPs. These bits can be used for other operations. #### wsametag <27> See the definition above (**wfirsttag**<26>). #### seqoff <28> Sequence Off. When **seqoff** = 1 the ACCEPT.seq instructions are treated like the first ACCEPT.seq (using the destination of the ACCEPT.seq command and the size of **primsz**). # Reserved <31:29> Reserved. Writing to this field has *no* effect. Address MGABASE1 + 1E6Ch (MEM) Attributes RO, DYNAMIC, DWORD Reset Value unknown wcodeaddr Reserved | L | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |-----|----|----|----|----|----|----|-----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----|----|-----|----|-----|------| | | | | | | | | | | | | | | | | 17 | | | | | | | | _ | _ | _ | _ | _ | ١. | _ | _ | | _ | | - 1 | 31 | 30 | 29 | 28 | 27 | 26 | 2.5 | 24 | 23 | 2.2. | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 15 | 4 | - 3 | 2. | - 1 | () [ | | - 1 | | | | | | | | | | | | | | | | | | | | | | | - | - | | - | _ | | - | _ | _ | _ | wcodeaddr <31:8> Warp microcode Address. Specifies the address where the microcode can be found. The field **wcodeaddr** is 256 byte-aligned address. See 'Cache Operation' on page 6- 16. Reserved Reserved. Reading will return '0'. <7:0> WARP Flags WFLAG Address MGABASE1 + 1DC4h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD | | | | | | W | /pr | gfla | ag | | | | | | | | | wa | luc | fgf | lag | | | | | wa | lus | tsf | lag | | | |------|-------|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|-----|-----|-----|---|---|---|---|----|-----|-----|-----|---|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 3 | 30 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ## walustsflag <7:0> WARP ALUs Status Flags. | bit | flag | description | |-----|------|---------------| | <0> | С | Carry | | <1> | V | Overflow | | <2> | Z | Zero | | <3> | N | Negative | | <4> | X | Extended Flag | | <5> | F | Current Flag | | <6> | Q | Sequence Flag | | <7> | _ | Reserved | Flag Q (seQuence flag). The information from this bit is used to identify which WARP is tagged first or second. The programming of this bit depends on the information included in **wfirsttag** (WACCEPTSEQ), wsametag (WACCEPTSEQ), the programming of the WACCEPTSEQ register (when this register is programmed), the instruction ACCEPT.w and the ACCEPT.toggle sequence executed by the BFCTL (BFIFO controller). When the WARP executes an ACCEPT.w instruction after receiving the last DWORD WDBR (vertex information) the flag Q is programmed with the information Q sent to the BFCTL. For further details regarding the information sent by the BFCTL see the **WACCEPTSEQ** register description. ### walucfgflag <15:8> WARP ALUs Configuration Flags. | bit | flag | description | |------|------|---------------------------------| | <8> | L | Left edge sign | | <9> | R | Right edge sign | | <10> | S | Saturate Integer | | <11> | U | Enable culling | | <12> | T | Swap edge | | <13> | M | GetMSB without 'nnnnn' subtract | | <14> | Н | Double dword result | | <15> | _ | Reserved | ## wprgflag <31:16> WARP Program Available Flags. These flags are available to the program. They are specified as flag (F16), ..., flag (F31). Bits 31 to 24 are accumulated. (See 'Pipeline Operation' on page 6-6.) WFLAG1 WARP Flags 1 Address MGABASE1 + 1DE0h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD | | | | | | | W | prg | ıfla | g1 | | | | | | | | ١ | wal | ucí | gfl | agʻ | I | | | • | wal | ust | tsfl | ag1 | i | | |----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|-----|-----|-----|-----|---|---|---|---|-----|-----|------|-----|---|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ## walustsflag1 <7:0> WARP1 ALUs Status Flags. | bit | flag | description | |-----|------|---------------| | <0> | C | Carry | | <1> | V | Overflow | | <2> | Z | Zero | | <3> | N | Negative | | <4> | X | Extended Flag | | <5> | F | Current Flag | | <6> | Q | Sequence Flag | | <7> | _ | Reserved | Flag Q (seQuence flag). The information from this bit is used to identify which WARP is tagged first or second. The programming of this bit depends on the information included in **wfirsttag** (WACCEPTSEQ), wsametag (WACCEPTSEQ), the programming of the WACCEPTSEQ register (when this register is programmed), the instruction ACCEPT.w and the ACCEPT.toggle sequence executed by the BFCTL (BFIFO controller). When the WARP1 executes an ACCEPT.w instruction after receiving the last DWORD WDBR (vertex information) the flag Q is programmed with the information Q sent to the BFCTL. For further details regarding the information sent by the BFCTL see the **WACCEPTSEQ** register description. ## walucfgflag1 <15:8> WARP1 ALUs Configuration Flags. | bit | flag | description | |------|------|---------------------------------| | <8> | L | Left edge sign | | <9> | R | Right edge sign | | <10> | S | Saturate Integer | | <11> | U | Enable culling | | <12> | T | Swap edge | | <13> | M | GetMSB without 'nnnnn' subtract | | <14> | Н | Double dword result | | <15> | _ | Reserved | ## wprgflag1 <31:16> WARP1 Program Available Flags. These flags are available to the program. They are specified as flag (F16), ..., flag (F31). Bits 31 to 24 are accumulated. (See 'Pipeline Operation' on page 6-6.) Address MGABASE1 + 1E64h (MEM) Attributes R/W, DYNAMIC, DWORD Reset Value 0000 0000 0000 0000 0000 0000 0000 The WFLAGNB register is an alternate way to load the WFLAG register, bypassing the BFIFO. (See **WFLAG** for field descriptions.) ◆ *Note:* The WARP flags are *not stable* when the WARP engine is running. Address MGABASE1 + 1E08h (MEM) Attributes R/W, DYNAMIC, DWORD The **WFLAGNB1** register is an alternate way to load the **WFLAG1** register, bypassing the BFIFO. (See **WFLAG1** for field descriptions.) ◆ *Note:* The WARP1 flags are *not stable* when the WARP1 engine is running. Address MGABASE1 + 1DC8h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown wbrkrighttop wcentersnap wbrklefttop wfastcrop Reserved Reserved Reserved wGetMSBmax wGetMSBmin 19 18 15 14 13 12 11 10 9 2 30 | 29 | 28 | 27 | 26 | 25 | 24 | 17 3 **wGetMSBmin** GetMSB minimum value. See the following note. <4:0> wGetMSB GetMSB maximum value max <12:8> •• *Note:* These values are used by the GETMSB instruction to restrict the range of the results. Refer to the GETMSB instruction for more information. wbrklefttop See the following note. <16> **wfastcrop** See the following note. <17> wcentersnap See the following note. <18> Reserved <31:20> <15:13> <7:5> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. Address MGABASE1 + 1DC0h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD wiaddr Se Se | 2 | 1 3 | $\Omega$ | 29 | 28 | 27 | 26 | 25 | 24 | 22 | 22 | 21 | 20 | 10 | 18 | 17 | 16 | 15 | 14 | 12 | 12 | 11 | 10 | a | 0 | 7 | 6 | - 5 | 1 | 2 | 2 | 1 | $\cap$ | |---|-------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|---|--------| | ) | 1 3 | $\mathbf{v}$ | 29 | 20 | 21 | 20 | 23 | 24 | 23 | 22 | 21 | 20 | 19 | 10 | 1/ | 10 | 13 | 14 | 13 | 12 | 11 | 10 | 9 | 0 | / | U | ) | 4 | 3 | | 1 | U | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | wmode <1:0> WARP Mode of operation. | wmode | Operation | |-------------|-----------| | '00' | Suspend | | '01' | Resume | | '10' | Jump | | <b>'11'</b> | Start | • Suspend: In this mode, all execution in the WARP is stopped. Writing to the **wiaddr** and **wagp** field is ignored. • Resume: In this mode the microcode is allowed to resume from where it was STOPped (suspended or STOP (instruction)). Writing to the **wiaddr** and **wagp** field is ignored. This mode *must* be set *only* when the engine is idle. • Jump: In this mode, the microcode starts executing from where the **wiaddr** field specifies it. A reset is *not* performed in the engine; the software *must* be aware of the current state of the engine (pending store back) and must check the **wbusy** bit. This mode *must* be set *only* when the engine is idle. • Start: This mode operates like Jump mode, but it resets the engine. wagp <2> Specifies what host cycle should be used to load the microcode from the system memory when mastering is enabled (see **WMISC**). | wagp | cycle | |------------|-------| | '0' | PCI | | <b>'1'</b> | AGP | wiaddr <31:3> WARP Instruction Address. - Bits 31 to 3 represent the current address of the microcode to be fetched. - The WARP engine can only modify bits 17 to 3. - When caching is disabled, bit 31 to 11 must be set to '0' (the microcode must reside within the 2 kbyte instruction memory). - ◆ *Note*: The microcode has to be aligned on a 256 byte boundary. Address MGABASE1 + 1DD8h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD wiaddr | Wi wmode <1:0> WARP Mode of operation. | wmode | Operation | |--------------|-----------| | '00' | Suspend | | <b>'</b> 01' | Resume | | '10' | Jump | | <b>'11'</b> | Start | • Suspend: In this mode, all execution in the WARP is stopped. Writing to the **wiaddr** and **wagp** field is ignored. • Resume: In this mode the microcode is allowed to resume from where it was STOPped (suspended or STOP (instruction)). Writing to the **wiaddr** and **wagp** field is ignored. This mode *must* be set *only* when the engine is idle. • Jump: In this mode, the microcode starts executing from where the **wiaddr** field specifies it. A reset is *not* performed in the engine; the software *must* be aware of the current state of the engine (pending store back) and must check the **wbusy** bit. This mode *must* be set *only* when the engine is idle. • Start: This mode operates like Jump mode, but it resets the engine. wagp <2> Specifies what host cycle should be used to load the microcode from the system memory when mastering is enabled (see **WMISC**). | wagp | cycle | |-------------|-------| | <b>'</b> 0' | PCI | | <b>'</b> 1' | AGP | wiaddr <31:3> WARP Instruction Address. - Bits 31 to 3 represent the current address of the microcode to be fetched. - The WARP engine can only modify bits 17 to 3. - When caching is disabled, bit 31 to 11 must be set to '0' (the microcode must reside within the 2 kbyte instruction memory). - •• *Note*: The microcode has to be aligned on a 256 byte boundary. - ◆ Note: This register affects both warps. Address MGABASE1 + 1E60h (MEM) Attributes R/W, DYNAMIC, DWORD The **WIADDRNB** register is an alternate means of loading the **WIADDR** register, bypassing the BFIFO. (See **WIADDR** for the field descriptions). •• *Note:* Bits 2 to 0 are write only, reading will give '0'. •• *Note:* The WARP Instruction Address register is *not stable* when the WARP engine is running. Address MGABASE1 + 1E04h (MEM) Attributes RO, DYNAMIC, DWORD Bits 2 to 0 are write only, reading will give '0'. ◆ *Note:* The WARP1 Instruction Address register is *not stable* when the WARP engine is running. Address MGABASE1 + 1E00h (MEM) Attributes WO, DYNAMIC, DWORD The **WIADDRNB2** register is an alternate means of loading the **WIADDR2** register, bypassing the BFIFO. (See **WIADDR2** for the field descriptions). •• *Note:* Bits 2 to 0 are write only, reading will give '0'. •• *Note:* The WARP1 Instruction Address register is *not stable* when the WARP engine is running. Address MGABASE1 + 1E68h (MEM) Attributes WO, STATIC, DWORD Reset Value unknown | Reserved | wimemaddr | |----------|-----------| |----------|-----------| | 3 | 1 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| wimemaddr <7:0> WARP Instruction Memory Address. This register is used to address the Instruction Memory to load the microcode. This register is incremented every 2 writes to the **WIMEMDATA** space. When this address increments beyond the last Instruction Memory location, it will wrap around to location 0. Writing to this register will reset the modulo 2 counter to 0. Reading to the **WIMEMDATA** space will *not* increment **WIMEMADDR** Reserved <31:8> Reserved. When writing to this register, the bits in this field *must* be set to '0'. ◆ *Note:* The WARP engine *must* be idle before writing to this register. Address MGABASE1 + 2000h to MGABASE1 + 207Fh **Attributes** R/W, STATIC, DWORD Reset Value unknown #### wimemdata | | | | | | | | | | | | | | | | | | | | | | | | _ | _ | l _ | | _ | | _ | _ | | | |-----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|----|---|-----|----|-----|------| | -13 | 111 | 30 l | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 15 | 4 | - 3 | 2. | 1 1 | () [ | | | 1 | 50 | | | -, | | | | 23 | | | | 1/ | 10 | 1, | 10 | 10 | | 10 | 12 | | 10 | _ | 0 | , | 0 | _ | | | _ | - | | ## wimemdata <31:0> WARP Instruction Memory Data. This range is used to load data in the WARP Instruction Memory. Since the Instruction Memory is 64 bits wide, two accesses are required to this range in order to write one complete location. The address in the WARP Instruction Memory to be written is determined by the value in the WIMEMADDR register. When wucodecache = '0' there is no caching. To read one complete Instruction memory location (64 bits), **WIMEMADDR** must be written with the location to be read. This data can then be read at MGABASE1+2000h for DW0, and at MGABASE1+2004h for DW1. • Note: The wmaster field in the WMISC register must be set '0' when writing to this range (MGABASE1 + 2000h to MGABASE1 + 207Fh). Address MGABASE1 + 2100h to MGABASE1 + 217Fh **Attributes** R/W, STATIC, DWORD Reset Value unknown #### wimemdata1 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 10 | 1 2 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | a | Q | 7 | 6 | - 5 | 1 | 3 | 2 | 1 | $\cap$ | |----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|---|--------| | 31 | 50 | 4) | 20 | 41 | 20 | 23 | 4 | 23 | 22 | 41 | 20 | 1) | 10 | 1/ | 10 | 15 | 14 | 13 | 12 | 11 | 10 | | O | / | U | J | - | ) | | 1 | U | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ## wimemdata1 <31:0> WARP1 Instruction Memory Data. This range is used to load data in the WARP1 Instruction Memory. Since the Instruction Memory is 64 bits wide, two accesses are required to this range in order to write one complete location. The address in the WARP1 Instruction Memory to be written is determined by the value in the WIMEMADDR register. When wucodecache = '0' there is no caching. To read one complete Instruction memory location (64 bits), **WIMEMADDR1** must be written with the location to be read. This data can then be read at MGABASE1+2000h for DW0, and at MGABASE1+2004h for DW1. **Note:** The **wmaster** field in the **WMISC** register must be set '0' when writing to this range (**MGABASE1** + 2000h to **MGABASE1** + 207Fh). **Address** MGABASE1 + 1E70 (MEM) Attributes R/W, DWORD, STATIC **Reset Value** ???? ???? ???? ???? ???? <u>0</u>?<u>00</u>b wcacheflush Reserved wmaster wucodecache #### Reserved | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| wucode cache <0> WARP microcode Caching Enable. When set to '1', microcode caching is enabled. It is **not** necessary to load the microcode via the **WIMEMDATA** space before starting the WARP engine; the caching system will fetch the microcode when needed. When at '0', caching of the microcode will **not** be performed; the entire microcode must be loaded into the Instruction Memory via the **WIMEMDATA** space before starting the engine. wmaster <1> When at '1', this bit indicates that microcode loading will be done through bus mastering; when at '0', microcode loading will be handled by interrupt. (See 'Cache Operation' on page 6-16). This bit is only used when **wucodecache** = '1'. wcacheflush <3> WARP microcode Cache Flush. When this bit is set to '1' the WARP cache tags are reset: the contents of the Instruction memory are invalidated. Reading will give '0's. Reserved <31:4> <2> Reserved. When writing to this register, the bits in this field *must* be set to '0'. WARP Register WF Address MGABASE1 + 2D00h (MEM) (WR0) . . . MGABASE1 + 2DFCh (MEM) (WR63) Attributes WO, DB, DYNAMIC, DWORD, FIFO **Reset Value** unknown wr | 3 | 1 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| These are the 64 multi-purpose WARP registers (WR0, WR1, ... WR63). They can represent an IEEE single precision floating point number, a fixed point 32-bit integer, two 16-bit words or four bytes. It is up to the software to define what to put in these registers and how the microcode will interpret them. WVRTXSZ WARP Vertex Size Address MGABASE1 + 1DCCh (MEM) Attributes WO, FIFO, STATIC, DWORD **Reset Value** ???? ???? ???? ??00 0000 ??11 1111b | | | | | | | | R | ese | erve | ed | | | | | | | | | ķ | orir | nsz | Z | | Dograda | | | W | /vrt | txs | z | | |----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|------|-----|---|---|---------|---|---|---|------|-----|---|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | wvrtxsz <5:0> WARP Vertex Size. This is the number of registers (minus one) to be written sequentially in the **WR** register before switching to the next bank. This information is used to align the vertices in the register bank boundaries and is only used by the ACCEPT command. When **WVRTXSZ** + 1 registers have been transferred to the **WR** register, the pointer will jump to the beginning of the next bank. This field is also used by the Setup DMA Channel to determine the dword length of each DMA vertex fixed length setup list entry (setupmod = '00'). primsz <13:8> Primitive Size. This field is used in conjunction with **WACCEPTSEQ** and only with the sub-instruction .seq of the ACCEPT.w instruction. The first .seq sub-instruction executed by the ACCEPT sequencer will replace the size from this instruction by **primsz**<13:8>. The first ACCEPT .seq can be generated by WARPO or WARP1 depending on the micro code. All other ACCEPT.seq will use the size included with the instruction until **WACCPTSEQ** is programmed. The **primsz** field follows the same field size rules as in the ACCEPT instruction. Reserved <31:14> <7:6> Reserved. When writing to this register, the bits in this field *must* be set to '0'. AddressMGABASE1 + 1CB0h (MEM)AttributesWO, FIFO, DYNAMIC, DWORD Reset Value unknown Reserved xdst | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| xdst <15:0> The x-coordinate of destination address. The **xdst** field contains the running x-coordinate of the destination address. It is a 16-bit signed value in two's complement notation. - Before starting a vector draw, **xdst** must be loaded with the x-coordinate of the starting point of the vector. At the end of a vector, **xdst** contains the address of the last pixel of the vector. This can also be done by accessing the **XYSTRT** register. - This register does *not* require initialization for polyline operations. - For BLITs, this register is automatically loaded from fxleft (see FXLEFT on page 3-147) and fxright (see FXRIGHT on page 3-148), and no initial value must be loaded. - For trapezoids with depth, this register is automatically loaded from **fxleft**. For trapezoids without depth, **xdst** will be loaded with the larger of **fxleft** or **cxleft**, and an initial value must *not* be loaded. (See **CXLEFT** on page 3-108.) Reserved <31:16> Reserved. When writing to this register, the bits in this field *must* be set to '0'. XYEND XY End Address Address MGABASE1 + 1C44h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown y\_end x\_end The **XYEND** register is *not* a physical register. It is simply an alternate way to load registers **AR0** and **AR2**. The **XYEND** register is only used for AUTOLINE drawing. When **XYEND** is written, the following registers are affected: • x\_end<15:0> $\rightarrow$ ar0<17:0> (sign extended) • y\_end<15:0> $\rightarrow$ ar2<17:0> (sign extended) **x\_end** The **x\_end** field contains the x-coordinate of the end point of the vector. It is a 16-bit signed value in two's complement notation. y\_end The y\_end field contains the y-coordinate of the end point of the vector. It is a 16-bit signed value in two's complement notation. XY Start Address XYSTR Address MGABASE1 + 1C40h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown y\_start x\_start The **XYSTRT** register is *not* a physical register. It is simply an alternate way to load registers **AR5**, **AR6**, **XDST**, and **YDST**. The **XYSTRT** register is only used for LINE and AUTOLINE. **XYSTRT** does *not* need to be initialized for polylines because all the registers affected by **XYSTRT** are updated to the endpoint of the vector at the end of the AUTOLINE. When **XYSTRT** is written, the following registers are affected: • x start< $15:0> \rightarrow xdst<15:0>$ • $\mathbf{x}_{\text{start}} < 15:0 > \rightarrow \mathbf{ar5} < 17:0 > \text{ (sign extended)}$ • y start<15:0> $\rightarrow$ ydst<22:0> (sign extended), 0 $\rightarrow$ sellin • $y_start<15:0> \rightarrow ar6<17:0>$ (sign extended) x\_start <15:0> The **x\_start** field contains the x-coordinate of the starting point of the vector. It is a 16-bit signed value in two's complement notation. y\_start <31:16> The **y\_start** field contains the y-coordinate of the starting point of the vector. This coordinate is always xy (this means that, in order to use the **XYSTRT** register, the linearizer must be used). It is a 16-bit signed value in two's complement notation. Address MGABASE1 + 1C9Ch (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved cybot | 1 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| cybot <23:0> Clipper y bottom boundary. The **cybot** field contains an unsigned 24-bit value which is interpreted as a positive pixel address and compared with the current **ydst** (see **YDST on page 3-283**). The value of the **ydst** field must be less than or equal to **cybot** to be inside the drawing window. This register must be programmed with a linearized line number: **cybot** = (bottom line number) $\times$ **PITCH** The **YBOT** register must be loaded with a multiple of 32 (the five LSBs = 0). • Note: Clipping can be disabled by the **clipdis** bit in **DWGCTL** without changing **cybot**. Reserved <31:24> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Y Address YDST Address MGABASE1 + 1C90h (MEM) Attributes WO, FIFO, DYNAMIC, DWORD Reset Value unknown | | se | llin | | R | ese | erve | ed | | | | | | | | | | | | } | /ds | t | | | | | | | | | | | |---|-----|------|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|---|---| | 3 | 1 3 | 0 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | #### ydst <22:0> The y destination. The **ydst** field contains the current y-coordinate (in pixels) of the destination address as a signed value in two's complement notation. Two formats are supported: linear format and xy format. The current format is selected by **ylin** (see **PITCH on page 3-162)**. When xy format is used (**ylin**=0), ydst represents the y-coordinate of the address. The valid range is -32768 to +32767 (16-bit signed). The xy value is always converted to a linear value before being used. When linear format is used (**ylin**=1), ydst must be programmed as follows: The y-coordinate range is from -32768 to +32767 (16-bit signed) and the pitch range is from 32 to 4096. Pitch is also a multiple of 32. - Before starting a vector draw, **ydst** must be loaded with the y-coordinate of the starting point of the vector. This can be done by accessing the **XYSTRT** register. This register does *not* require initialization for polyline operations. - Before starting a BLIT, **ydst** must be loaded with the y-coordinate of the starting corner of the destination rectangle. - For trapezoids, this register must be loaded with the y-coordinate of the first scanned line of the trapezoid. - To load the texture color palette, **ydst** must be loaded with the position in the color palette (0 to 255) at which the texture color palette will begin loading. - •• *Note:* When **ylin** = 0 (even when the y-coordinate range is 16-bit signed), the sign must be extended until bit 22. - For sub-pixel trapezoids, it is a signed 16.4 value in two's complement notation, and *xy* format *must* be used. # sellin <31:29> Selected line. The **sellin** field is used to perform the dithering, patterning, and transparency functions. During linearization, this field is loaded with the three LSBs of **ydst** (y-coordinate). If no linearization occurs, then those bits must be initialized correctly if one of the above-mentioned functions is to be used. #### Reserved <28:23> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Address MGABASE1 + 1C88h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown yval length | 31 | 1 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| The **YDSTLEN** register is *not* a physical register. It is simply an alternate way to load the **YDST** and **LEN** registers. length <15:0> Length. See the **LEN register on page 3-151.** yval <31:16> The y destination value. See the **YDST register on page 3-283.** The **yval** field can be used to load the **YDST** register in xy format. In this case the valid range -32768 to +32767 (16-bit signed) for **YDST** is respected. **ydst**<22:0> <= sign extension (**yval**<31:16>) For the linear format, **yval** does *not* contain enough bits, so **YDST** must be used directly. Address MGABASE1 + 1C98h (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown Reserved cytop | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| cytop <23:0> Clipper y top boundary. The **cytop** field contains an unsigned 24-bit value which is interpreted as a positive pixel address and compared with the current **ydst** (see **YDST** on page 3-283). The value of the **ydst** field must be greater than or equal to **cytop** to be inside the drawing window. This register must be programmed with a linearized line number: **cytop** = (top line number) $\times$ **PITCH** This register must be loaded with a multiple of 32 (the five LSBs = 0). • Note: Clipping can be disabled by the **clipdis** bit in **DWGCTL** without changing **cytop**. Reserved <31:24> Reserved. When writing to this register, the bits in this field *must* be set to '0'. ZORG Z-Depth Origin Address MGABASE1 + 1C0Ch (MEM) Attributes WO, FIFO, STATIC, DWORD Reset Value unknown zorgacc zorgmap #### zorg | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| zorgmap <0> Z-depth Origin Map. This field indicates the map location. - 0: depth buffer is in the frame buffer - 1: depth buffer is in the system memory zorgacc <1> Z-depth Origin Access type. This field specifies the mode used to access the map. - 0: PCI access - 1: AGP access - •• *Note:* This field is *not* considered if, the depth buffer resides in the frame buffer space. zorg <31:2> Z-depth origin. The **zorg** field is a 30-bit unsigned value used as an offset from the Intensity buffer to position the first Z value of the depth buffer. The **zorg** field is a dword address in memory. This register must be set so that there is no overlap with the Intensity buffer. This field must be loaded with a multiple of 128 (the seven LSBs = 0). • Note: See 'Zbuffer Direct Access Procedure when Zbuffer is in AGP Space' on page 4-51. ### 3.2 VGA Mode Register Descriptions ### 3.2.1 VGA Mode Register Descriptions The Matrox G400 VGA Mode register descriptions contain a (single-underlined) main header which indicates the register's name and mnemonic. Below the main header, the memory address or index, attributes, and reset value are indicated. Next, an illustration of the register identifies the bit fields, which are then described in detail below the illustration. Reserved bit fields are identified by black underscore bars; all other fields display alternating white and gray bars. #### **Address** This address is an offset from the Power Graphic mode base memory address. The memory addresses can be read, write, color, or monochrome, as indicated. #### Index The index is an offset from the starting address of the register group. #### **Attributes** The VGA mode attributes are: RO: There are no writable bits. WO: The state of the written bits cannot be read. R/W: The state of the written bits can be read. BYTE: 8-bit access to the register is possible. • WORD: 16-bit access to the register is possible. STATIC: The contents of the register will not change during an operation. DYNAMIC: The contents of the register might change during an operation. #### **Reset Value** $\blacksquare$ 000? 0000b (b = binary,? = unknown, N/A = not applicable) Attribute Controller ATTR Address R/W at port 03C0h (I/O), MGABASE1 + 1FC0h (MEM) VGA R at port 03C1h (I/O), MGABASE1 + 1FC1h (MEM) VGA **Attributes** BYTE, STATIC Reset Value nnnn nnnn 0000 0000b | | | | at | trd | | | | Rese | rved | pas | | | attrx | | | |----|----|----|----|-----|----|---|---|------|------|-----|---|---|-------|---|---| | | | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | attrx <4:0> Attribute controller index register. VGA. A binary value that points to the VGA Attribute Controller register where data is to be written or read. | Register name | Mnemonic | attrx address | |----------------------------|----------|---------------| | Palette entry 0 | ATTR0 | 00h | | Palette entry 1 | ATTR1 | 01h | | Palette entry 2 | ATTR2 | 02h | | Palette entry 3 | ATTR3 | 03h | | Palette entry 4 | ATTR4 | 04h | | Palette entry 5 | ATTR5 | 05h | | Palette entry 6 | ATTR6 | 06h | | Palette entry 7 | ATTR7 | 07h | | Palette entry 8 | ATTR8 | 08h | | Palette entry 9 | ATTR9 | 09h | | Palette entry A | ATTRA | 0Ah | | Palette entry B | ATTRB | 0Bh | | Palette entry C | ATTRC | 0Ch | | Palette entry D | ATTRD | 0Dh | | Palette entry E | ATTRE | 0Eh | | Palette entry F | ATTRF | 0Fh | | Attribute Mode Control | ATTR10 | 10h | | Overscan Color | ATTR11 | 11h | | Color Plane Enable | ATTR12 | 12h | | Horizontal Pel Panning | ATTR13 | 13h | | Color Select | ATTR14 | 14h | | Reserved - read as '0' (1) | _ | 15h-1Fh | <sup>(1)</sup> Writing to a reserved index has no effect. <sup>•</sup>A read from port 3BAh/3DAh resets this port to the attributes address register. The first write at 3C0h after a 3BAh/3DAh reset accesses the attribute index. The next write at 3C0h accesses the palette. Subsequent writes at 3C0h toggle between the index and the palette. <sup>•</sup>A read at port 3C1h does not toggle the index/data pointer. ### **Example of a palette write:** Reset pointer: read at port 3BAh Write index: write at port 3C0h Write color: write at port 3C0h #### Example of a palette read: Reset pointer: read at port 3BAh Write index: write at port 3C0h Read color: read at port 3C1h Palette address source. VGA. This bit controls use of the internal palette. If **pas** = 0, the host CPU can read and write the palette, and the display is forced to the overscan color. If **pas** = 1, the palette is used normally by the video stream to translate color indices (CPU writes are inhibited and reads return all '1's). Normally, the internal palette is loaded during the blank time, since loading inhibits video translation. attrd ATTR data register. <15:8> Retrieve or write the contents of the register pointed to by the **attrx** field. **Reserved** Reserved. When writing to this register, the bits in this field *must* be set to '0'. **<7:6>** Reading will give '0's. Index attrx = 00h to attrx = 0Fh Reset Value 0000 0000b | Rese | rved | | | pale | t0-F | | | |------|------|---|---|------|------|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | palet0-F <5:0> Internal palette data. VGA. These six-bit registers allow dynamic mapping between the text attribute or graphic color input value and the display color on the CRT screen. These internal palette register values are sent from the chip to the video DAC, where they in turn serve as addresses to the DAC internal registers. A palette register can be loaded only when pas(ATTR<5>) = 0. Reserved <7:6> Reserved. When writing to this register, the bits in this field *must* be set to '0'. # atcgrmode <0> Graphics/alphanumeric mode. VGA. - 0: Alphanumeric mode is enabled and the input of the internal palette circuit comes from the expansion of the foreground/background attribute. - 1: Graphics mode is enabled and the input of the internal palette comes from the frame buffer pixel. This bit also selects between graphics blinking or character blinking if blinking is enabled (**blinken** = 1). ## mono <1> Mono emulation. VGA. - 0: Color emulation. - 1: Monochrome emulation. # lgren <2> Enable line graphics character code. VGA. - 0: The ninth dot of a line graphic character (a character between C0h and DFh) will be the same as the background. - 1: Forces the ninth dot to be identical to the eighth dot of the character. For other ASCII codes, the ninth dot will be the same as the background. For character fonts that do not utilize the line graphics character, **Igren** should be '0'. Otherwise, unwanted video information will be displayed. This bit is 'don't care' in graphics modes (**atcgrmode** = 0). ## blinken <3> Select background intensity or blink enable. VGA. - 0: Blinking is disabled. In alpha modes (**atcgrmode** (**ATTR10**<0>) = 0), this bit defines the attribute bit 7 as a background high-intensity bit. In graphic modes, planes 3 to 0 select 16 colors out of 64. - 1: Blinking is enabled. In alpha modes (**atcgrmode** = 0), this bit defines the attribute bit 7 as a blink attribute (when the attribute bit 7 is '1', the character will blink). The blink rate of the character is vsync/32, and the blink duty cycle is 50%. In monochrome graphics mode (**mono** and **atcgrmode** (**ATTR10**<1:0>) = 11), all pixels toggle on and off. In color graphics modes (**mono** and **atcgrmode** (**ATTR10**<1:0>) = 01), only pixels that have **blinken** (bit 3) high will toggle on and off: other pixels will have their bit 3 forced to '1'. The graphic blink rate is VSYNC/32. Graphic blink logic is applied after plane masking (that is, if plane 3 is disabled, monochrome mode will blink and color mode will not blink). # pancomp <5> Pel panning compatibility. VGA. - 0: Line compare has no effect on the output of the PEL panning register. - 1: A successful line compare in the CRT controller maintains the panning value to '0' until the end of frame (until next vsync), at which time the panning value returns to the value of **hpelcnt** (ATTR13<3:0>). This bit allows panning of only the top portion of the display. ### pelwidth Pel width. VGA. <6> - 0: The six bits of the internal palette are used instead. - 1: Two 4-bit sets of video data are assembled to generate 8-bit video data. ### p5p4 <7> P5/P4 select. VGA. - 0: Bits 5 and 4 of the internal palette registers are transmitted to the DAC. - 1: When it is set to '1', **colsel54** (**ATTR14**<1:0>) will be transmitted to the DAC. See the **ATTR14** register on page 3-297. # Reserved <4> Reserved. When writing to this register, this field *must* be set to '0'. ATTR11 **Overscan Color** Index attrx = 11h**Reset Value** 0000 0000ь | | ovs | col | |--|-----|-----| | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| ovscol <7:0> Overscan color. VGA. Determines the overscan (border) color displayed on the CRT screen. The value programmed is the index of the border color in the DAC. The border color is displayed when the internal DISPEN signal is inactive and blank is not active. **Color Plane Enable** ATTR12 Index attrx = 12h**Reset Value** 0000 0000ь > Reserved vidstmx colplen 5 4 3 2 0 7 6 1 colplen <3:0> Enable color plane. VGA. vidstmx <5:4> Video status multiplexer (MUX). VGA. These bits select two of eight color outputs for the status port. Refer to the table in the description of the **INSTS1** register's **diag** field that appears on page 3-357. Reserved <7:6> Reserved. When writing to this register, the bits in this field *must* be set to 0.13. | | Rese | erved | | | hpe | lcnt | | |---|------|-------|---|---|-----|------|---| | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | hpelcnt <3:0> Horizontal pel count. VGA. This 4-bit value specifies the number of picture elements to shift the video data horizontally to the left, according to the following table (values 9 to 15 are reserved): | hpelcnt | 8 dot mode<br>pixel shifted<br><b>dotmode</b><br>( <b>SEQ1</b> <0>) = '1' | 9 dot mode pixel shifted dotmode = '0' | mode256<br>(GCTL5<6>) = '1' | |---------|---------------------------------------------------------------------------|----------------------------------------|-----------------------------| | '0000' | 0 | 1 | 0 | | '0001' | 1 | 2 | - | | '0010' | 2 | 3 | 1 | | '0011' | 3 | 4 | - | | '0100' | 4 | 5 | 2 | | '0101' | 5 | 6 | - | | '0110' | 6 | 7 | 3 | | '0111' | 7 | 8 | - | | '1000' | - | 0 | - | Reserved <7:4> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Color Select ATTR14 | | Rese | erved | | cols | el76 | cols | el54 | |---|------|-------|---|------|------|------|------| | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | colsel54 Select color 5 to 4. VGA. <1:0> When **p5p4** (ATTR10<7>) is '1', **colsel54** is used instead of internal palette bits 5 and 4. This mode is intended for rapid switching between sets of colors (four sets of 16 colors can be defined). These bits are 'don't care' when **mode256** = 1. colsel76 Select color 7 to 6. VGA. <3:2> These bits are the two MSB bits of the external color palette index. They can rapidly switch between four sets of 64 colors. These bits are 'don't care' when **mode256** (**GCTL5**<6>) = 1. Reserved <7:4> Reserved. When writing to this register, the bits in this field *must* be set to '0'. **CACHEFLUSH Cache Flush** **Address** MGABASE1 + 1FFFh (MEM) **Attributes** R/W, BYTE, STATIC **Reset Value** unknown #### cacheflush | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| cacheflush <7:0> Flush the cache. Writes to this register will flush the cache. For additional details, refer to 'Direct Access Read Cache' on page 4-5. Even though this register can be read, its data has no significance, and may not be consistent. When writing to this register, all bits must be set to '0'. CRTC Registers CRTC Address 03B4h (I/O), (MISC<0> == 0: MDA emulation) 03D4h (I/O), (MISC<0> == 1: CGA emulation) MGABASE1 + 1FD4h (MEM) AttributesR/W, BYTE/WORD, STATICReset Valuennnn nnnn 0000 0000b | | crtcd | | | | | | | | | rved | | | crt | CX | | | |---|-------|----|----|----|----|----|---|---|---|------|---|---|-----|----|---|---| | - | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | crtcx <5:0> CRTC index register. A binary value that points to the VGA **CRTC** register where data is to be written or read when the **crtcd** field is accessed. | Register name | Mnemonic | crtcx address | |--------------------------------|----------|---------------| | CRTC register index | CRTCx | | | Horizontal Total | CRTC0 | 00h | | Horizontal Display Enable End | CRTC1 | 01h | | Start Horizontal Blanking | CRTC2 | 02h | | End Horizontal Blanking | CRTC3 | 03h | | Start Horizontal Retrace Pulse | CRTC4 | 04h | | End Horizontal Retrace | CRTC5 | 05h | | Vertical Total | CRTC6 | 06h | | Overflow | CRTC7 | 07h | | Preset Row Scan | CRTC8 | 08h | | Maximum Scan Line | CRTC9 | 09h | | Cursor Start | CRTCA | 0Ah | | Cursor End | CRTCB | 0Bh | | Start Address High | CRTCC | 0Ch | | Start Address Low | CRTCD | 0Dh | | Cursor Location High | CRTCE | 0Eh | | Cursor Location Low | CRTCF | 0Fh | | Vertical Retrace Start | CRTC10 | 10h | | Vertical Retrace End | CRTC11 | 11h | | Vertical Display Enable End | CRTC12 | 12h | | Offset | CRTC13 | 13h | | Underline Location | CRTC14 | 14h | | Start Vertical Blank | CRTC15 | 15h | | End Vertical Blank | CRTC16 | 16h | | CRTC Mode Control | CRTC17 | 17h | | Line Compare | CRTC18 | 18h | | Reserved - read as 0 (1) | _ | 19h - 21h | | CPU Read Latch | CRTC22 | 22h | | Reserved - read as 0 | | 23h | <sup>(1)</sup> Writing to a reserved index has no effect. CRTC Registers | Register name | Mnemonic | crtcx address | |-------------------------------|----------|---------------| | Attribute address/data select | CRTC24 | 24h | | Reserved - read as 0 | _ | 25h | | Attribute address | CRTC26 | 26h | | Reserved read as 0 | _ | 27h - 3Fh | crtcd CRTC data register. Retrieve or write the contents of the register pointed to by the <15:8> **Reserved** Reserved. When writing to this register, the bits in this field *must* be set to '0'. Reading will give '0's. Horizontal Total CRTC0 | htotal | | |--------|--| | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| htotal <7:0> Horizontal total. VGA/MGA. This is the low-order eight bits of a 9-bit register (bit 8 is contained in **htotal** (**CRTCEXT1**<0>)). This field defines the total horizontal scan period in character clocks minus 5. ### hdispend | | | | | • | | | | |---|---|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | hdispend <7:0> Horizontal display enable end. VGA/MGA. Determines the number of displayed characters per line. The display enable signal becomes inactive when the horizontal character counter reaches this value. | | | | hbl | kstr | | | | |---|---|---|-----|------|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | hblkstr <7:0> Start horizontal blanking. VGA/MGA. This is the low-order eight bits of a 9-bit register. Bit 8 is contained in **hblkstr** (**CRTCEXT1**<1>). The horizontal blanking signal becomes active when the horizontal character counter reaches this value. # hblkend <4:0> End horizontal blanking bits. VGA/MGA. The horizontal blanking signal becomes inactive when, after being activated, the lower six bits of the horizontal character counter reach the horizontal blanking end value. The five lower bits of this value are located here; bit 5 is located in the **CRTC5** register, and bit 6 is located in **CRTCEXT1**. This register can be write-inhibited when **crtcprotect** (CRTC11 < 7 >) = 1. ## hdispskew <6:5> Display enable skew control. VGA/MGA. Defines the number of character clocks to delay the display enable signal to compensate for internal pipeline delays. Normally, the hardware can accommodate the delay, but the VGA design allows greater flexibility by providing extra control. | hdispskew | Skew | |-------------|-------------------------------| | '00' | 0 additional character delays | | '01' | 1 additional character delays | | '10' | 2 additional character delays | | <b>'11'</b> | 3 additional character delays | # Reserved <7> This field is defined as a bit for chip testing on the IBM VGA, but is not used on the MGA. Writing to it has no effect (it will read as 1). For compatibility considerations, a '1' should be written to it. | hsyncstr | | | | | | | | |----------|---|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ' | U | J | | | _ | ' | U | hsyncstr <7:0> Start horizontal retrace pulse. VGA/MGA. These are the low-order eight bits of a 9-bit register. Bit 8 is contained in **hsyncstr** (**CRTCEXT1**<2>). The horizontal sync signal becomes active when the horizontal character counter reaches this value. hsyncend <4:0> End horizontal retrace. VGA/MGA. The horizontal sync signal becomes inactive when, after being activated, the five lower bits of the horizontal character counter reach the end horizontal retrace value. This register can be write-inhibited when **crtcprotect** (CRTC11<7>) = 1. hsyncdel <6:5> Horizontal retrace delay. VGA/MGA. Defines the number of character clocks that the hsync signal is delayed to compensate for internal pipeline delays. | hsyncdel | Skew | |-------------|-------------------------------| | '00' | 0 additional character delays | | '01' | 1 additional character delays | | '10' | 2 additional character delays | | <b>'11'</b> | 3 additional character delays | hblkend <7> End horizontal blanking bit 5. VGA/MGA. Bit 5 of the End Horizontal Blanking value. See the **CRTC3** register on page 3-304. Vertical Total CRTC6 | | | | vtc | tal | | | | |---|---|---|-----|-----|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | vtotal <7:0> Vertical total. VGA/MGA. These are the low-order eight bits of a 12-bit register. Bit 8 is contained in **CRTC7**<0>, bit 9 is in **CRTC7**<5>, and bits 10 and 11 are in **CRTCEXT2**<1:0>. The value defines the vsync period in scan lines if **hsyncsel** (**CRTC17**<2>) = 0, or in double scan lines if **hsyncsel** = 1). CRTC7 Overflow Index crtcx = 07h Reset Value 0000 0000b | vsyncstr | vdispend | vtotal | linecomp | vblkstr | vsyncstr | vdispend | vtotal | |----------|----------|--------|----------|---------|----------|----------|--------| | 7 | 6 | 5 | 1 | 3 | 2 | 1 | 0 | | / | Ö | 5 | 4 | 3 | | ı | U | **vtotal** Vertical total bit 8. VGA/MGA. Contains bit 8 of the Vertical Total. See the CRTC6 register on page 3-307. This register can be write-inhibited when **crtcprotect** (**CRTC11**<7>) = 1, except for linecomp. **vdispend** Vertical display enable end bit 8. VGA/MGA. <1> Contains bit 8 of the Vertical Display Enable End. See the CRTC12 register on page 3-319. **vsyncstr** Vertical retrace start bit 8. VGA/MGA. Contains bit 8 of the Vertical Retrace Start. See the CRTC10 register on page 3-317. **vblkstr** Start vertical blank bit 8. VGA/MGA. Contains bit 8 of the Start Vertical Blank. See the CRTC15 register on page 3-322. **linecomp** Line compare bit 8. VGA/MGA. Line compare bit 8. See the CRTC18 register on page 3-328. This bit is not write- protected by **crtcprotect** (**CRTC11**<7>). **vtotal** Vertical total bit 9. VGA/MGA. Contains bit 9 of the Vertical Total. See the CRTC6 register on page 3-307. **vdispend** Vertical display enable end bit 9. VGA/MGA. Contains bit 9 of the Vertical Display Enable End. See the CRTC12 register on page 3-319. **vsyncstr** Vertical retrace start bit 9. VGA/MGA. <7> Contains bit 9 of the Vertical Retrace Start. See the CRTC10 register on page 3-317. Preset Row Scan CRTC8 prowscan <4:0> Preset row scan. VGA/MGA. After a vertical retrace, the row scan counter is preset with the value of **prowscan**. At maximum row scan compare time, the row scan is cleared (not preset). The units can be one or two scan lines: • **conv2t4** (**CRTC9**<7>) = 0: 1 scan line • conv2t4 = 1: 2 scan lines bytepan Byte panning control. VGA/MGA. <6:5> This field controls the number of bytes to pan during a panning operation. Reserved <7> Reserved. When writing to this register, this field *must* be set to '0'. Reading will give '0's. maxscan Maximum scan line. VGA/MGA. <4:0> This field specifies the number of scan lines minus one per character row. vblkstr <5> Start vertical blank bit 9. VGA/MGA. **\**J> Bit 9 of the Start Vertical Blank register. See the **CRTC15** register on page 3-322. linecomp Line compare bit 9. VGA/MGA. <6> Bit 9 of the Line Compare register. See the **CRTC18** register on page 3-328. conv2t4 <7> 200 to 400 line conversion. VGA/MGA. Controls the row scan counter clock and the time when the start address latch loads a new memory address: • conv2t4 (CRTC9<7>) = 0: HS • conv2t4 = 1: HS/2 This feature allows a low resolution mode (200 lines, for example) to display as 400 lines on a display monitor. This lowers the requirements for sync capability of the monitor. Cursor Start CRTCA currowstr <4:0> Row scan cursor begins. VGA. These bits specify the row scan of a character line where the cursor is to begin. When the cursor start register is programmed with a value greater than the cursor end register, no cursor is generated. curoff <5> Cursor off. VGA. • Logical '1': turn off the cursor • Logical '0': turn on the cursor Reserved <7:6> Reserved. When writing to this register, the bits in this field *must* be set to '0'. CRTCB Cursor End Description Curskew currowend 7 6 5 4 3 2 1 0 currowend Row scan cursor ends. VGA. <4:0> This field specifies the row scan of a character line where the cursor is to end. curskew <6:5> Cursor skew control. VGA. These bits control the skew of the cursor signal according to the following table: | curskew | Skew | |---------|---------------------------------------------| | '00' | 0 additional character delays | | '01' | Move the cursor right by 1 character clock | | '10' | Move the cursor right by 2 character clocks | | '11' | Move the cursor right by 3 character clocks | Reserved <7> Reserved. When writing to this register, this field *must* be set to '0'. | | | | star | tadd | | | | |---|---|---|------|------|---|---|---| | 7 | 6 | 5 | 1 | 3 | 2 | 1 | 0 | | , | 0 | ז | + | ז | | - | U | startadd <7:0> Start address, bits<15:8>. VGA/MGA. These are the middle eight bits of the start address. The 21-bit value from the **startadd** (**CRTCEXT0**<3:0>) high-order and (**CRTCD**<7:0>) low-order start address registers is the first address after the vertical retrace on each screen refresh. See 'Programming in Power Graphic Mode' on page 4-74 for more information on **startadd** programming. **CRTCD Start Address Low** Index crtcx = 0Dh**Reset Value** 0000 0000ь #### startadd | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| startadd <7:0> Start address, bits<7:0>. VGA/MGA. These are the low-order eight bits of the start address. See the CRTCC register on page 3-313. | | | | cur | loc | | | | |---|---|---|-----|-----|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | curloc <7:0> High order cursor location. VGA. These are the high-order eight bits of the cursor address. The 16-bit value from the high-order and low-order cursor location registers is the character address where the cursor will appear. The cursor is available only in alphanumeric mode. Index crtcx = 0FhReset Value 0000 0000ь | | | | cur | loc | | | | |---|---|---|-----|-----|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | curloc <7:0> Low order cursor location. VGA. These are the low-order eight bits of the cursor location. See the CRTCE register on page 3-315. | 7 6 5 4 2 2 1 0 | | | | vsyr | ncstr | | | | |-----------------|---|---|---|------|-------|---|---|---| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | vsyncstr <7:0> Vertical retrace start bits 7 to 0. VGA/MGA. The vertical sync signal becomes active when the vertical line counter reaches the vertical retrace start value (a 12-bit value). The lower eight bits are located here. Bit 8 is in **CRTC7**<2>, bit 9 is in **CRTC7**<7>, and bits 10 and 11 are in **CRTCEXT2**<6:5>. The units can be one or two scan lines: •hsyncsel (CRTC17<2>) = 0: 1 scan line •hsyncsel = 1: 2 scan lines vsyncend <3:0> Vertical retrace end. VGA/MGA. The vertical retrace signal becomes inactive when, after being activated, the lower four bits of the vertical line counter reach the vertical retrace end value. vintclr <4> Clear vertical interrupt. VGA/MGA. A '0' in **vintclr** will clear the internal request flip-flop. After clearing the request, an interrupt handler *must* write a '1' to **vintclr** in order to allow the next interrupt to occur. vinten <5> Enable vertical interrupt. VGA/MGA. - 0: Enables a vertical retrace interrupt. If the interrupt request flip-flop has been set at enable time, an interrupt will be generated. We recommend setting **vintclr** to '0' when **vinten** is brought low. - 1: Removes the vertical retrace as an interrupt source. sel5rfs <6> Select 5 refresh cycles. VGA. This bit is read/writable to maintain compatibility with the IBM VGA. It does not control the MGA RAM refresh cycle (as in the IBM implementation). Refresh cycles are optimized to minimize disruptions. crtcprotect <7> Protect **CRTC** registers 0-7. VGA/MGA. - 1: Disables writing to **CRTC** registers 0 to 7. - 0: Enables writing. The **linecomp** (line compare) field of **CRTC7** is not protected. | vdispend | | | | | | | | | | |----------|---|---|---|---|---|---|---|--|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | vdispend <7:0> Vertical display enable end. VGA/MGA. The vertical display enable end value determines the number of displayed lines per frame. The display enable signal becomes inactive when the vertical line counter reaches this value. Bits 7 to 0 are located here. Bit 8 is in **CRTC7**<1>, bit 9 is in **CRTC7**<6>, and bit 10 is in **CRTCEXT2**<2>. CRTC13 Offset Index crtcx = 13h**Reset Value** 0000 0000ь | offset | | | | | | | | | |--------|---|---|---|---|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | offset <7:0> Logical line width of the screen. VGA/MGA. These bits are the eight LSBs of a 10-bit value that is used to offset the current line start address to the beginning of the next character row. Bits 8 and 9 are in register **CRTCEXT0**<5:4>. The value is the number of double words (**dword** (**CRTC14**<6>) = 1) or single words (**dword** = 0) in one line. See 'Programming in Power Graphic Mode' on page 4-74 for more information about offset programming. Underline Location CRTC14 undrow <4:0> Horizontal row scan where the underline will occur. VGA. These bits specify the horizontal row scan of a character row on which an underline occurs. count4 <5> Count by 4. VGA. • 0: Causes the memory address counter to be clocked as defined by the **count2** field (CRTC17<3>), 'count by two bits'. • 1: Causes the memory address counter to be clocked with the character clock divided by four. The **count2** field, if set, will supersede **count4**, and the memory address counter will be clocked every two character clocks. dword <6> Double word mode. VGA. - 0: Causes the memory addresses to be single word or byte addresses, as defined by the **wbmode** field (**CRTC17**<6>). - 1: Causes the memory addresses to be double word addresses. See the **CRTC17** register for the address table. Reserved <7> Reserved. When writing to this register, this field *must* be set to '0'. •• Note: In MGA mode, dword must be set to '0' | vblkstr | | | | | | | | |---------|---|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | vblkstr <7:0> Start vertical blanking bits 7 to 0. VGA/MGA. The vertical blank signal becomes active when the vertical line counter reaches the vertical blank start value (a 12-bit value). The lower eight bits are located here. Bit 8 is in **CRTC7**<3>, bit 9 is in **CRTC9**<5>, and bits 10 and 11 are in **CRTCEXT2**<4:3>. **Start Vertical Blank** End Vertical Blank CRTC16 | ., | h | ke | nd | |----|----|----|----| | V | DI | ĸe | na | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| vblkend <7:0> End vertical blanking. VGA/MGA. The vertical blanking signal becomes inactive when, after being activated, the eight lower bits of the internal vertical line counter reach the end vertical blanking value. cms <0> Compatibility mode support. VGA. - 0: Select the row scan counter bit 0 to be output instead of memory counter address 13. See the tables below. - 1: Select memory address 13 to be output. See the tables below. #### **Memory Address Tables** #### Legend: A: Memory address from the CRTC counter RC: Row counter MA: Memory address is sent to the memory controller Double word access {dword (CRTC14<6>), wbmode} = 1X | | {addwrap, selrowscan: cms} | | | | | | | | | |--------|----------------------------|-------|-------|-------------|--|--|--|--|--| | Output | 'X00' | 'X01' | 'X10' | 'X11' | | | | | | | MA0 | '0' | '0' | '0' | <b>'</b> 0' | | | | | | | MA1 | '0' | '0' | '0' | <b>'</b> 0' | | | | | | | MA2 | A0 | A0 | A0 | A0 | | | | | | | MA3 | A1 | A1 | A1 | A1 | | | | | | | MA4 | A2 | A2 | A2 | A2 | | | | | | | MA5 | A3 | A3 | A3 | A3 | | | | | | | MA6 | A4 | A4 | A4 | A4 | | | | | | | MA7 | A5 | A5 | A5 | A5 | | | | | | | MA8 | A6 | A6 | A6 | A6 | | | | | | | MA9 | A7 | A7 | A7 | A7 | | | | | | | MA10 | A8 | A8 | A8 | A8 | | | | | | | MA11 | A9 | A9 | A9 | A9 | | | | | | | MA12 | A10 | A10 | A10 | A10 | | | | | | | MA13 | RC0 | A11 | RC0 | A11 | | | | | | | MA14 | RC1 | RC1 | A12 | A12 | | | | | | | MA15 | A13 | A13 | A13 | A13 | | | | | | Word access {dword, wbmode} = 00 | | | {addwrap, selrowscan: cms} | | | | | | | | | | |--------|--------------|----------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--|--|--| | Output | <i>'000'</i> | <i>'001'</i> | <i>'010'</i> | <i>'011'</i> | <i>'100'</i> | <i>'101'</i> | <i>'110'</i> | <i>'111'</i> | | | | | MA0 | A13 | A13 | A13 | A13 | A15 | A15 | A15 | A15 | | | | | MA1 | A0 | | | | MA2 | A1 | | | | MA3 | A2 | | | | MA4 | A3 | | | | MA5 | A4 | | | | MA6 | A5 | | | | MA7 | A6 | | | | MA8 | A7 | | | | MA9 | A8 | | | | MA10 | A9 | | | | MA11 | A10 | | | | MA12 | A11 | | | | MA13 | RC0 | A12 | RC0 | A12 | RC0 | A12 | RC0 | A12 | | | | | MA14 | RC1 | RC1 | A13 | A13 | RC1 | RC1 | A13 | A13 | | | | | MA15 | A14 | | | ### Byte access {dword, wbmode} = 01 | | {addwrap, selrowscan: cms} | | | | | | | | | |--------|----------------------------|-------|-------|--------------|--|--|--|--|--| | Output | 'X00' | 'X01' | 'X10' | <i>'X11'</i> | | | | | | | MA0 | A0 | A0 | A0 | A0 | | | | | | | MA1 | A1 | A1 | A1 | A1 | | | | | | | MA2 | A2 | A2 | A2 | A2 | | | | | | | MA3 | A3 | A3 | A3 | A3 | | | | | | | MA4 | A4 | A4 | A4 | A4 | | | | | | | MA5 | A5 | A5 | A5 | A5 | | | | | | | MA6 | A6 | A6 | A6 | A6 | | | | | | | MA7 | A7 | A7 | A7 | A7 | | | | | | | MA8 | A8 | A8 | A8 | A8 | | | | | | | MA9 | A9 | A9 | A9 | A9 | | | | | | | MA10 | A10 | A10 | A10 | A10 | | | | | | | MA11 | A11 | A11 | A11 | A11 | | | | | | | MA12 | A12 | A12 | A12 | A12 | | | | | | | MA13 | RC0 | A13 | RC0 | A13 | | | | | | | MA14 | RC1 | RC1 | A14 | A14 | | | | | | | MA15 | A15 | A15 | A15 | A15 | | | | | | **CRTC Mode Control** CRTC17 ### selrowscan Select row scan counter. VGA. <1> - 0: Select the row scan counter bit 1 to be output instead of memory counter address 14. - 1: Select memory address 14 to be output. See the tables in the **cms** field's description. #### hsyncsel <2> Horizontal retrace select. VGA/MGA. - 0: The vertical counter is clocked on every horizontal retrace. - 1: The vertical counter is clocked on every horizontal retrace divided by 2. This bit can be used to double the vertical resolution capability of the CRTC. All vertical timing parameters have a resolution of two lines in divided-by-two mode, including the scroll and line compare capability. #### count2 <3> Count by 2. VGA. - 0: The **count4** field (**CRTC14**<5>) dictates if the character clock is divided by 4 (count4 = 1) or by 1 (count4 = 0). - 1: The memory address counter is clocked with the character clock divided by 2 (count4 is 'don't care' in this case). #### addwrap <5> Address wrap. VGA. - 0: In word mode, select memory address counter bit 13 to be used as memory address bit 0. In byte mode, memory address counter bit 0 is used for memory address bit 0. - 1: In word mode, select memory address counter bit 15 to be used as memory address bit 0. In byte mode, memory address counter bit 0 is used for memory address bit 0. See the tables in the **cms** field's description. #### wbmode <6> Word/byte mode. VGA. - 0: When not in double word mode (**dword** (**CRTC14**<6>) = 0), this bit will rotate all memory addresses left by one position. Otherwise, addresses are not affected. In double word mode, this bit is 'don't care'. See the tables in the **cms** field's description. - 1: Select byte mode. The memory address counter bits are applied directly to the video memory. ### crtcrstN CRTC reset. VGA/MGA. <7> - 0: Force the horizontal and vertical sync to be inactive. - 1: Allow the horizontal and vertical sync to run. #### Reserved <4> Reserved. When writing to this register, this field *must* be set to '0'. Reading will give '0's. **Note:** In MGA mode, wbmode *must* be set to 1, selrowscan set to 1, and cms to 1. CRTC18 Line Compare #### linecomp | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| linecomp <7:0> Line compare. VGA/MGA. When the vertical counter reaches the line compare value, the memory address counter is reset to '0'. This means that memory information located at 0 and up are displayed, rather than the memory information at the line compare. This register is used to create a split screen: - •Screen A is located at memory start address (CRTCC, CRTCD) and up. - •Screen B is located at memory address 0 up to the CRTCC, CRTCD value. The line compare value is an 11-bit value. Bits 7 to 0 reside here, bit 8 is in **CRTC7**<4>, bit 9 is in **CRTC9**<6>, and bit 10 is in **CRTCEXT2**<7>. The line compare unit is always a scan line that is independent of the **conv2t4** field (**CRTC9**<7>). The line compare is also used to generate the vertical line interrupt. CPU Read Latch CRTC22 | cpuc | lata | |------|------| |------|------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| cpudata <7:0> CPU data. VGA. This register reads one of four 8-bit registers of the graphics controller CPU data latch. These latches are loaded when the CPU reads from display memory. The **rdmapsl** field (**GCTL4**<1:0>) determines which of the four planes is read in Read Mode '0' (The **chain4** (**SEQ4** <3>)and **gcoddevmd** (**GCTL5** <4>) fields must be '0'). This register contains color compare data in Read Mode 1. attradsel <7> Attributes address/data select. VGA. - 0: The attributes controller is ready to accept an address value. - 1: The attributes controller is ready to accept a data value. Reserved <6:0> Attributes Address CRTC26 | Rese | erved | pas | attrx | | | | | | | |------|-------|-----|-------|---|---|---|---|--|--| | | | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | attrx <4:0> VGA attributes address pas VGA palette enable. <5> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Reserved <7:6> •See the **ATTR** register on page 3-289. CRTCEXT CRTC Extension Address 03DEh (I/O), MGABASE1 + 1FDEh (MEM) Attributes R/W, BYTE/WORD, STATIC Reset Value nnnn nnnn 0000 0000b | crtcextd | | | | | | Reserved crtcex | | | | | rtcext | X | | | | |----------|----|----|----|----|----|-----------------|---|---|---|---|--------|---|---|---|---| | | | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | crtcextx <2:0> CRTC extension index register. A binary value that points to the CRTC Extension register where data is to be written or read when the **crtcextd** field is accessed. | Register Name | Mnemonic | crtcextx address | |-------------------------------|----------|------------------| | Address Generator Extensions | CRTCEXT0 | 00h | | Horizontal Counter Extensions | CRTCEXT1 | 01h | | Vertical Counter Extensions | CRTCEXT2 | 02h | | Miscellaneous | CRTCEXT3 | 03h | | Memory Page register | CRTCEXT4 | 04h | | Horizontal Video Half Count | CRTCEXT5 | 05h | | Priority Request Control | CRTCEXT6 | 06h | | Request for Control | CRTCEXT7 | 07h | | Address Extension | CRTCEXT8 | 08h | crtcextd <15:8> CRTC extension data register. Retrieves or writes the contents of the register pointed to by the **crtcextx** field. Reserved <7:3> $\label{eq:crtcextx} \begin{array}{ll} \text{Index} & \text{crtcextx} = 00h \\ \text{Reset Value} & 0000 & 0000b \end{array}$ The stand of stan startadd <3:0> Start address bits 20, 19, 18, 17, and 16. These are the five most significant bits of the start address. See the CRTCC register on page 3-313. offset Logical line width of the screen bits 9 and 8. These are the two most significant bits of the offset. See the **CRTC13** register on page 3-320. startadd <6> Start address bits 20. This is a bit of the start address. See the **CRTCC** register on page 3-313. interlace <7> Interlace enable. Indicates if interlace mode is enabled. • 0: Not in interlace mode. • 1: Interlace mode. | vrsten | hblkend | vsyncoff | hsyncoff | hrsten | hsyncstr | hblkstr | htotal | |--------|---------|----------|----------|--------|----------|---------|--------| | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | **htotal** Horizontal total bit 8. This is the most significant bit of the **htotal** (horizontal total) register. See the **CRTC0** register on page 3-301. **hblkstr** Horizontal blanking start bit 8. This is the most significant bit of the **hblkstr** (horizontal blanking start) register. See the **CRTC2** register on page 3-303. **hsyncstr** Horizontal retrace start bit 8. This is the most significant bit of the **hsyncstr** (horizontal retrace start) register. See the **CRTC4** register on page 3-305. **hrsten** Horizontal reset enable. When at '1', the horizontal counter can be reset by the VIDRST pin. hsyncoff Horizontal sync off. <4> • 0: HSYNC runs freely. • 1: HSYNC is forced inactive. **vsyncoff** Vertical sync off. • 0: VSYNC runs freely. • 1: VSYNC is forced inactive. **hblkend** End horizontal blanking bit 6. This bit is used only in MGA mode (**mgamode** = 1; <6> see CRTCEXT3). Bit 6 of the End Horizontal Blanking value. See the **CRTC3** register on page 3-304. **vrsten** Vertical reset enable. When at '1', the vertical counter can be reset by the VIDRST pin. vtotal <1:0> Vertical total bits 11 and 10. These are the two most significant bits of the **vtotal** (vertical total) register (the vertical total is then 12 bits wide). See the **CRTC6** register on page 3-307. vdispend <2> Vertical display enable end bit 10. This is the most significant bit of the **vdispend** (vertical display end) register (the vertical display enable end is then 11 bits wide). See the **CRTC12** register on page 3-319. vblkstr <4:3> Vertical blanking start bits 11 and 10. These are the two most significant bits of the **vblkstr** (vertical blanking start) register (the vertical blanking start is then 12 bits wide). See the **CRTC15** register on page 3-322. vsyncstr <6:5> Vertical retrace start bits 11 and 10. These are the two most significant bits of the **vsyncstr** (vertical retrace start) register (the vertical retrace start is then 12 bits wide). See the **CRTC10** register on page 3-317. linecomp <7> Line compare bit 10. This is the most significant bit of the **linecomp** (line compare) register (the line compare is then 11 bits wide). See the **CRTC18** register on page 3-328. CRTCEXT3 Miscellaneous scale <2:0> Video clock scaling factor. Specifies the video clock division factor in MGA mode. | Scale | Division Factor | |--------------|-----------------| | '000' | /1 | | '001' | /2 | | '010' | /3 | | '011' | /4 | | '100' | Reserved | | '101' | /6 | | '110' | Reserved | | <b>'111'</b> | /8 | slow256 <5> 256 color mode acceleration disable. - 0: Direct frame buffer accesses are accelerated in VGA mode 13. - 1: VGA Mode 13 direct frame buffer access acceleration is disabled. Unless otherwise specified, this bit should always be '0'. csyncen <6> Composite Sync Enable. Generates a composite sync signal on the VVSYNC/ pin. - 0: Horizontal sync. - 1: Composite sync (block sync). Miscellaneous CRTCEXT3 # mgamode <7> MGA mode enable. 0: Select VGA compatibility mode. In this mode, VGA data is sent to the DAC via the VGA attribute controller. The memory address counter clock will be selected by the count2 (CRTC17<3> and count4 (CRTC14<5>) bits. This mode should be used for all VGA modes up to mode 13, and for all Super VGA alpha modes. When mgamode = '0', the full frame buffer aperture mapped to MGABASE2 is unusable. 1: Select MGA mode. In this mode, the graphics engine data is sent directly to the DAC. The memory address counter is clocked, depending on the state of the hzoom field of the XZOOMCTRL register. This mode should be used for all Super VGA graphics modes and all accelerated graphics modes. ### Reserved <4:3> CRTCEXT4 Memory Page | page | | | | | | | | | |------|---|---|---|---|---|---|---|---| | ľ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | page <7:0> Page. This register provides the extra bits required to address the full frame buffer through the VGA memory aperture in Power Graphic Mode. This field *must* be programmed to zero in VGA Mode. Up to 32 megabytes of memory can be addressed (with the **page8** bit of **CRTCEXT8**<4>. The **page** register can be used instead of or in conjunction with the MGA frame buffer aperture. | GCTL6<3:2> | Bits used to address RAM | Comment | |------------|--------------------------------------------------------|---------------------| | ,00, | CRTCEXT8<4>, CRTCEXT4<7:1>,<br>CPUA<16:0> | 128K window | | '01' | <b>CRTCEXT8</b> <4>, <b>CRTCEXT4</b> <7:0>, CPUA<15:0> | 64K window | | '1X' | Undefined | Window is too small | Index crtcextx = 05h**Reset Value** 0000 0000ь | hvidmid | | | | | | | | |---------|---|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | hvidmid <7:0> Horizontal video half count. This register specifies the horizontal count at which the vertical counter should be clocked when in interlaced display in field 1. This register is only used in interlaced mode. The value to program is: Start Horizontal Retrace + End Horizontal Retrace - Horizontal Total - 1 hiprilvl <2:0> High Priority request Level. This field indicates the number of 8-qword requests in the CRTC fifo when the request to the memory controller changes from low to high priority | hiprilvl | high priority request level | |----------|-----------------------------| | '000' | 1 | | '001' | 2 | | '010' | 3 | | '011' | 4 | | '100' | 5 | | '101' | 6 | | '110' | 7 | | '111' | 8 | maxhipri <6:4> Maximum High Priority requests. This register indicates the minimum number of high priority requests to be made. | maxhipri | maximum<br>high priority request level | |----------|----------------------------------------| | '000' | 1 | | '001' | 2 | | '010' | 3 | | '011' | 4 | | '100' | 5 | | '101' | 6 | | '110' | 7 | | '111' | 8 | Reserved <3><7> | winfreq | | | winsize | | | | | |---------|---|---|---------|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | winsize <1:3> Window Size. This field controls the size of the requesting window left by the CRTC(s). | winsize | no. of mclks per window | |---------------|-------------------------| | ,000, | 0 | | '001' | 16 | | '010' | 24 | | '011' | 32 | | '100' | 40 | | '101' | 48 | | '110 <b>'</b> | 56 | | <b>'111'</b> | 64 | winfreq <5:7> Window Frequency. This field controls the frequency of the requesting window left by the CRTC(s). | winfreq | no. of mclks between<br>requests | |---------|----------------------------------| | '000' | never | | '001' | 32 | | '010' | 48 | | '011' | 64 | | '100' | 96 | | '101' | 128 | | '110' | 192 | | '111' | 256 | Reserved <0> <4> CRTCEXT8 Address Extension | Re | eserve | ed | page8 | Re | eserve | ed | startadd | |----|--------|----|-------|----|--------|----|----------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | **startadd** Start Address bit 21. This is the most significant bit of the START ADDRESS. See CRTC on page 3-299. **page8** Bit 8 of page register (see **CRTCEXT4**). Used to access up to 32 megabytes of **<4>** memory. Reserved <3:1> <7:5> DAC Status DACSTAT Address 03C7h (I/O), MGABASE1 + 1FC7h (MEM) **Attributes** RO, BYTE, STATIC Reset Value 0000 0000b | Reserved | | | | | ds | ts | | |----------|---|---|---|---|----|----|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | dsts <1:0> This port returns the last access cycle to the palette. • '00': Write palette cycle • '11': Read palette cycle Reserved This field returns zeroes when read. <7:2> Data read 03C7h will not be transmitted to the RAMDAC, and the contents of the DACSTAT register will be presented on the PCI bus. Writes to 03C7h will be transmitted to the RAMDAC. **FEAT Feature Control** **Address** 03BAh (I/O), Write (MISC<0>==0: MDA emulation) 03DAh (I/O), Write (MISC<0> == 1: CGA emulation) 03CAh (I/O) Read MGABASE1 + 1FDAh (MEM) **Attributes** R/W, BYTE, STATIC **Reset Value** 0000 0000ь featcb0 <0> Feature control bit 0. VGA. General read/write bit. featcb1 Feature control bit 1. VGA. General read/write bit. <1> Reserved Reserved. When writing to this register, the bits in this field *must* be set to '0'. <7:2> Address 03CEh (I/O), MGABASE1 + 1FCEh (MEM) Attributes R/W, BYTE/WORD, STATIC Reset Value nnnn nnnn 0000 0000b | _ | | | | gc | tld | | | | | Reserved | | | gctix | | | | |---|----|----|----|----|-----|----|---|---|---|----------|---|---|-------|---|---|---| | 1 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | gctlx <3:0> Graphics controller index register. A binary value that points to the VGA graphic controller register where data is to be written or read when the **gctld** field is accessed. | Register name | Mnemonic | gctlx address | |-------------------------|----------|---------------| | Set/Reset | GCTL0 | 00h | | Enable Set/Reset | GCTL1 | 01h | | Color Compare | GCTL2 | 02h | | Data Rotate | GCTL3 | 03h | | Read Map Select | GCTL4 | 04h | | Graphic Mode | GCTL5 | 05h | | Miscellaneous | GCTL6 | 06h | | Color Don't Care | GCTL7 | 07h | | Bit Mask | GCTL8 | 08h | | Reserved <sup>(1)</sup> | | 09h - 0Fh | <sup>(1)</sup> Writing to a reserved index has no effect; reading from a reserved index will give '0's. gctld Graphics controller data register. <15:8> Retrieve or write the contents of the register pointed to by the **gctlx** field. Reserved <7:4> GCTL0 Set/Reset | Reserved 7 6 5 4 | | | | | set | rst | | |----------------------------------------------------|---|---|---|---|-----|-----|---| | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | setrst <3:0> Set/reset. VGA. These bits allow setting or resetting byte values in the four video maps: - 1: Set the byte, assuming the corresponding set/reset enable bit is '1'. - 0: Reset the byte, assuming the corresponding set/reset enable bit is '0'. - •• *Note:* This register is *active* when the graphics controller is in write mode 0 and enable set/reset is activated. Reserved <7:4> Enable Set/Reset GCTL1 | | Rese | rved | | setrsten | | | | | |---|------|------|---|----------|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | setrsten <3:0> Enable set/reset planes 3 to 0. VGA. When a set/reset plane is enabled (the corresponding bit is '1') and the write mode is 0 (**wrmode** (**GCTL5**<1:0>) = 00), the value written to all eight bits of that plane represents the contents of the set/reset register. Otherwise, the rotated CPU data is used. •• *Note:* This register has no effect when *not* in Write Mode 0. Reserved <7:4> GCTL2 Color Compare | | Rese | erved | | refcol | | | | | |---|------|-------|---|--------|---|---|---|--| | | _ | _ | _ | _ | _ | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | refcol <3:0> Reference color. VGA. These bits represent a 4-bit color value to be compared. If the host processor sets Read Mode 1 (**rdmode** (**GCTL5**<3>) = 1), the data returned from the memory read will be a '1' in each bit position where the four planes equal the reference color value. Only the planes enabled by the **GCTL7** ('Color Don't Care'; page 3-354) register will be tested. Reserved <7:4> Data Rotate GCTL3 | R | Reserved | | | sel | rot | | | | |---|----------|---|---|-----|-----|---|---|--| | | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | rot <2:0> Data rotate count bits 2 to 0. VGA. These bits represent a binary encoded value of the number of positions to right-rotate the host data before writing in Mode 0 (**wrmode** (**GCTL5**<1:0>) = 00). The rotated data is also used as a mask together with the **GCTL8** ('Bit Mask', page 3-355) register to select which pixel is written. funsel <4:3> Function select. VGA. Specifies one of four logical operations between the video memory data latches and any data (the source depends on the write mode). | funsel | Function | |-------------|-------------------------| | '00' | Source unmodified | | '01' | Source AND latched data | | <b>'10'</b> | Source OR latched data | | <b>'11'</b> | Source XOR latched data | Reserved <7:5> | | Reserve | | | | | rdm | apsl | |---|---------|---|---|---|---|-----|------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | rdmapsl <1:0> Read map select. VGA. These bits represent a binary encoded value of the memory map number from which the host reads data when in Read Mode 0. This register has no effect on the color compare read mode (**rdmode** (**GCTL5**<3>) = 1). Reserved <7:2> Graphics Mode GCTL5 # wrmode <1:0> Write mode select. VGA. These bits select the write mode: '00': In this mode, the host data is rotated and transferred through the set/reset mechanism to the input of the Boolean unit. - '01': In this mode, the CPU latches are written directly into the frame buffer. The IBLU is not used. - '10': In this mode, host data bit n is replicated for every pixel of memory plane n, and this data is fed to the input of the BLU. - '11': Each bit of the value contained in the **setrst** field (**GCTL0**<3:0>) is replicated to 8 bits of the corresponding map expanded. Rotated system data is ANDed with the **GCTL8** ('Bit Mask', page 3-355) register to give an 8-bit value which performs the same function as **GCTL8** in Modes 0 and 2. # rdmode <3> Read mode select. VGA. - 0: The host reads data from the memory plane selected by **GCTL4**, unless **chain4** (**SEQ4**<3>) equals 1 (in this case, the read map has no effect). - 1: The host reads the result of the color comparison. ### gcoddevmd <4> Odd/Even mode select. VGA - 0: The GCTL4 (Read Map Select) register controls which plane the system reads data from. - 1: Selects the odd/even addressing mode. It causes CPU address bit A0 to replace bit 0 of the read plane select register, thus allowing A0 to determine odd or even plane selection. # srintmd <5> Shift register interleave mode. VGA. - 0: Normal serialization. - 1: The shift registers in the graphics controller format: - Serial data with odd-numbered bits from both maps in the odd-numberedmap - Serial data with the even-numbered bits from both maps in the even-numbered maps. GCTL5 **Graphics Mode** ### mode256 256-color mode. VGA. <6> - 0: The loading of the shift registers is controlled by the **srintmd** field. - 1: The shift registers are loaded in a manner which supports 256-color mode. #### Reserved <2> <7> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. These fields return '0's when read. Miscellaneous GCTL6 gcgrmode <0> Graphics mode select. VGA. • 0: Enables alpha mode, and the character generator addressing system is activated. • 1: Enables graphics mode, and the character addressing system is not used. chainodd even <1> Odd/Even chain enable. VGA. • 0: The A0 signal of the memory address bus is used during system memory addressing. • 1: Allows A0 to be replaced by either the A16 signal of the system address (if **memmapsl** is '00'), or by the **hpgoddev** (**MISC**<5>, odd/even page select) field, described on page 3-358). memmapsl <3:2> Memory map select bits 1 and 0. VGA. These bits select where the video memory is mapped, as shown below: | memmapsl | Address | |----------|-----------------| | '00' | A0000h - BFFFFh | | '01' | A0000h - AFFFFh | | '10' | B0000h - B7FFFh | | '11' | B8000h - BFFFFh | Reserved <7:4> GCTL7 Color Don't Care | | Rese | rved | | colcompen | | | | | |---|------|------|---|-----------|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | colcompen Color enable comparison for planes 3 to 0. VGA. <3:0> When any of these bits are set to '1', the associated plane is included in the color compare read cycle. Reserved <7:4> Bit Mask GCTL8 | | | | wrm | nask | | | | |---|---|---|-----|------|---|---|--| | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | | wrmask <7:0> Data write mask for pixels 7 to 0. VGA. If any bit in this register is set to '1', the corresponding bit in all planes may be altered by the selected write mode and system data. If any bit is set to '0', the corresponding bit in each plane will not change. INSTS0 Input Status 0 Address 03C2h (I/O), MGABASE1 + 1FC2h (MEM) Read Attributes RO, BYTE, STATIC Reset Value ?111 0000b **switchsns** Switch sense bit. VGA. <4> Always read as '1'. Writing has no effect. **featin10** Feature inputs 1 and 0. VGA. **<6:5>** Always read as '11'. Writing has no effect. crtcintcrt Interrupt. <7> • 0: Vertical retrace interrupt is cleared. • 1: Vertical retrace interrupt is pending. Input Status 1 INSTS1 **Address** 03BAh (I/O), Read (MISC<0> == 0: MDA emulation) 03DAh (I/O), Read (MISC<0> == 1: CGA emulation) MGABASE1 + 1FDAh (MEM) **Attributes** RO, BYTE, DYNAMIC **Reset Value** unknown | Rese | erved | di | ag | vretrace | Rese | erved | hretrace | |------|-------|----|----|----------|------|-------|----------| | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | hretrace <0> Display enable • 0: Indicates an active display interval • 1: Indicates an inactive display interval. vretrace <3> Vertical retrace. • 0: Indicates that no vertical retrace interval is occurring. • 1: Indicates a vertical retrace period. diag <5:4> Diagnostic. The **diag** bits are selectively connected to two of the eight color outputs of the attribute controller. The **vidstmx** field (**ATTR12**<5:4>) determines which color outputs are used. | vids | tmx | di | ag | | | | | |------------|------------|-----|-----|--|--|--|--| | 5 | 4 | 5 | 4 | | | | | | '0' | '0' | PD2 | PD0 | | | | | | '0' | <b>'1'</b> | PD5 | PD4 | | | | | | <b>'1'</b> | '0' | PD3 | PD1 | | | | | | <b>'1'</b> | <b>'1'</b> | PD7 | PD6 | | | | | Reserved <2:1> <7:6> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. These fields return '0's when read. Address 03C2h (I/O), MGABASE1 + 1FC2h (MEM) Write 03CCh (I/O) MGABASE1 + 1FCCh (MEM) Read **Attributes** R/W, BYTE, STATIC Reset Value 0000 0000b # ioaddsel <0> I/O address select. VGA. - 0: The CRTC I/O addresses are mapped to 3BXh and the **STATUS** register is mapped to 03BAh for MDA emulation. - 1: CRTC addresses are set to 03DXh and the **STATUS** register is set to 03DAh for CGA emulation. ## rammapen Enable RAM. VGA/MGA. <1> - Logical '0': disable mapping of the frame buffer on the host bus. - Logical '1': enable mapping of the frame buffer on the host bus. ## clksel Clock selects. VGA/MGA. <3:2> These bits select the clock source that drives the hardware. - '00': Select the 25.175 MHz clock. - '01': Select the 28.322 Mhz clock. - '1X': Reserved in VGA mode. Selects the MGA pixel clock. ### videodis <4> Video disable. VGA This bit is reserved and read as '0'. hpgoddev <5> Page bit for odd/even. VGA. This bit selects between two 64K pages of memory when in odd/even mode. - 0: Selects the low page of RAM. - 1: Selects the high page of RAM. # hsyncpol <6> Horizontal sync polarity. VGA/MGA. - Logical '0': active high horizontal sync pulse. - Logical '1': active low horizontal sync pulse. The vertical and horizontal sync polarity informs the monitor of the number of lines per frame. | VSYNC | <b>HSYNC</b> | Description | |-------|--------------|----------------------------------| | | | 768 lines per frame | | + | + | (marked as Reserved for IBM VGA) | | - | + | 400 lines per frame | | + | - | 350 lines per frame | | _ | - | 480 lines per frame | # vsyncpol <7> Vertical sync polarity. VGA/MGA. - Logical '0': active high vertical sync pulse - Logical '1': active low vertical sync pulse SEQ Sequencer Address 03C4h (I/O), MGABASE1 + 1FC4h (MEM) Attributes R/W, BYTE/WORD, STATIC Reset Value nnnn nnnn 0000 0000b | | | | | se | eqd | | | | Reserved seqx | | | | | | | | | | |--|----|---------------------------------|--|----|-----|---|---|---|---------------|---|---|---|---|--|--|--|--|--| | | | | | | | | | | | | | | | | | | | | | | 15 | 15 14 12 12 11 10 0 | | | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | seqx <2:0> Sequencer index register. A binary value that points to the VGA sequencer register where data is to be written or read when the **seqd** field is accessed. | Register name | Mnemonic | seqx address | |-----------------------------|----------|--------------| | Reset | SEQ0 | 00h | | Clocking Mode | SEQ1 | 01h | | Map Mask | SEQ2 | 02h | | Character Map Select | SEQ3 | 03h | | Memory Mode | SEQ4 | 04h | | Reserved ( <sup>(1)</sup> ) | | 05h - 07h | <sup>(1)</sup> When writing to a reserved register, all fields *must* be set to '0'. Reading from a reserved index will give '0's. seqd <15:8> Sequencer data register. Retrieve or write the contents of the register that is pointed to by the **seqx** field. Reserved <7:3> Reset SEQ0 asyncrst <0> Asynchronous reset. VGA. • 0: For the IBM VGA, this bit was used to clear and stop the sequencer asynchronously. For MGA, this bit can be read or written (for compatibility) but it does not stop the memory controller. • 1: For the IBM VGA, this bit is used to remove the asynchronous reset. syncrst <1> Synchronous reset. VGA. - 0: For the IBM VGA, this bit was used to clear and stop the sequencer at the end of a memory cycle. For MGA, this bit can be read or written (for compatibility), but it does not stop the memory controller. The Matrox G400 does not require that this bit be set to '0' when changing any VGA register bits. - 1: For the IBM VGA, used to remove the synchronous reset. Reserved <7:2> SEQ1 Clocking Mode | ġ | | scroff | shiftfour | dotclkrt | shftldrt | Reserved | dotmode | |---|---|--------|-----------|----------|----------|----------|---------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | # dotmode <0> 9/8 dot mode. VGA. - 0: The sequencer generates a 9-dot character clock. - 1: The sequencer generates an 8-dot character clock. ### shftldrt <2> Shift/load rate. VGA. • 0: The graphics controller shift registers are reloaded every character clock. • 1: The graphics controller shift registers are reloaded every other character clock. This is used for word fetches. # dotclkrt Dot clock rate. VGA. <3> - 0: The dot clock rate is the same as the clock at the VCLK pin. - 1: The dot clock rate is slowed to one-half the clock at the VCLK pin. The character clock and shift/load signals are also slowed to half their normal speed. # shiftfour <4> Shift four. VGA. - 0: The graphics controller shift registers are reloaded every character clock. - 1: The graphics controller shift registers are reloaded every fourth character clock. This is used for 32-bit fetches. # scroff Screen off. VGA/MGA. <5> - 0: Normal video operation. - 1: Turns off the video, and maximum memory bandwidth is assigned to the system. The display is blanked, however, all sync pulses are generated normally. ### Reserved ### <1> <7:6> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. These fields return '0's when read. Map Mask SEQ2 | | Rese | rved | | | plw | ren | | |---|------|------|---|---|-----|-----|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | plwren <3:0> Map 3, 2, 1 and 0 write enable. VGA. A '1' in any bit location will enable CPU writes to the corresponding video memory map. Simultaneous writes occur when more than one bit is '1'. Reserved <7:4> | 3 | Ď<br>><br>D | mapasel | mapbsel | | lla pasel | 2 | liappose | |---|-------------|---------|---------|---|-----------|---|----------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | This register is reset by the reset pin (PRST/), or by the **asyncrst** field of the **SEQ0** register. # mapbsel <4, 1:0> Map B select bits 2, 1, and 0. VGA. These bits are used for alpha character generation when the character's attribute bit 3 is '0', according to the following table: | mapbsel | Мар# | Map location | |---------|------|--------------------------| | ,000, | 0 | 1st 8 kilobytes of Map 2 | | '001' | 1 | 3rd 8 kilobytes of Map 2 | | '010' | 2 | 5th 8 kilobytes of Map 2 | | '011' | 3 | 7th 8 kilobytes of Map 2 | | '100' | 4 | 2nd 8 kilobytes of Map 2 | | '101' | 5 | 4th 8 kilobytes of Map 2 | | '110' | 6 | 6th 8 kilobytes of Map 2 | | '111' | 7 | 8th 8 kilobytes of Map 2 | # mapasel <5, 3:2> Map A select bits 2, 1, and 0. VGA. These bits are used for alpha character generation when the character's attribute bit 3 is '1', according to the following table: | mapasel | Мар# | Map location | |---------|------|--------------------------| | ,000, | 0 | 1st 8 kilobytes of Map 2 | | '001' | 1 | 3rd 8 kilobytes of Map 2 | | '010' | 2 | 5th 8 kilobytes of Map 2 | | '011' | 3 | 7th 8 kilobytes of Map 2 | | '100' | 4 | 2nd 8 kilobytes of Map 2 | | '101' | 5 | 4th 8 kilobytes of Map 2 | | '110' | 6 | 6th 8 kilobytes of Map 2 | | '111' | 7 | 8th 8 kilobytes of Map 2 | Reserved <7:6> Memory Mode SEQ4 Reserved chain4 4 3 2 1 0 memsz256 <1> 256K memory size. • Set to '0' when 256K of memory is not installed. Address bits 14 and 15 are forced to '0'. • Set to '1' when 256K of memory is installed. This bit should always be '1'. seqoddevmd Odd/Even mode. VGA. <2> • 0: The CPU writes to Maps 0 and 2 at even addresses, and to Maps 1 and 3 at odd addresses. • 1: The CPU writes to any map. → *Note:* In all cases, a map is written *unless* it has been disabled by the map mask register. chain4 <3> Chain four. VGA. • 0: The CPU accesses data sequentially within a memory map. • 1: The two low-order bits A0 and A1 select the memory plane to be accessed by the system as shown below: | A<1:0> | Map selected | |-------------|--------------| | '00' | 0 | | '01' | 1 | | '10' | 2 | | <b>'11'</b> | 3 | Reserved <0> <7:4> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. These fields return '0's when read ## 3.3 DAC Registers ## 3.3.1 DAC Register Descriptions The Matrox G400 DAC register descriptions contain a (gray single-underlined) main header which indicates the register's name and mnemonic. Below the main header, the memory address or index, attributes, and reset value are indicated. Next, an illustration of the register identifies the bit fields, which are then described in detail below the illustration. The reserved bit fields are underscored by black bars, and all other fields are delimited by alternating white and gray bars. #### **Address** This address is an offset from the Power Graphic mode base memory address. #### Index The index is an offset from the starting address of the indirect access register (**X\_DATAREG**). #### **Attributes** The DAC register attributes are: RO: There are no writable bits. WO: There are no readable bits. R/W: The state of the written bits can be read. BYTE: 8-bit access to the register is possible. WORD: 16-bit access to the register is possible. DWORD: 32-bit access to the register is possible. ### **Reset Value** Here are some of the symbols that appear as part of a register's reset value. ■ 000? 0?00b (b = binary, ? = unknown, N/A = not applicable) **Address CURPOSXL MGABASE1** + 3C0Ch (MEM) > **CURPOSXH MGABASE1** + 3C0Dh (MEM) CURPOSYL MGABASE1 + 3C0Eh (MEM) **CURPOSYH MGABASE1** + 3C0Fh (MEM) **Attributes** R/W, BYTE, WORD, DWORD **Reset Value** unknown | R | ese | erv | ed | | curposy | | | | | | Reserved | | | | | | curposx | | | | | | | | | | | | | | | |----|-----|-----|----|----|---------|----|----|----|----|----|----------|----|----|----|----|----|---------|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ### curposx <11:0> X Cursor position. Determines the position of the last column of the hardware cursor on the display screen. In order to avoid either noise or a split cursor within a frame, the software must ensure that a cursor update never occurs during a retrace period (when the vsyncsts status is 1 - see the **STATUS** register). Cursor update can take place at any other time. Cursor repositioning will only take effect on the next activation of the vertical retrace. Cursor position (1,1) corresponds to the top left corner of the screen (it is the first displayed pixel following a vertical retrace). Specifically, the programmed cursor x position is the number of pixels from the end of the blank signal at which the bottom right hand corner of the cursor is located. Therefore, loading 001h into **curposx** causes the rightmost pixel of the cursor to be displayed on the leftmost pixel of the screen. Likewise, the programmed cursor y position is the number of scan lines from the end of vertical blanking at which the bottom right hand corner of the cursor is located. Therefore, loading 001h into **curposy** causes the bottommost pixel of the cursor to be displayed on the top scanline of the screen. If 000h is written to either of the cursor position registers, the cursor will be located off-screen. The hardware cursor is operational in both non-interlace and interlaced display modes (see the **interlace** bit of the **CRTCEXTO** VGA register). curposy <27:16> Y Cursor position. Determines the position of the last row of the hardware cursor on the display screen. Reserved <15:12> <31:28> Palette RAM Data PALDATA **Address** 03C9h (I/O), **MGABASE1** + 3C01h (MEM) Attributes R/W, BYTE Reset Value unknown ### paldata | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| paldata <7:0> Palette RAM data. This register is used to load data into and read data from the palette RAM. Since the palette RAM is 24 bits wide, three writes are required to this register in order to write one complete location in the RAM. The address in the palette RAM to be written is determined by the value of the **PALWTADD** register. Likewise, three reads are required to obtain all three bytes of data in one entry. The address in the palette RAM to be read is determined by the value of the **PALRDADD** register. The **vga8dac** bit (see the **XMISCCTRL** register) controls how the data is written into the palette. - In 6-bit mode, the host data is shifted left by two to compensate for the lack of a sufficient bit width (zeros are shifted in). When reading data from the palette RAM in 6-bit mode, the data will be shifted right and the two most significant bits filled with 0's to be compatible with VGA. - In 8-bit mode, no shifting or zero padding occurs; the full 8 bit host data is transferred. The palette RAM is dual-ported, so reading or writing will not cause any noticeable disturbance of the display. Address 03C7h (I/O, W), MGABASE1 + 3C03h (MEM, R/W) Attributes BYTE Reset Value unknown ## palrdadd | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| # palrdadd <7:0> Palette address register for LUT read. This register is used to address the palette RAM during a read operation. It is increased for every three bytes read from the **PALDATA** port (the palette RAM is 24 bits wide). When the address increments beyond the last palette location, it will wrap around to location 0. Writing this register resets the modulo 3 counter to 0. **◆** *Note:* This location stores the same physical register as location **PALWTADD**. Address 03C8h (I/O), MGABASE1 + 3C00h (MEM) Attributes R/W, BYTE Reset Value unknown | | palwtadd | | | | | | | | | | |---|----------|---|---|---|---|---|---|--|--|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | # palwtadd <7:0> Palette address register for LUT write. This register has two functions: - It is used to address the palette RAM during a write operation. This register is incremented for every 3 bytes written to the **PALDATA** port (the palette RAM is 24 bits wide). When the address increments beyond the last palette location, it will wrap around to location 0. Writing this register resets the modulo 3 counter to 0. - When used as the index register, this register is loaded with the index of the indirect register which is to be accessed through the X\_DATAREG port. - •• *Note:* This location stores the same physical register as the PALRDADD location. PIXRDMSK Pixel Read Mask Address 03C6h (I/O), MGABASE1 + 3C02h (MEM) Attributes R/W, BYTE Reset Value 1111 1111h ## pixrdmsk | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| ## pixrdmsk <7:0> Pixel read mask. The pixel read mask register is used to enable or disable a bit plane from addressing the palette RAM. This mask is used in all modes which access the palette RAM (not just the 8 bit/pixel modes). Each palette address bit is logically ANDed with the corresponding bit from the read mask register before going to the palette RAM. •• *Note:* Direct pixels (pixels that do not go through the palette RAM) are not masked in any mode. Indexed Data X\_DATAREG Address MGABASE1 + 3C0Ah (MEM) Attributes R/W, BYTE Reset Value unknown ### indd | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| indd <7:0> Indexed data register. This is the register that is used to read from or write to any of the valid indexed (indirect) registers. See the following register descriptions. The address which is accessed is determined by the Index Register (PALWTADD). Locations marked as 'Reserved' return unknown information; writing to any such reserved location may affect other indexed registers. | indd Address | Register Addressed | Mnemonic | |--------------|-----------------------------|---------------| | 00h-03h | Reserved | _ | | 04h | Cursor Base Address Low | XCURADDL | | 05h | Cursor Base Address High | XCURADDH | | 06h | Cursor Control | XCURCTRL | | 07h | Reserved | _ | | 08h | Cursor Color 0 RED | XCURCOL0RED | | 09h | Cursor Color 0 GREEN | XCURCOL0GREEN | | 0Ah | Cursor Color 0 BLUE | XCURCOL0BLUE | | 0Bh | Reserved | _ | | 0Ch | Cursor Color 1 RED | XCURCOL1RED | | 0Dh | Cursor Color 1 GREEN | XCURCOL1GREEN | | 0Eh | Cursor Color 1 BLUE | XCURCOL1BLUE | | 0Fh | Reserved | _ | | 10h | Cursor Color 2 RED | XCURCOL2RED | | 11h | Cursor Color 2 GREEN | XCURCOL2GREEN | | 12h | Cursor Color 2 BLUE | XCURCOL2BLUE | | 13h-17h | Reserved | _ | | 18h | Voltage Reference Control | XVREFCTRL | | 19h | Multiplex Control | XMULCTRL | | 1Ah | Pixel Clock Control | XPIXCLKCTRL | | 1Bh-1Ch | Reserved | _ | | 1Dh | General Control | XGENCTRL | | 1Eh | Miscellaneous Control | XMISCCTRL | | 1Fh-29h | Reserved | _ | | 2Ah | General Purpose I/O Control | XGENIOCTRL | | 2Bh | General Purpose I/O Data | XGENIODATA | | 2Ch | SYSPLL M Value | XSYSPLLM | | 2Dh | SYSPLL N Value | XSYSPLLN | | 2Eh | SYSPLL P Value | XSYSPLLP | | 2Fh | SYSPLL Status | SYSPLL Status | | indd Address | Register Addressed | Mnemonic | |--------------|-----------------------|---------------| | 30h-37h | Reserved | _ | | 38h | Zoom Control | XZOOMCTRL | | 39h | Reserved | _ | | 3Ah | Sense Test | XSENSETEST | | 3Bh | Reserved | _ | | 3Ch | CRC Remainder Low | XCRCREML | | 3Dh | CRC Remainder High | XCRCREMH | | 3Eh | CRC Bit Select | XCRCBITSEL | | 3Fh | Reserved | _ | | 40h | Color Key Mask | XCOLMSK | | 41h | Reserved | _ | | 42h | Color Key | XCOLKEY | | 43h | Reserved | _ | | 44h | PIXPLL M Value Set A | XPIXPLLAM | | 45h | PIXPLL N Value Set A | XPIXPLLAN | | 46h | PIXPLL P Value Set A | XPIXPLLAP | | 47h | Reserved | _ | | 48h | PIXPLL M Value Set B | XPIXPLLBM | | 49h | PIXPLL N Value Set B | XPIXPLLBN | | 4Ah | PIXPLL P Value Set B | XPIXPLLBP | | 4Bh | Reserved | _ | | 4Ch | PIXPLL M Value Set C | XPIXPLLCM | | 4Dh | PIXPLL N Value Set C | XPIXPLLCN | | 4Eh | PIXPLL P Value Set C | XPIXPLLCP | | 4Fh | PIXPLL Status | XPIXPLLSTAT | | 50h | Reserved | _ | | 51h | KEYING Operating Mode | XKEYOPMODE | | 52h | Color Mask 0 Red | XCOLMSK0RED | | 53h | Color Mask 0 Green | XCOLMSK0GREEN | | 54h | Color Mask 0 Blue | XCOLMSK0BLUE | | 55h | Color Key 0 Red | XCOLKEY0RED | | 56h | Color Key 0 Green | XCOLKEY0GREEN | | 57h | Color Key 0 Blue | XCOLKEY0BLUE | | 58h-5Fh | Reserved | _ | | 60h | Cursor Color 3 Red | XCURCOL3RED | | 61h | Cursor Color 3 Green | XCURCOL3GREEN | | 62h | Cursor Color 3 Blue | XCURCOL3BLUE | | 63h | Cursor Color 4 Red | XCURCOL4RED | | 64h | Cursor Color 4 Green | XCURCOL4GREEN | | 65h | Cursor Color 4 Blue | XCURCOL4BLUE | | 66h | Cursor Color 5 Red | XCURCOL5RED | | 67h | Cursor Color 5 Green | XCURCOL5GREEN | Indexed Data X\_DATAREG | indd Address | Register Addressed | Mnemonic | |--------------|-----------------------|----------------| | 68h | Cursor Color 5 Blue | XCURCOL5BLUE | | 69h | Cursor Color 6 Red | XCURCOL6RED | | 6Ah | Cursor Color 6 Green | XCURCOL6GREEN | | 6Bh | Cursor Color 6 Blue | XCURCOL6BLUE | | 6Ch | Cursor Color 7 Red | XCURCOL7RED | | 6Dh | Cursor Color 7 Green | XCURCOL7GREEN | | 6Eh | Cursor Color 7 Blue | XCURCOL7BLUE | | 6Fh | Cursor Color 8 Red | XCURCOL8RED | | 70h | Cursor Color 8 Green | XCURCOL8GREEN | | 71h | Cursor Color 8 Blue | XCURCOL8BLUE | | 72h | Cursor Color 9 Red | XCURCOL9RED | | 73h | Cursor Color 9 Green | XCURCOL9GREEN | | 74h | Cursor Color 9 Blue | XCURCOL9BLUE | | 75h | Cursor Color 10 Red | XCURCOL10RED | | 76h | Cursor Color 10 Green | XCURCOL10GREEN | | 77h | Cursor Color 10 Blue | XCURCOL10BLUE | | 78h | Cursor Color 11 Red | XCURCOL11RED | | 79h | Cursor Color 11 Green | XCURCOL11GREEN | | 7Ah | Cursor Color 11 Blue | XCURCOL11BLUE | | 7Bh | Cursor Color 12 Red | XCURCOL12RED | | 7Ch | Cursor Color 12 Green | XCURCOL12GREEN | | 7Dh | Cursor Color 12 Blue | XCURCOL12BLUE | | 7Eh | Cursor Color 13 Red | XCURCOL13RED | | 7Fh | Cursor Color 13 Green | XCURCOL13GREEN | | 80h | Cursor Color 13 Blue | XCURCOL13BLUE | | 81h | Cursor Color 14 Red | XCURCOL14RED | | 82h | Cursor Color 14 Green | XCURCOL14GREEN | | 83h | Cursor Color 14 Blue | XCURCOL14BLUE | | 84h | Cursor Color 15 Red | XCURCOL15RED | | 85h | Cursor Color 15 Green | XCURCOL15GREEN | | 86h | Cursor Color 15 Blue | XCURCOL15BLUE | XCOLKEY Color Key Index 42h Attributes R/W, BYTE Reset Value unknown | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| # colkey <7:0> Color key bits for alpha overlay. The color key is *only* used to perform color keying between graphics and the alpha overlay buffer in 32 bits/pixel single frame buffer mode (**depth** = '100'). The equation is: ◆ *Note:* The **depth** field is located in the **XMULCTRL** register. ### where: ALPHA is the address of the overlay register (in that mode, the palette is used as 256 overlay registers) and LUT(ALPHA) is the overlay color. The overlay can be disabled by programming COLMSK = 0 and COLKEY = 0. Color Key 0 XCOLKEY0 Index 55h XCOLKEY0RED 56h XCOLKEYOGREEN57h XCOLKEYOBLUE Attributes R/W, BYTE Reset Value unknown colkey0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| colkey0 <7:0> Color Key bits 7 to 0 for window 0. The color key is used to perform color keying between graphics and the video buffer. XCOLMSK Color Key Mask Index 40h Attributes R/W, BYTE Reset Value unknown ## colmsk | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| ### colmsk <7:0> Color key mask bits 7 to 0. To prevent a particular bit plane from participating in a keying comparison, the corresponding color key mask bit should be set to 0b. The mask is *only* used in 32 bits/pixel single frame buffer modes (**depth** = '100') for overlay enable/disable. See "XCOLKEY" on page 376 for more information. Color Mask 0 XCOLMSK0 Index 52h XCOLMSK0RED 53h XCOLMSKOGREEN54h XCOLMSKOBLUE Attributes R/W, BYTE Reset Value unknown ### colmsk0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| colmsk0 <7:0> Color Key mask bits 7 to 0 for window 0. To prevent a particular bit plane from participating in a keying comparison, the corresponding color key mask bit should be set to '0'. XCRCBITSEL CRC Bit Select Index 3Eh Attributes R/W, BYTE Reset Value unknown | Re | Reserved | | | ( | crcse | l | | |----|----------|---|---|---|-------|---|---| | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | crcsel <4:0> CRC bit selection. This register determines which of the 24 DAC data lines the 16-bit CRC should be calculated on. Valid values are 0h-17h: | Value | DAC Data Lines to Use | |---------|-----------------------| | 00h-07h | blue0 - blue7 | | 08h-0Fh | green0 - green7 | | 10h-17h | red0 - red7 | Reserved <7:5> Index 3Dh Attributes RO, BYTE Reset Value unknown | | | | crc | data | | | | |---|---|---|-----|------|---|---|---| | 7 | 6 | 5 | 1 | 3 | 2 | 1 | 0 | | ' | 0 | ז | + | ז | | | U | # crcdata <7:0> High-order CRC remainder. This register is used to read the results of the 16-bit CRC calculation. **XCRCREMH** corresponds to bits 15:8 of the 16-bit CRC. A 16-bit cyclic redundancy check (CRC) is provided so that the video data's integrity can be verified at the input of the DAC's. The **XCRCBITSEL** register indicates which video line is checked. The **XCRCREMH** and **XCRCREML** registers accept video data when the screen is not in the blank period. The CRC Remainder register is reset to 0 at the end of vertical sync period and must be read at the beginning of the next vertical sync period (when VSYNC status goes to 1). ### The CRC is calculated as follows: Index 3Ch Attributes RO, BYTE Reset Value unknown | _ | | _ | _ | _ | | |---|---|---|---|---|----| | C | r | c | n | а | тa | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| crcdata <7:0> Low-order CRC remainder. This register is used to read the results of the 16-bit CRC calculation. **XCRCREML** corresponds to bits 7:0 of the 16-bit CRC. See XCRCREMH. Index 05h Attributes R/W, BYTE Reset Value unknown | Rese | erved | | | cura | adrh | | | |------|-------|---|---|------|------|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | curadrh <5:0> Cursor address high. These are the high-order bits of the cursor map The 14-bit value from the high and low order cursor address locations is the base address (bits 23:10) of the frame buffer where the cursor maps are located. The cursor maps must be aligned on a 1 KByte boundary. When **XCURADDH** or **XCURADDH** are written, the values take effect immediately. This may result in temporarily invalid cursor pixel values, if the cursor map is being fetched simultaneously. Two cursor maps are possible depending on the cursor mode selected (see the **curmode** field in XCURCTRL). These are based on either a two-slice mode or a six-slice mode. In two-slice mode, each pixel of the cursor is defined by two bits (bit plane 1 and bit plane 0). The cursor data is stored in 64-bit slices in memory (each slice contains all the data for one plane of one cursor scanline). One scanline-plane is stored in memory as follows:: In six-slice mode, each pixel color is defined by 4 bits, with two additional bits: one for transparency and another for complement. The 4-bit color is linearly written into the 4 slices and is binary encoded to select one of 16 cursor colors (see XCURCOL). The memory map of this mode for one scanline is stored in memory as follows: | Address | Data | |------------|------------------------------------| | Base + 0 | Slice 0 cursor pixels 0 to 15 | | Base + 1 | Slice 1 cursor pixels 16 to 31 | | Base $+2$ | Slice 2 cursor pixels 34 to 48 | | Base $+3$ | Slice 3 cursor pixels 49 to 63 | | Base $+4$ | Complement pixels 0 to 63 | | Base $+ 5$ | Slice 4 transparent pixels 0 to 63 | Reserved <7:6> 04h Index R/W, BYTE **Attributes** Reset Value unknown | curadrl | |---------| |---------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| curadrl <7:0> Cursor address low. These are the low-order bits of the cursor map address. See the **XCURADDH** register description for more details. Cursor Color XCURCOL | 08h | XCURCOL0RED | 6Fh | XCURCOL8RED | |-----|---------------|-----|----------------| | 09h | XCURCOL0GREEN | 70h | XCURCOL8GREEN | | 0Ah | XCURCOL0BLUE | 71h | XCURCOL8BLUE | | 0Ch | XCURCOL1RED | 72h | XCURCOL9RED | | 0Dh | XCURCOL1GREEN | 73h | XCURCOL9GREEN | | 0Eh | XCURCOL1BLUE | 74h | XCURCOL9BLUE | | 10h | XCURCOL2RED | 75h | XCURCOL10RED | | 11h | XCURCOL2GREEN | 76h | XCURCOL10GREEN | | 12h | XCURCOL2BLUE | 77h | XCURCOL10BLUE | | 60h | XCURCOL3RED | 78h | XCURCOL11RED | | 61h | XCURCOL3GREEN | 79h | XCURCOL11GREEN | | 62h | XCURCOL3BLUE | 7Ah | XCURCOL11BLUE | | 63h | XCURCOL4RED | 7Bh | XCURCOL12RED | | 64h | XCURCOL4GREEN | 7Ch | XCURCOL12GREEN | | 65h | XCURCOL4BLUE | 7Dh | XCURCOL12BLUE | | 66h | XCURCOL5RED | 7Eh | XCURCOL13RED | | 67h | XCURCOL5GREEN | 7Fh | XCURCOL13GREEN | | 68h | XCURCOL5BLUE | 80h | XCURCOL13BLUE | XCURCOL6RED **XCURCOL6GREEN** **XCURCOL7GREEN** **XCURCOL7BLUE** **XCURCOL6BLUE** XCURCOL7RED Attributes R/W, BYTE Reset Value unknown 69h 6Ah 6Bh 6Ch 6Dh 6Eh | | | | cur | COI | | | | |---|---|---|-----|-----|---|---|---| | 7 | _ | _ | 4 | 2 | 2 | 4 | | | / | ь | 5 | 4 | 3 | 2 | 1 | U | curcol <7:0> Index Cursor color register. The desired color register (0-15) is chosen according to both the cursor mode and cursor map information. (See the **XCURCTRL** register for more information.) Each color register is 24 bits wide and contains an 8-bit red, 8-bit green, and 8-bit blue field. 81h 82h 83h 84h 85h 86h XCURCOL14RED **XCURCOL14GREEN** **XCURCOL15GREEN** XCURCOL15BLUE XCURCOL14BLUE XCURCOL15RED XCURCTRL **Cursor Control** Index 06h **Attributes** R/W, BYTE Reset Value 0000 0000ь | Reserved | | | | | Cl | ırmod | de | |----------|---|---|---|---|----|-------|----| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ### curmode <2:0> Cursor mode select. This field is used to disable or select the cursor mode, as indicated below: • '000': cursor disabled (default) • '001': three-color cursor • '010': XGA cursor • '011': X-Windows cursor • '100': 16-color palettized cursor • '101': Reserved • '110': Reserved • '111': Reserved In cursor modes other than 16 color palettized (**curmode** = '100'), there are four possible ways to display each pixel of the cursor. The following table shows how the encoded pixel data is decoded, based on the cursor mode (set by **curmode**): | RAM | | Cursor Mode | | | | | |---------|---------|----------------------------|---------------------------|----------------|--|--| | Plane 1 | Plane 0 | Three-Color | XGA | X-Windows | | | | '0' | '0' | Transparent <sup>(1)</sup> | Cursor Color 0 | Transparent | | | | '0' | '1' | Cursor Color 0 | Cursor Color 1 | Transparent | | | | '1' | '0' | Cursor Color 1 | Transparent | Cursor Color 0 | | | | '1' | '1' | Cursor Color 2 | Complement <sup>(2)</sup> | Cursor Color 1 | | | <sup>(1)</sup> The underlying pixel is displayed (that is, the cursor has no effect on the display). In 16 color palettized cursor mode, the cursor bit map is placed in memory as described in **XCURADDH.** The following table demonstrates how the bit map data is encoded: | Diamlan | Slice | | | | | | | |-------------|-------|---|-------|-------|-------|-------|--| | Display | 5 | 4 | 3 | 2 | 1 | 0 | | | Pixel color | 0 | 0 | $C_3$ | $C_2$ | $C_1$ | $C_0$ | | | Complement | 0 | 1 | X | X | X | X | | | Transparent | 1 | 0 | X | X | X | X | | | Transparent | 1 | 1 | X | X | X | X | | <sup>(2)</sup> Each bit of the underlying pixel is inverted, then displayed. Reserved <7:2> XGENCTRL General Control Index 1Dh Attributes R/W, BYTE Reset Value 0000 0000b # alphaen <1> Video alpha bit enable. This bit is used by the keying function to enable or disable the alpha bits in the equation for split frame buffer modes (mode G16V16 or 2G8V16). It is also used in 15-bit single frame buffer mode to enable or disable the 1-bit overlay. - 0: disabled (forces the effective value of all alpha bits to 0b) or overlay disable - 1: enabled (alpha bits are used for color keying) or overlay enable # pedon <4> Pedestal control. This field specifies whether a 0 or 7.5 IRE blanking pedestal is to be generated on the video outputs. - 0: 0 IRE (default) - 1: 7.5 IRE # iogsyncdis <5> Green channel sync disable. This field specifies if sync (from the internal signal HSYNC) information is to be sent to the output of the green DAC. - 0: enable (default) - 1: disable (sync information is sent to the output of the green DAC) - Note: The HSYNC can be programmed to be either horizontal sync only, or composite (block) sync. See the csyncen bit of the CRTCEXT3 VGA register. #### Reserved ## <0> <3:2> <7:6> Index 2Ah Attributes R/W, BYTE Reset Value 0000 0000b ddcoe <3:0> DDC pin output control. Controls the output enable of the driver on pins DDC<3:0>, respectively. - 0: disable the output driver - 1: enable the output driver miscoe <6:4> MISC pin output control. Controls the output enable of the driver on pins MISC<2:0>, respectively. - 0: disable the output driver - 1: enable the output driver Reserved <7:6> Index 2Bh Attributes R/W, BYTE Reset Value 0000 0000b ddcdata <3:0> DDC pin output state. Controls the output state of the driver on pins DDC<3:0>, respectively. On read, this field returns the state of the DDC<3:0> pins. miscdata <6:4> MISC pin output state. Controls the output state of the driver on pins MISC<2:0> during a write operation. On read, this field returns the state of the MISC<2:0> pins. Reserved <7:6> Index 51h Attributes R/W, BYTE Reset Value 0000 0001b colkeyen0 This field selects the type of display for video window '0'. <0> • 0: overlay • 1: color key Reserved <7:1> XMAFCDEL MAFC Delay Index 20h Attributes R/W, BYTE Reset Value 0000 1000b | Reserved | | | | mafcclkdel | | | | | |----------|---|---|---|------------|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | mafcclkdel <3:0> This field delays/accelerates the relationship between the clock and the data. Programming values closer to '0000' will *increase* the clock output; programming values closer to '1111' will *decrease* the clock output. All timings for the MAFC port are specified with a programming of '1000'. Reserved <7:4> Index 1Eh Attributes R/W, BYTE Reset Value 0000 0110b | vdoutsel | | ramcs | vga8dac | mfo | sel | dacpdN | | |----------|---|-------|---------|-----|-----|--------|---| | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ## dacpdN <0> DAC power down. This field is used to remove power from the DACs, to conserve power. - 0: DAC disabled (default) - 1: DAC enabled ## mfcsel <2:1> Matrox advanced feature connector (MAFC) Function Select. - '00': Reserved - '01': Matrox Advanced Feature Connector. In MAFC mode, the data just before the DAC is output to the 12-bit feature connector using both edges of the clock. - '10': Panel Link Mode. In Panel Link Mode, the data just before the DAC, is output to the 12-bit feature connector using both edges of the clock. - '11': Disable Feature Connector. When the feature connector is disabled, the VOBLANK/, VDOCLK, and VDOUT<11:0> pins are driven low. #### vga8dac <3> VGA 8-bit DAC. This field is used for compatibility with standard VGA, which uses a 6-bit DAC. - 0: 6 bit palette (default) - 1: 8 bit palette ## ramcs <4> LUT RAM chip select. Used to power up the LUT. - 0: LUT disabled - 1: LUT enabled #### vdoutsel <7:5> Video Out Select. This field selects the source an the data transfer protocol of the Matrox G400's MAFC port. - '000': In MAFC12 mode, the outputs are taken just before DAC and are output 12 bits at a time on both edges of the clock. This effectively transfers one 24 bit pixel (8 bits per channel) per clock. This works in *all* MGA display modes. - '001': Reserved - '010': In BYPASS656 mode, the output is taken directly from the Video-In bus and passed directly through to the Video-Out bus at 1 byte per clock cycle. - '011': Reserved - '100': In SECOND CRTC RGB24 mode, the RGB data is first expanded to 24 bits RGB (if needed) and then output through the MAFC port 12 bits at a time on both VDOCLK edges. In this mode, the alpha data is *always* discarded. - '101': Reserved - '110': In SECOND CRTC ITU-R-656 mode, the YUV422 data is sent along with the ITU-R-656 timing codes through the MAFC port 8 bits at a time on each VDOCLK rising edge, requiring 2 VDOCLK cycles per pixel. The alpha data can be sent along with the YUV422 data over the 4 MSBs of the MAFC port. When those 4 MSB bits are not used, they are set to the zero level. • '111': Reserved Index 19h Attributes R/W, BYTE Reset Value 0000 0000b | Reserved | | | | | depth | | | | |----------|---|---|---|---|-------|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | depth <2:0> Color depth. The following table shows the available color depths and their properties: | Value | Color Depth Use | ed | |--------------|-----------------|-------------------------------------------| | '000' | 8 bits/pixel | (palettized) (default) | | '001' | 15 bits/pixel | (palettized) + 1-bit overlay | | '010' | 16 bits/pixel | (palettized) | | '011' | 24 bits/pixel | (packed, palettized) | | '100' | 32 bits/pixel | (24 bpp direct, 8 bpp overlay palettized) | | '101' | Reserved | | | <b>'110'</b> | Reserved | | | <b>'111'</b> | 32 bits/pixel | (24 bpp palettized, 8 bpp unused) | When at '0', the **mgamode** field of the **CRTCEXT3** VGA register sets the DAC to VGA mode. The **depth** field should be programmed to '000' when in VGA mode. Reserved <7:3> Reserved. When writing to this register, the bits in this field *must* be set to '0'. •• *Note:* The **depth** and **mgamode** fields also control the VCLK division factor. XPANELMODE Panel Mode Index 1Fh Attributes R/W, BYTE Reset Value 0000 0000b | panvspol | panhspol | panvsoff | panhsoff | p | anelc | tl | panelsel | |----------|----------|----------|----------|---|-------|----|----------| | | | | | | 1 | 1 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | panelsel <0> <3:1> • 0: Eclipse PanelLink • 1: Slave PanelLink mode (will control if VIDRST/VDOCLK is in output mode/input mode. This will be used in conjunction with VDOUTSEL and MFCSEL) **panelctl** Control bits for PanelLink interface. They hard-reset to '0' and must be programmed to '0', otherwise, they will always be muxed-out even in MAFC12 mode. • 0: Hsync runs freely • 1: Hsync is forced inactive panvsoff PanelLink vertical sync. off <5> • 0: Vsync runs freely • 1: Vsync is forced inactive panhspol PanelLink horizontal sync. polarity.<6> 0: Active high horizontal sync. pulse1: Active low horizontal sync. pulse 0: Active high vertical sync. pulse1: Active low vertical sync. pulse Pixel Clock Control XPIXCLKCTRL Index 1Ah Attributes R/W, BYTE Reset Value 0000 0000b | | Rese | erved | | pixpllpdN | pixcIkdis | pixo | lksl | |---|------|-------|---|-----------|-----------|------|------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | pixclksl <1:0> Pixel clock selection. These bits select the source of the pixel clock: • '00': selects the output of the PCI clock • '01': selects the output of the pixel clock PLL • '10': selects external source (from the **VDOCLK** pin) • '11': selects the SYSPLL as a clock source pixclkdis <2> Pixel clock disable. This bit controls the pixel clock output: • 0: enable pixel clock oscillations. • 1: stop pixel clock oscillations. pixpllpdN<3> Pixel PLL power down. • 0: power down • 1: power up Reserved <7:4> Reserved. When writing to this register, the bits in this field *must* be set to '0'. ◆ *Note:* See 'Clock Source Selection / PLL Reprogramming' on page 4-93 for information on modifying the clock parameters. XPIXPLLM PIXPLL M Value | Index | 44h | XPIXPLLAM | |-------------|----------|-----------| | | 48h | XPIXPLLBM | | | 4Ch | XPIXPLLCM | | Attributes | R/W, BYT | E | | Reset Value | 15h | XPIXPLLAM | | | 1Eh | XPIXPLLBM | | | unknown | XPIXPLLCM | | Reserved | | | pixpllm | | | | | |----------|---|---|---------|---|---|---|---| | | | | | 1 | 1 | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | pixpllm <4:0> Pixel PLL M value register. The 'm' value is used by the reference clock prescaler circuit. There are three sets of PIXPLL registers: | Set A | Set B | Set C | |-----------|-----------|-----------| | XPIXPLLAM | XPIXPLLBM | XPIXPLLCM | | XPIXPLLAN | XPIXPLLBN | XPIXPLLCN | | XPIXPLLAP | XPIXPLLBP | XPIXPLLCP | The **pixpllm** field can be programmed from any of the 'm' registers in Set A, B, or C: **XPIXPLLAM**, **XPIXPLLBM**, or **XPIXPLLCM**. The register set which defines the pixel PLL operation is selected by the **clksel** field of the **MISC** VGA register as shown in the following table: | clksel | Pixel Clock PLL Frequency | Reset Value | |--------|-----------------------------|-------------| | '00' | Register Set A (25.172 MHz) | M = 6h | | '01' | Register Set B (28.361 MHz) | M = 4h | | '1X' | Register Set C | Unknown | •• *Note:* The **pixpllm** value *must* be in the range of 1 to 31. Reserved <7:5> Reserved. When writing to this register, the bits in this field *must* be set to '0'. PIXPLL N Value XPIXPLLN | Index | 45h | XPIXPLLAN | | |-------------|----------|-----------|---------| | | 49h | XPIXPLLBN | | | | 4Dh | XPIXPLLCN | | | Attributes | R/W, BYT | E | | | Reset Value | 28h | XPIXPLLAN | | | | 40h | XPIXPLLBN | | | | unknown | XPIXPLLCN | | | | Reserved | | pixplln | pixplln <6:0> Pixel PLL N value register. The 'n' value is used by the VCO feedback divider circuit. 3 5 6 4 The **pixplin** field can be programmed from any of the 'n' registers in Set A, B, or C: **XPIXPLLAN**, **XPIXPLLBN**, or **XPIXPLLCN**. The register set which defines the pixel PLL operation is selected by the **clksel** field of the **MISC** VGA register as shown in the following table: 2 1 0 | clksel | Pixel Clock PLL Frequency | Reset Value | |--------|-----------------------------|-------------| | '00' | Register Set A (25.172 MHz) | N = 33h | | '01' | Register Set B (28.361 MHz) | N = 29h | | '1X' | Register Set C | Unknown | •• *Note:* The **pixplln** value must be in the range of 1 (1h) to 127 (7Fh) inclusive. Reserved <7> Reserved. When writing to this register, this field must be set to '0'. XPIXPLLP P Value Index 46h XPIXPLLAP 4Ah XPIXPLLBP 4Eh XPIXPLLCP **Attributes** R/W, BYTE Reset Value 01h XPIXPLLAP 01h XPIXPLLBP unknown XPIXPLLCP | Reserved | | pixplls | | pixpllp | | | | |----------|---|---------|---|---------|---|---|---| | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | pixpllp <2:0> Pixel PLL P value register. The 'p' value is used by the VCO clock divider circuit. The permitted values are: $P = 0 \rightarrow Fo = Fvco/1$ $P = 1 \rightarrow Fo = Fvco/2$ $P = 3 \rightarrow Fo = Fvco/4$ $P = 7 \rightarrow Fo = Fvco/8$ pixplls <4:3> Pixel PLL S value register. The 's' value controls the loop filter bandwidth. 50 MHz <= Fvco < 110 MHz S=0 110 MHz <= Fvco < 170 MHz S=1 170 MHz <= Fvco < 240 MHz S=2 240 MHz <= Fvco < 310 MHz S=3 register as shown in the following table: The **pixpllp** and **pixplls** fields can be programmed from any of the 'p' registers in Set A, B, or C: **XPIXPLLAP**, **XPIXPLLBP**, or **XPIXPLLCP**. The register set which defines the pixel PLL operation is selected by the **clksel** field of the **MISC** VGA clkselPixel Clock PLL FrequencyReset Value'00'Register Set A (25.172 MHz)P = 1h, S = 0'01'Register Set B (28.361 MHz)P = 1h, S = 0'1X'Register Set CUnknown Reserved <7:5> Reserved. When writing to this register, the bits in this field *must* be set to '0'. PIXPLL Status XPIXPLLSTAT Index 4Fh Attributes RO, BYTE Reset Value unknown pixlock <6> Pixel PLL lock status. • 1: indicates that the pixel PLL has locked to the selected frequency defined by Set A, B, or C • 0: indicates that lock has not yet been achieved Reserved <5:0> <7> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. XSENSETEST Sense Test Index 3Ah Attributes R/W, BYTE Reset Value 0xxx xxxxb | SensepdN | | Rese | erved | | rcomp | dwoob | pcomp | |----------|---|------|-------|---|-------|-------|-------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | bcomp RO<0> Sampled blue compare. Verifies that the blue termination is correct. - 0: blue DAC output is below 350 mV1: blue DAC output exceeds 350 mV - **gcomp** Sampled green compare. Verifies that the green termination is correct. - 0: green DAC output is below 350 mV1: green DAC output exceeds 350 mV - **rcomp** Sampled red compare. Verifies that the red termination is correct. - 0: red DAC output is below 350 mV1: red DAC output exceeds 350 mV sensepdN <7> Sense comparator power down • 0: power down • 1: power up Reserved <6:3> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Note: This register reports the sense comparison function, which determines the presence of the CRT monitor and if the termination is correct. The output of the comparator is sampled at the end of every active line. When doing a sense test, the software should program a uniform color for the entire screen. SYSPLL M Value XSYSPLLM Index 2Ch Attributes R/W, BYTE Reset Value 0000 0101b | Reserved | | syspllm | | | | | | |----------|---|---------|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | sysplim <4:0> System PLL M value register. The 'm' value is used by the reference clock prescaler circuit. ◆ *Note:* The **syspllm** value *must* be in the range of 1 to 31. Reserved <7:5> Reserved. When writing to this register, the bits in this field *must* be set to '0'. XSYSPLLN SYSPLL N Value Index 2Dh Attributes R/W, BYTE Reset Value 0001 1111b sysplin <6:0> System PLL N value register. The 'n' value is used by the VCO feedback divider circuit. •• *Note:* The **sysplin** value must be in the range of 1 (1h) to 127 (7Fh) inclusive. Reserved <7> Reserved. When writing to this register, this field must be set to '0'. SYSPLL P Value XSYSPLLP Index 2Eh Attributes R/W, BYTE Reset Value 0001 0000b | Reserved | | sysplls | | syspllp | | | | |----------|---|---------|---|---------|---|---|---| | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | syspllp <2:0> System PLL P value register. The 'p' value is used by the VCO post-divider circuit. The permitted values are: $P=0 \rightarrow Fo = Fvco/1$ $P=1 \rightarrow Fo = Fvco/2$ $P=3 \rightarrow Fo = Fvco/4$ $P=7 \rightarrow Fo = Fvco/8$ Other values are reserved. sysplls <4:3> System PLL S value register. The 's' value controls the loop filter bandwidth. $50 \text{ MHz} \le \text{Fvco} < 110 \text{ MHz} \rightarrow \text{S}=0$ 110 MHz $\leq$ Fvco < 170 MHz $\rightarrow$ S=1 170 MHz $\leq$ Fvco < 240 MHz $\rightarrow$ S=2 240 MHz $\leftarrow$ Fvco < 310 MHz $\rightarrow$ S=3 Reserved <7:5> Reserved. When writing to this register, the bits in this field *must* be set to '0'. XSYSPLLSTAT SYSPLL Status Index 2Fh Attributes RO, BYTE Reset Value unknown syslock <6> System PLL lock status. • 1: indicates that the system PLL has locked to the selected frequency • 0: indicates that lock has *not* yet been achieved Reserved <5:0> <7> Reserved. When writing to this register, the bits in these fields *must* be set to '0'. Index 18h Attributes R/W, BYTE Reset Value 0000 0000b dacbgpdN DAC voltage reference block power down. <4> • 0: power down • 1: power up dacbgen <5> DAC voltage reference enable. • 0: use external voltage reference • 1: use DAC voltage reference block Reserved <7:6> <3:0> Reserved. When writing to this register, the bits in this field *must* be set to '0'. Note: To select an off-chip voltage reference, *all* enables must be set to '0'. To select the internal voltage references, all enables must be set to '1', and all voltage reference blocks must be powered up (write '00111111'). XZOOMCTRL Zoom Control Index 38h Attributes R/W, BYTE Reset Value 0000 0000b | | Reserved | | | | hzo | om | | |---|----------|---|---|---|-----|----|---| | 7 | 6 | E | 4 | 2 | 2 | 1 | 0 | | / | О | Э | 4 | 3 | | ı | U | hzoom <1:0> Horizontal zoom factor. Specifies the (zoom) factor used to replicate pixels in the horizontal display line. The following factors are supported: - '00': 1x (default) - '01': 2x - '10': reserved - '11': 4x - •• *Note:* The cursor is not affected by the **hzoom** bits (the cursor is never zoomed). Reserved <7:2> Reserved. When writing to this register, the bits in this field *must* be set to '0'. # Chapter 4: Programmer's Specification | HOST Interface | 4-2 | |---------------------------------------|-------| | Memory Interface | 4-19 | | Chip Configuration and Initialization | 4-23 | | Direct Frame Buffer Access | 4-28 | | Drawing in Power Graphic Mode | 4-29 | | CRTC Programming | 4-70 | | Video Interface | 4-79 | | Video Input Interface | 4-94 | | CODEC Interface | 4-101 | | Backend Scaler | 4-115 | | Interrupt Programming | 4-131 | | Power Saving Features | 4-135 | | Accessing the Serial EEPROM | 4-137 | | Second CRTC Programming | 4-140 | ## 4.1 HOST Interface #### 4.1.1 Introduction The Matrox G400 chip deals directly with the AGP interface. Each interface has been optimized to improve the performance of the graphics subsystem. As a result, the following buffering has been provided: **BFIFO** This is a 16-entry FIFO which is used to interface with the drawing engine registers. All the registers that are accessed through the BFIFO are identified in the register descriptions in Chapter 3 with the 'FIFO' attribute. The BFIFO is also used for the data by ILOAD operations. MIFIFO This is an 16-entry FIFO which is used for direct frame buffer VGA/MGA accesses. **CACHE** This is a 8-location cache, which is used for direct frame buffer MGA read accesses. **ROMFIFO** This is a 2-entry FIFO used for ROM accesses. The following table shows when the BFIFO, MIFIFO, CACHE, or ROMFIFO are used for different classes of access. | Access | Type | BFIFO | MIFIFO | CACHE | ROMFIFO | |-------------------------------------|------|-------|--------|-------|---------| | Configuration registers | | | | | | | Host Registers | | | | | | | VGA Registers | R | | | | | | DAC Registers | W | | | | | | Backend Scaler Registers | ** | | | | | | Video-In and CODEC Registers | | | | | | | WARP Instruction Memory | | | | | | | ROM | R | | | | W | | KOWI | W | | | | W | | DMAWIN or <b>MGABASE3</b> | WO | W | | | | | Drawing registers | R | | | | | | Drawing registers | W | W | | | | | Host registers +DRWI <sup>(1)</sup> | R | | | | | | Host registers +DRW1 | W | W | _ | _ | | | VGA frame buffer | R | | W | | | | VOA ITAINE BUITEI | W | | W | | | | MGABASE2 | R | | W | R | | | WOADAGEZ | W | | W | | | <sup>(1)</sup> DRWI: Drawing Register Window Indirect access ## 4.1.2 PCI Retry Handling In certain situations the chip may not be able to respond to a PCI access immediately, therefore, a number of retry cycles will be generated. A retry will be asserted when: - The BFIFO is written to when it is full. - The MIFIFO is written to when it is full. - The Frame Buffer is read when the MIFIFO is not empty or when the data is not available. - The VGA registers are written to when the MIFIFO is not empty. - The ROMFIFO is written to when it is full. - The Serial EEPROM is read and the data is not available. - •• *Note:* Some systems generate an error after only a few retries. In this case, you must check the BFIFO flag (thereby limiting the number of retries) to prevent a system error. ### 4.1.3 PCI Burst Support The chip uses PCI burst mode in all situations where performance is critical. The following table summarizes when bursting is used: | Access | Access Type | | |-------------------------------------------------|---------------|--| | MGABASE1 + DMAWIN range | W | | | MGABASE1 + drawing register range | W | | | MGABASE1 + host reg. range +DRWI range | W | | | <b>MGABASE1</b> + WARP instruction memory range | W | | | MGABASE3 range | W | | | VGA frame buffer range | W | | | VGA frame buffer range (mgamode = 1) | R (cache hit) | | | MGABASE2 range | W | | | MGABASE2 range | R (cache hit) | | ◆ *Note:* Accesses that are not supported in burst mode always generate a target disconnect when they are accessed in burst mode. Refer to Section 2.1.3 on page 2-4 for the exact addresses. The PCI Specification (Rev. 2.1) states that a target is required to complete the initial data phase within 16 PCLK's. In order to meet this specification, a read of a location within the VGA frame buffer range, the MGABASE2 range (when there is a cache miss), or the ROMBASE range will activate the delayed transaction mechanism (when the **noretry** field of **OPTION** = '0'). #### 4.1.4 **PCI Target-Abort Generation** The Matrox G400 generates a target-abort in two cases, as stated in the PCI Specification. The targetabort is generated only for I/O accesses, since they are the only types of access that apply to each case. #### Case A: PCBE<3:0>/ and PAD<1:0> are Inconsistent The only exception, mentioned in the PCI Specification, is when PCBE<3:0>/= '1111'. The following table shows the combinations of PAD<1:0> and PCBE<3:0>/ which result in the generation of a targetabort by the Matrox G400. | PAD<1:0> | PCBE<3:0>/ | |-------------|------------| | ,00, | '0XX1' | | | 'X0X1' | | | 'XX01' | | '01' | 'XXX0' | | | 'X011' | | | '0111' | | <b>'10'</b> | 'XXX0' | | | 'XX01' | | | '0111' | | <b>'11'</b> | 'XXX0' | | | 'XX01' | | | 'X011' | #### CASE B: PCBE<3:0>/ Addresses More Than One Device For example, if a write access is performed at 3C5h with PCBE<3:0>/ = '0101', both the VGA SEQ (Data) register and the DAC PALRDADD register are addressed. All of these accesses are terminated with a target-abort, after which the **sigtargab** bit of the **DEVCTRL** register is set to '1'. #### 4.1.5 Transaction Ordering The order of the transactions is extremely important for the VGA and the DAC for either I/O or memory mapped accesses. This means that a read to a VGA register must be completed before a write to the same VGA register can be initiated (especially when there is an address/data pointer that toggles when the register is accessed). In fact, this limits to one the number of PCI devices that are allowed to access the Matrox G400's VGA or DAC. #### 4.1.6 Direct Access Read Cache Direct read accesses to the frame buffer (either by the MGA full frame buffer aperture or the VGA window) are cached by one eight-dword cache entry. After a hard or soft reset, no cache hit is possible and the first direct read from the frame buffer fills the cache. When the data is available in the cache, the data phase of the first access will be completed in 2 pclks, and the data phase of the next accesses (in the case of a burst) will be completed in 1 pclk. The following situations will cause a *cache flush*, in order to maintain data coherency: - 1.A write access to the frame buffer (MGABASE2 or VGA frame buffer). - 2.A write to the VGA registers (either I/O or memory). - 3.A hard or soft reset. - Note: The cache is **not** flushed when the frame buffer configuration is modified (or when the drawing engine writes to a cached location). As a result, it is the software's responsibility to invalidate the cache, using one of the methods listed above, whenever any bit is written that affects the frame buffer configuration or contents. The **CACHEFLUSH** register can be used, since it occupies a reserved address in the memory mapped VGA register space (MGABASE1 + 1FFFh). ## 4.1.7 Big-Endian Support PCI may be used as an expansion bus for either Little-Endian or Big-Endian processors. The host-to-PCI bridge should be implemented to enforce address invariance, as required by the *PCI Specification*. Address invariance means, for example, that when memory locations are accessed as bytes they return data in the same format. When this is done, however, non 8-bit data will appear to be *byte-swapped*. Certain actions are then taken within the Matrox G400 to correct this situation. The exact action that will be taken depends on the data size (the Matrox G400 must be aware of the data size when processing Big-Endian data). The data size depends on the location of the data (the specific memory space), and the pixel size (when the data is a pixel). There are *six* distinct memory spaces: - 1. Configuration space. - 2.Boot space (EPROM). - 3.I/O space. - 4. Register space. - 5.Frame buffer space. - 6.ILOAD space. #### **Configuration space** Each register in the configuration space is 32 bits, and should be addressed using dword accesses. For these registers, no byte swapping is done, and bytes will appear in different positions, depending on the endian mode of the host processor. Keep in mind that the Matrox G400 chip specification is written from the point of view of a Little-Endian processor, and that the chip powers up in Little-Endian mode. #### **Boot space (EPROM)** As with the configuration space, no special byte translation takes place. Proper byte organization can be achieved through correct EPROM programming. That is, data should be stored in Big-Endian format for Big-Endian processors, and in Little-Endian format for Little-Endian processors. #### I/O space Since I/O is only used on the Matrox G400 for VGA emulation, it should, theoretically, only be enabled on (Little-Endian) x86 processors. However, it is still possible to use the I/O registers with other processors because I/O accesses are considered to be 8-bit. In such a case, bytes should not be swapped anyway. Byte swapping considerations aside, Matrox G400 I/O operations are mapped at fixed locations, which renders them incompatible with PCI's Plug and Play philosophy. This presents a second reason to avoid using the Matrox G400 I/O mapping on non x86 platforms. #### **Register Space** The majority of the data in the register space is 32 bits wide, with a few exceptions: - The VGA compatibility section. Data in this section is 8 bits wide. - The DAC. Data in this section is 8 bits wide. - External devices. In this case, the width of the data cannot be known in advance. Byte swapping for Big-Endian processors can be enabled in the register space by setting the **OPTION** configuration space register's **powerpc** bit to 1. Setting the **powerpc** bit ensures that a 32-bit access by a Big-Endian processor will load the correct data into a 32-bit register. In other words, when data is treated as 32-bit quantities, it will appear in the identical way to both little and Big-Endian processors. •• Note: Byte and word accesses will not return the same data on both Little and Big-Endian processors. In the register mapping tables in Chapter 3, all addresses are given for a Little-Endian processor. ### powerpc = 1 ## **PCI Bus** ## powerpc = 0 ### **PCI Bus** #### Frame Buffer Space The frame buffer is organized in Little-Endian format, and byte swapping depends on the size of the pixel. As usual, addresses are not modified. Swapping mode is directed by the **dirDataSiz** field of the **OPMODE** host register. This field is used for direct access either through the VGA frame buffer window or the full memory aperture. The only exception is 24 bits/pixel mode, which is correctly supported only by Little-Endian processors. #### 32 bits/pixel, dirDataSiz = 10 ### 16 bits/pixel, dirDataSiz = 01 #### 8 bits/pixel, dirDataSiz = 00 #### **ILOAD Space (DMAWIN or 8 MByte Pseudo-DMA Window)** Access to this space requires the same considerations as for the direct access frame buffer space (described previously), except that the **dmaDataSiz** field of the **OPMODE** register is used instead of **dirDataSiz** (for ILOAD operations in DMA BLIT WRITE mode). Other DMA modes - DMA General Purpose, DMA Vector Write, or DMA Vertex Write - should set **dmaDataSiz** to '10' for Big-Endian or '00' for Little-Endian processor. #### 4.1.8 Host Pixel Format There are several ways to access the frame buffer. The pixel format used by the host depends on the following: - The current frame buffer's data format - The access method - The processor type (Big-Endian or Little-Endian) - The control bits which select the type of byte swapping The supported data formats are listed below, and are shown from the processor's perspective. The supported formats for direct frame buffer access and ILOAD are explained in their respective sections of this chapter. •• Note: For Big-Endian processors, these tables assume that the CPU-to-PCI bridge respects the *PCI Specification*, which states that byte address coherency must be preserved. This is the case for PREP systems and for Macintosh computers. ### **Pixel Format (From the Processor's Perspective)** **8-bit A** Little-Endi Little-Endian 8-bit (see the **powerpc** field of **OPTION**) is used in ILOAD operations. Refer to Table 4-8 on page 4-66. $31\ 30\ 29\ 28\ 27\ 26\ 25\ 24\ 23\ 22\ 21\ 20\ 19\ 18\ 17\ 16\ 15\ 14\ 13\ 12\ 11\ 10\ 9\ 8\ 7\ 6\ 5\ 4\ 3\ 2\ 1\ 0$ | 0 | Pixel 3 | Pixel 2 | Pixel 1 | Pixel 0 | |---|---------|---------|---------|---------| | 1 | : | : | : | : | | 2 | : | : | : | : | | 3 | : | : | : | : | **8-bit B** Big-Endian 8-bit (see the **powerpc** field of **OPTION**) is used in ILOAD operations. Refer to Table 4-8 on page 4-66. 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | 0 | Pixel 0 | Pixel 1 | Pixel 2 | Pixel 3 | |---|---------|---------|---------|---------| | 1 | | : | : | : | | 2 | : | : | : | : | | 3 | : | : | : | : | # **16-bit A** Little-Endian 16-bit (see the **powerpc** field of **OPTION**) is used in ILOAD operations. Refer to Table 4-8 on page 4-66. 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | 0 | Pixel 1 | Pixel 0 | |---|---------|---------| | 1 | : | : | | 2 | : | : | | 3 | : | : | ## **16-bit B** Big-Endian 16-bit (see the **powerpc** field of **OPTION**) is used in ILOAD operations. Refer to Table 4-8 on page 4-66. 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | 0 | Pixel 0 | Pixel 1 | |---|---------|---------| | 1 | : | : | | 2 | : | : | | 3 | : | : | #### **32-bit A** 32-bit RGB, used in ILOAD operations. Refer to Table 4-8 on page 4-66. 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | 0 | Alpha Pixel 0 | Red Pixel 0 | Green Pixel 0 | Blue Pixel 0 | |---|---------------|-------------|---------------|--------------| | 1 | Alpha Pixel 1 | Red Pixel 1 | Green Pixel 1 | Blue Pixel 1 | | 2 | Alpha Pixel 2 | Red Pixel 2 | Green Pixel 2 | Blue Pixel 2 | | 3 | : | : | : | : | #### **32-bit B** 32-bit BGR used in ILOAD operations. Refer to Table 4-8 on page 4-66. 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | 0 | Alpha Pixel 0 | Blue Pixel 0 | Green Pixel 0 | Red Pixel 0 | |---|---------------|--------------|---------------|-------------| | 1 | Alpha Pixel 1 | Blue Pixel 1 | Green Pixel 1 | Red Pixel 1 | | 2 | Alpha Pixel 2 | Blue Pixel 2 | Green Pixel 2 | Red Pixel 2 | | 3 | : | : | : | : | #### **24-bit A** 24-bit RGB packed pixel, used in ILOAD operations. Refer to Table 4-8 on page 4-66. 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | 0 | Blue Pixel 1 | Red Pixel 0 | Green Pixel 0 | Blue Pixel 0 | |---|--------------------------|---------------|---------------|---------------| | 1 | Green Pixel 2 | Blue Pixel 2 | Red Pixel 1 | Green Pixel 1 | | 2 | Red Pixel 3 | Green Pixel 3 | Blue Pixel 3 | Red Pixel 2 | | 3 | Blue Pixel 5 Red Pixel 4 | | Green Pixel 4 | Blue Pixel 4 | | 4 | : | : | : | : | ### **24-bit B** 24-bit BGR packed pixel, used in ILOAD operations. Refer to Table 4-4 on page 4-66. 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | 0 | Red Pixel 1 | Blue Pixel 0 | Green Pixel 0 | Red Pixel 0 | |---|---------------|---------------|---------------|---------------| | 1 | Green Pixel 2 | Red Pixel 2 | Blue Pixel 1 | Green Pixel 1 | | 2 | Blue Pixel 3 | Green Pixel 3 | Red Pixel 3 | Blue Pixel 2 | | 3 | Red Pixel 5 | Blue Pixel 4 | Green Pixel 4 | Red Pixel 4 | | 4 | : | : | : | : | # MONO A Little-Endian 1-bit used in ILOAD and BITBLT operations. Refer to Table 4-9 on page 4-67. 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | 0 | P31 | P0 | |---|-----|-----| | 1 | P63 | P32 | | 2 | P95 | P64 | | 3 | | ; | P = 'pixel' # MONO B Little-Endian 1-bit Windows format, used in ILOAD and BITBLT operations. Refer to Table 4-9 on page 4-67. 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | 0 | P24 | | P31 | P16 | | P23 | P8 | | P15 | P0 | | P7 | |---|-----|---|-----|-----|---|-----|-----|---|-----|-----|---|-----| | 1 | P56 | | P63 | P48 | | P55 | P40 | | P47 | P32 | | P39 | | 2 | P88 | | P95 | P80 | | P87 | P72 | | P79 | P64 | | P71 | | 3 | | : | | | : | | | : | | | : | | # **MONO C** Big-Endian 1-bit Windows format, used in ILOAD and BITBLT operations. Refer to Table 4-9 on page 4-67. 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | 0 | P0 | P31 | |---|-----|-----| | 1 | P32 | P63 | | 2 | P64 | P95 | | 3 | : | | ### 4.1.9 Programming Bus Mastering for DMA Transfers When the busmaster field bit of the DEVCTRL register is '0' (disabled), the Matrox G400 will not perform PCI bus mastering, even if the other bus mastering registers are accessed. Disabling busmaster does not preclude writing to the host registers related to bus mastering. To enable AGP bus mastering, the following register must be correctly set: **data\_rate**, **agp\_enable** and **sba\_enable**. The bus mastering feature allows the Matrox G400 to access system memory through a DMA channel (used in conjunction with Pseudo-DMA mode). In order to send 3D commands to the chip, General Purpose Pseudo-DMA should be used. For texture mapping transfers between system memory and the off-screen area, ILOAD Pseudo-DMA mode should be used. For Vertex transfer to the WARP engine, the Vertex write Pseudo-DMA mode should be used. • Note: This is the recommended usage - any Pseudo-DMA mode can actually be used for either case. The DMA channel is built with three sets of registers, as well as interrupt control and status bits. The three sets of registers identify the system memory area to be used for the primary, secondary and setup DMA channels. - The primary DMA registers are accessible through the host register's base address. They are readable and writable. - The secondary DMA registers are accessible only by a primary DMA transfer for writes, and through the drawing register base addresses for reads. The secondary DMA registers cannot be written directly through the drawing register base addresses or through the DMAWIN base address, nor can they be written to by a secondary DMA transfer. - The setup DMA registers are accessible only by a primary DMA transfer for writes, and through the drawing register base addresses for reads. The setup DMA registers cannot be written directly through the drawing register base addresses or through the DMAWIN base address, nor can they be written to by a secondary DMA transfer. #### 4.1.9.1 DMA Registers #### Primary Current Address (PRIMADDRESS) This register must be initialized with the starting address of the primary DMA channel in the system memory area. The two LSBs of this register specify the Pseudo-DMA mode to be used for transfers. #### Primary End Address (PRIMEND) This register must be initialized with the end address of the primary DMA channel in the system memory area. Bit 1 is used to specify the system memory type where the channel reside in (PCI/AGP). And bit 0 can be used to prevent that the primary list execution restart when there is a Soft Trap Interrupt pending. #### Secondary Current Address (SECADDRESS) This register must be initialized with the starting address of the secondary DMA channel in the system memory area. The two LSBs of this register specify the Pseudo-DMA mode to be used for transfers. This register is accessed using General Purpose Pseudo-DMA mode (primary DMA transfer) in order to be able to start secondary DMA transfers while the primary DMA channel is active. #### Secondary End Address (SECEND) This register must be initialized with the end address of the secondary DMA channel in the system memory area. It is accessed using General Purpose Pseudo-DMA mode (primary DMA transfer) in order to be able to start secondary DMA transfers while the primary DMA channel is active. Bit 1 is used to specify the system memory type where the channel reside in (PCI/AGP). #### Setup Current Address (SETUPADDRESS) This register must be initialized with the starting address of the setup DMA channel in the system memory area. The two LSBs of this register specify the Setup-DMA mode to be used for transfers. This register is accessed using General Purpose Pseudo-DMA mode (primary DMA transfer) in order to start setup DMA transfers while the primary DMA channel is active. ### Setup End Address (SETUPEND) This register must be initialized with the end address of the setup DMA channel in the system memory area. It is accessed using General Purpose Pseudo-DMA mode (primary DMA transfer) in order to start setup DMA transfers while the primary DMA channel is active. Bit 1 is used to specify the system memory type where the channel reside in (PCI/AGP). #### **Soft Trap Interrupt (SOFTRAP)** This register is used when the secondary DMA channel is unavailable (due to a system or memory constraint, or other reason). When **SOFTRAP** is written, the Matrox G400 will generate an interrupt (if the **IEN** register is set). In the context of texture mapping, this register must be written with the handle of the texture so that the interrupt handler can know where the texture is located in system memory. Writing this register stops primary DMA transfers. To restart the primary DMA channel, the **PRIMEND** register must be re-written with bit 0 set to '0'. #### Interrupt Clear (ICLEAR) Interrupt clearing. This register clears the pending soft trap interrupt. #### Interrupt Enable (IEN) Interrupt enable. This register allows the pending soft trap interrupt to be seen on the PINTA/ line. #### Status (STATUS) End of primary DMA channel status bit and soft trap interrupt pending bit. Use of the primary DMA channel is complete when the primary, secondary and setup DMA transfers are finished. ### 4.1.9.2 Using the DMA Channel To use the DMA channel, follow this sequence: - 1. Write a list of commands to a buffer in main memory. - 2. Write the starting address of the primary buffer in memory to the **PRIMADDRESS** register. Since this is a 32-bit pointer, the two LSBs are not used as an address but rather as an indication of the type of Pseudo-DMA transfer to be used. - 3. Write the address of the first dword after the end of the primary buffer to the **PRIMEND** register, and the memory type the list resides in (PAGPXFER). - 4. As soon as the **PRIMEND** register is accessed, the primary DMA channel will be activated (if there is no **SOFTRAP** pending or if bit 0 (**PRIMNOSTART**) of **PRIMEND** is set to '0'). - 5. A read access will be performed on the PCI bus at the location pointed to by **PRIMADDRESS**. The data that is read will be fed to the 7K Pseudo-DMA window (which is internal to the chip). **PRIMADDRESS** will be advanced to point to the next dword. - 6. If, within this process the host requires the second level of Pseudo-DMA, then the **SECADDRESS** register must be written with the starting address of the secondary buffer in memory and the Pseudo-DMA mode to be used, then the **SECEND** register must be written. In this case, steps 7 to 9 will be taken; if not, operations resume at step 10. - •• *Note*: It is not permitted to set **SECEND** to the same value as **SECADDRESS**. - •• Note: If the primary list status fetch pointer enable (**primptren**) is set, the DMA engine will send the status info to the system memory at the address programmed in **PRIMPTR**. - 7. Read accesses will be performed on the PCI/AGP bus at the location pointed to by **SECADDRESS** with the method indicated by SAGPXFER. The data that is read will be fed to the DMAWIN window (which is internal to the chip). The secondary current address will be advanced to point to the next dword. - 8. The **SECADDRESS** and **SECEND** registers cannot be accessed while they are being used by the secondary DMA channel. This will produce unpredictable results. - 9. **SECADDRESS** and **SECEND** are compared. If they are different, the secondary DMA continues (refer to step 7). If they are equal, the secondary DMA is finished and the primary DMA continues. It should be noted that when the primary DMA continues, the selected Pseudo-DMA mode restarts. The General Purpose Pseudo-DMA mode is selected, the first dword fetch will be interpreted as a set of four register indexes. - 10. If, within this process the host requires a level of Setup-DMA, then the **SETUPADDRESS** register must be written with the starting address of the setup buffer in memory and the Setup-DMA mode to be used, then the **SETUPEND** register must be written. In this case, steps 11 to 13 will be taken; if not, operations resume at step 14. - **►►** *Note:* It is not permitted to set **SETUPEND** to the same value as **SETUPADDRESS**. - •• *Note:* If the primary list status fetch pointer enable (**primptren**) is set, the DMA engine will send the status info to the system memory at the address programmed in **PRIMPTR**. - 11. Read accesses will be performed on the PCI/AGP bus at the location pointed by **SETUPADDRESS** with the method indicated by **SETUPEND**. The data that is read will be fed to the Setup-DMA engine which will generate virtual secondary DMA based on the Setup-DMA mode (SETUPMOD) (refer to section 4.1.9.3 for Setup-DMA mode description). The setup current address will be advanced to point to the next dword. - •• *Note:* The **SETUPADDRESS** and **SETUPEND** registers can only be accessed by the primary DMA channel. - 12. **SETUPADDRESS** and **SETUPEND** are compared. If they are different, the setup DMA continues (refer to step 10). If they are equal, the setup DMA is finished and the primary DMA continues. It should be noted that when the primary DMA continues, the selected Pseudo-DMA mode restarts. The General Purpose Pseudo-DMA mode is selected, the first dword fetch will be interpreted as a set of four register indexes. - 13. **PRIMADDRESS** is compared with **PRIMEND**. If they are different, the DMA transfer continues (refer to step 5). If they are equal, the DMA transfer is complete. - 14. If the **SOFTRAP** register is accessed in the primary DMA channel, the primary DMA transfer will stop and an interrupt will be generated (see the softrapen field). In the context of texture mapping, the **SOFTRAP** register must be written with the handle of the texture so that the interrupt routine will know what action to take. To restart the primary DMA channel, the **PRIMEND** register must be written with the **primnostart** field set to '0'. Until **PRIMEND** is written, any operation can be undertaken with the Matrox G400. If the DMAWIN window is accessed before **PRIMEND** is written, it will be controlled by the **dmamod** field of the **OPTION** register (when the **SOFTRAP** register is written, a DMA reset will occur). #### 4.1.9.3 **Setup-DMA Channel Operation** The Setup-DMA channel (access via **SETUPADDRESS** and **SETUPEND**) is an intermediate level of DMA used to build a virtual secondary list based on the **setupmod** programmed. The only **setupmod** available is the DMA Vertex Fixed Length Setup List mode (see page 3-170) which uses the information in the list to build a virtual secondary list of DMA Vertex Write for each entry of the list. Each entry of the list is used as a pointer to the start of a Vertex list in system memory, the length of each list correspond to the **wvrtxsz** field of the **WVRTXSZ** register. So. ``` virtual SECADDRESS(n) = data read from the 'n' entry of the Setup-DMA list ``` virtual **SECMOD**(n) = DMA Vertex Write virtual **SECEND**(n) = data read from the 'n' entry of the Setup-DMA list + WVRTXSZ + 1 virtual **SAGPXFER**(n) = SETUPAGPXFER #### 4.1.9.4 **Special Cases** The PCI Specification indicates that when the Matrox G400 acts as a master on the PCI bus, two particular circumstances can arise (aside from the regular transfer of data): - 1. The first case is a *master-abort*, which occurs when an access is attempted and no device responds (often due to a glitch in programming). When this happens, the **recmastab** bit of the **DEVCTRL** register will be set (and will remain set until a '1' is written to it). - 2. The second case is a *target-abort*. This is a target termination that is used when the target detects a problem with an access generated by the Matrox G400. The Matrox G400 always generates accesses in the correct form, so this situation depends on the target. Target-aborts should not occur, since the PCI Specification indicates that they occur with I/O accesses; the Matrox G400 generates *memory* accesses. There is no way to change the Matrox G400 or its programming to prevent a target-abort from occurring. If a target-abort occurs, the **rectargab** bit of the **DEVCTRL** register will be set (and will remain set until a '1' is written to it). The software must write to the **softreset** bit of the **RST** register when either a *master-abort* or a *target*abort occurs (the RST register will indicate this) to reset the DMA channel and the BFIFO. This must also be done when a warm boot occurs (on a PC, when Ctrl+Alt+Del is pressed). #### Reset of the Pseudo-DMA sequence: A reset of the Pseudo-DMA sequence will be generated under the following conditions: - When the **PRIMADDRESS** register is written. - When the **SECEND** register is written, assuming **SECEND** is *not* equal to **SECADDRESS**). - When the **SETUPEND** register is written, assuming **SETUPEND** is *not* equal to **SETUPADDRESS**). - When the **SOFTRAP** register is written. - When secondary DMA transfers end (that is, when **SECADDRESS** becomes equal to **SECEND** at the end of the secondary DMA, and not when **SECADDRESS** is written with the **SECEND** value). - When setup DMA transfers end (that is, when **SETUPADDRESS** becomes equal to **SETUPEND** at the end of the setup DMA, and *not* when **SETUPADDRESS** is written with the **SETUPEND** value). - When a master-abort or target-abort is detected. - ◆ *Note:* There is *no* reset of the Pseudo-DMA sequence when **PRIMEND** is written (since **PRIMEND** starts the primary DMA transfers); writing can happen more than once to extend the list (even while the list is still being transferred). - •• *Note:* There is *no* reset of the Pseudo-DMA sequence when primary DMA transfers end. If commands are added to the primary display list, **PRIMEND** has to be written with its new value to restart the primary DMA transfers. If you intend to write PRIMEND more than once (without re-writing **PRIMADDRESS**), fill the last set of Pseudo-DMA transfers with no-ops (reserved registers). Otherwise, the Pseudo-DMA transfers will restart at the last Pseudo-DMA location (either index or data when in General Purpose Pseudo-DMA mode). #### **Example:** - When **PRIMADDRESS** is written with 'primaddress0', a reset of the Pseudo-DMA sequence is executed. - When **SOFTRAP** is written (through a primary DMA transfer), another reset is executed ('reset\_f'). - When **SECEND** is written, and when the secondary DMA ends, two other resets are executed ('reset\_b' and 'reset\_c'). - When **SETUPEND** is written, and when the setup DMA ends, two other resets are executed ('reset\_d' and 'reset\_e'). #### Additional Information - When the DMA channel is used (mastering), it is possible to know which parts of the buffer have been executed by the drawing engine. - The DMA current pointer is readable by the CPU through the PRIMADDRESS, SECADDRESS or SETUPADDRESS registers. - The primary list status fetch pointer (**PRIMPTR**) functionality can be used to allow the DMA engine to send the status info to system memory every time **SECEND**, **SETUPEND** or **SOFTRAP** is written. - The **endprdmasts** field of the **STATUS** register always indicates whether or not all the DMA channels have been read completely (**PRIMADDRESS** = **PRIMEND** and **SECADDRESS** = **SECEND** and **SETUPADDRESS** = **SETUPEND**). It is set to '1' when a soft trap interrupt occurs. This bit toggles to '0' as soon as the primary DMA channel restarts. #### If primnostart is '1' when reprogramming primend: ■ To get an interrupt when the primary DMA channel terminates, include a write to the **SOFTRAP** register as the last DMA transfer. ## 4.2 Memory Interface ## 4.2.1 Frame Buffer Organization The Matrox G400 supports a total of 32 megabytes of SGRAM memory comprised of one or two banks of 8, 16, or 32 MBytes each. There are two different frame buffer organizations, described below: - VGA Mode - Power Graphic Mode ### 4.2.1.1 Supported Resolutions In Power Graphic Mode, the resolution depends on the amount of available memory. The following table shows the memory requirements for each standard VESA resolution and pixel depth. | | Sing | le Frame | Buffer l | Mode | Single Z Buffer | | | | | | | | |-------------|----------------------------|----------|----------|--------|-----------------|--------|-------|--------|-----------|--------|--|-----| | | | No | Z | | | Z 16 | bits | | Z 32 bits | | | | | Resolution | 8-bit 16-bit 24-bit 32-bit | | 8-bit | 16-bit | 24-bit | 32-bit | 8-bit | 16-bit | 24-bit | 32-bit | | | | 640 x 480 | 8M | 8M | 8M | 8M | 8M | 8M | | 8M | 8M | 8M | | 8M | | 720 x 480 | 8M | 8M | 8M | 8M | 8M | 8M | | 8M | 8M | 8M | | 8M | | 800 x 600 | 8M | 8M | 8M | 8M | 8M | 8M | | 8M | 8M | 8M | | 8M | | 1024 x 768 | 8M | 8M | 8M | 8M | 8M | 8M | _ | 8M | 8M | 8M | | 8M | | 1152 x 864 | 8M | 8M | 8M | 8M | 8M | 8M | _ | 8M | 8M | 8M | | 8M | | 1280 x 1024 | 8M | 8M | 8M | 8M | 8M | 8M | | 8M | 8M | 8M | | 10M | | 1600 x 1200 | 8M | 8M | 8M | 8M | 8M | 8M | _ | 16M | 16M | 16M | | 16M | | 1920 x 1080 | 8M | 8M | 8M | 8M | 8M | 8M | _ | 16M | 16M | 16M | | 16M | | 1800 x 1440 | 8M | 8M | 8M | 16M | 8M | 16M | | 16M | 16M | 16M | | 32M | | 1920 x 1200 | 8M | 8M | 8M | 8M | 8M | 8M | _ | 16M | 16M | 16M | | 16M | | 2048 x 1536 | 8M | 8M | 16M | 16M | 16M | 16M | _ | 32M | 16M | 32M | | 32M | #### 4.2.1.2 VGA Mode In VGA Mode, the frame buffer can be up to 1M. In a 128-bit slice, byte line 0 is used as plane 0; byte line 1 is used as plane 1; byte line 2 is used as plane 2; byte line 3 is used as plane 3. Byte lines 4-15 are not used, and the contents of this memory are preserved. <sup>(1)</sup> All addresses are hexadecimal byte addresses which correspond to pixel addresses in 8 bits/pixel mode. #### 4.2.1.3 **Power Graphic Mode** The possible memory configurations are described in the subsections which follow. ◆ *Note:* All addresses are hexadecimal and are byte addresses. Figure 4-1: OPTION<12:10> memconfig [2:0] = '000' or '100' Figure 4-2: OPTION<12:0> memconfig [2:0] = '001' or '010' Figure 4-3: OPTION<12:10> memconfig [2:0] = '011' or '101' ## 4.2.2 Pixel Format The slice is 128 bits long and is organized as follows. In all cases, the least significant bit is 0. The 24 bit/pixel frame buffer organization is a special case wherein there are three different slice types. In this case, one pixel can be in two different slices. ## 32 bits/pixel ## 24 bits/pixel ## 16 bits/pixel ### 8 bits/pixel #### Monochrome For each of these modes, the pixels are arranged as follows: # 32 bits/pixel | 31 | 2 | 4 23 | 16 | 15 | 8 | 7 | | 0 | |----|---------|------|-------|----|---------|---|------|---| | 7 | Alpha ( | 7 | Red 0 | 7 | Green 0 | 7 | Blue | 0 | # 24 bits/pixel | 23 | | 16 | 15 | | 8 | 7 | | 0 | |----|-----|----|----|-------|---|---|------|---| | 7 | Red | 0 | 7 | Green | 0 | 7 | Blue | 0 | # 16 bits/pixel (5:5:5) | | 15 | 14 | | 10 | 9 | | 5 | 4 | | 0 | |-----|----|----|-----|----|---|-------|---|---|------|---| | | 0 | 4 | Red | 0 | 4 | Green | 0 | 4 | Blue | 0 | | Alp | ha | | | | | | | | | | # 16 bits/pixel (5:6:5) | 15 | | 11 | 10 | | 5 | 4 | | 0 | |----|-----|----|----|-------|---|---|------|---| | 4 | Red | 0 | 5 | Green | 0 | 4 | Blue | 0 | # 8 bits/pixel | 7 | 5 | 4 | 2 | 1 | 0 | |-----|---|----|-----|----|----| | 2 | 0 | 2 | 0 | 1 | 0 | | Red | | Gr | een | BI | ue | # 8 bits/pixel | 7 | | 0 | |---|--------------|---| | | Pseudo Color | | # 4.3 Chip Configuration and Initialization ### 4.3.1 Reset The Matrox G400 can be both Hard and Soft reset. Hard reset is achieved by activating the PRST/pin. There is no need for the PRST/pin to be synchronous with any clock. - A Hard reset will reset all chip registers to their reset values if such values exist. Refer to the individual register descriptions in Chapter 3 to determine which bits are hard reset. - All state machines are reset (possibly with termination of the current operation). - FIFOs will be emptied, and the cache will be invalidated. - A hard reset will activate the local bus reset (EXTRST/) in order to reset expansion devices when required. The EXTRST/ signal is synchronous on PCLK. The state of the straps are read and registered internally upon hard reset. A Soft reset will not re-read the external straps, nor will it change the state of the bits of the **OPTION** register. | Strap Name | Pins | Description | |----------------------------------------------------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | biosboot | HDATA<1> | Indicates whether a ROM is installed ('1') or not ('0'). The biosboot strap also controls the <b>biosen</b> field of the <b>OPTION</b> register. | | modclkp | MDQ<31:29> | Used to determine the frequency at which an LVTTL memory expansion module is designed to operate on MDQ<63:0>. | | mod2clkp | MDQ2<31:29> | Used to determine the frequency at which an LVTTL memory expansion module is designed to operate on MDQ2<63:0>. | | vgaboot HDATA<0> Indicates whether not ('0') only if to the class field to | | Indicates whether the VGA I/O locations are decoded ('1') or not ('0') only if the <b>vgaioen</b> bit has not been written. The vgaboot strap also controls bit 23 of the <b>CLASS</b> register, setting the <b>class</b> field to 'Super VGA compatible controller' ('1') or to 'Other display controller' ('0'). | A soft reset is performed by programming a '1' into bit 0 of the **RST** host register. Soft reset will be maintained until a '0' is programmed (see the **RST** register description on page 3-167 for the details). The soft reset should be interpreted as a drawing engine reset more than as a general soft reset. The video circuitry, VGA registers, and frame buffer memory accesses, for example, are not affected by a soft reset. Only circuitry in the host section which affects the path to the drawing engine will be reset. Soft reset has no effect on the EXTRST/ line; the softextrst (RST host register) does. # 4.3.2 Operations After Hard Reset - After a hard reset, the chip will be in a VGA-compatible state. - Register bits that do not have a reset value will wake up with unknown values. - Frame buffer memory refreshing is not running. ## 4.3.3 Power Up Sequence Aside from the PCI initialization, certain bits in the **OPTION** register must be set, according to the devices in the system that the chip is used in. These bits, shown in the following table, are essential to the correct behavior of the chip: | Name | Reset Value | Description | |-------------------------------------------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------| | <b>eepromwt</b> '0' To be set to '1' if a FLASH ROM is us to the ROM. | | To be set to '1' if a FLASH ROM is used, and writes are to be done to the ROM. | | <b>powerpc</b> '0' To be set to '1' to support Big-Endian processor accesses. | | To be set to '1' to support Big-Endian processor accesses. | | rfhcnt | ,000000, | The refresh counter defines the rate of MGA memory refresh. | | vgaioen | vgaboot strap | Takes the strap value on hard reset, but is also writable: '0': VGA I/O locations are not decoded '1': VGA I/O locations are decoded. | # 4.3.3.1 SGRAM/SDRAM Reset Sequence After a reset, the clocks must be initialized first. Observe the following sequences to ensure proper behavior of the chip and to properly initialize the RAM. ## **Analog Macro Power Up Sequence** - **Step 1.** If an 'off-chip' voltage reference is not used, then: - (i) Program XVREFCTRL (refer to the register description and its associated note). - (ii) Wait 100 mS for the reference to become stable. - **Step 2.** Power up the system PLL by setting the **sysplipdN** field of **OPTION** to '1'. - Step 3. Wait for the system PLL to lock (indicated when the **syslock** field of the **XSYSPLLSTAT** register is '1'). - **Step 4.** Power up the pixel PLL by setting the **pixpllpdN** field of **XPIXCLKCTRL** to '1'. - **Step 5.** Wait for the pixel PLL to lock (indicated when the **pixlock** field of **XPIXPLLSTAT** is '1'). - **Step 6.** Power up the LUT by setting the **ramcs** field of **XMISCCTRL** to '1'. - **Step 7.** Power up the DAC by setting the dacpdN field of XMISCCTRL to '1'. The PLLs are now set up and oscillating at their reset frequencies, but they are not selected. The following steps will set MCLK to 150 MHz, GCLK to 90 MHz, WCLK to 100, and PIXCLK to 25.175 MHz. See 'Clock Source Selection / PLL Reprogramming' on page 4-93. - 1. Disable the system clocks by setting **sysclkdis** (**OPTION** register) to '1'. - 2. Select the system PLL by setting **sysclksl** to '01'. - 3. Enable the system clocks by setting **sysclkdis** to '0'. - 4. Disable the pixel clock and video clock by setting **pixclkdis** (XPIXCLKCTRL register) to '1'. - 5. Select the pixel PLL by setting **pixelksl** to '01'. - 6. Enable the pixel clock and video clock by setting **pixclkdis** to '0'. - •• *Note:* Each of the preceding six steps *must* be done as a single PCI access. They cannot be combined. #### **SGRAM/SDRAM Initialization** - **Step 1.** Set the **scroff** blanking field (**SEQ1**<5>) to prevent any transfer. - **Step 2.** Set the **c2en** blanking field (**C2CTL**<0>) to prevent any transfer. - **Step 3.** Program all the fields of the **MCTLWTST** register. - **Step 4.** Program the memconfig field of the **OPTION** register. - **Step 5.** Program the **mrscopcod** field of the **MEMRDBK** register to '0000'. - **Step 6.** Program the mclkbrd0 and mclkbrd1 fields in the MEMRDBK register with tap delay values appropriate for the SGRAM type and loading. - **Step 7.** Wait a minimum of $200 \mu s$ . - Step 8. Set the memreset field of MACCESS. - **Step 9.** Start the refresh by programming the **rfhcnt** field of the **OPTION** register. The Matrox G400 provides three different display modes: text (VGA or SVGA), VGA graphics, and SVGA graphics. Table 4-1 lists all of the display modes which are available through BIOS calls. - The text display uses a multi-plane configuration in which a character, its attributes, and its font are stored in these separate memory planes. All text modes are either VGA-compatible or extensions of the VGA modes. - The VGA graphics modes can operate in either multi-plane or packed-pixel modes, as is the case with standard VGA. - The SVGA modes operate in packed-pixel mode they enable use of the graphics engine. This results in very high performance, with high resolution and a greater number of pixel depths. Table 4-1: Display Modes (Part 1 of 2) No. of Mode Organization Resolution Type colors 0 **VGA** 40x25 Text 360x400 16 1 VGA 40x25 Text 360x400 16 2 **VGA** 80x25 Text 720x400 16 3 **VGA** 80x25 Text 720x400 16 4 Packed-pixel 2 bpp **VGA** 320x200 4 5 VGA Packed-pixel 2 bpp 320x200 4 6 **VGA** 2 Packed-pixel 1 bpp 640x200 VGA 80x25 Text 2 7 720x400 D VGA Multi-plane 4 bpp 320x200 16 VGA E Multi-plane 4 bpp 640x200 16 F **VGA** Multi-plane 1 bpp 640x350 2 10 **VGA** Multi-plane 4 bpp 640x350 16 11 **VGA** Multi-plane 1 bpp 640x480 2 12 **VGA** Multi-plane 4 bpp 640x480 16 13 **VGA** 256 Packed-pixel 8 bpp 320x200 108 **VGA** 80x60 Text 640x480 16 VGA 10A 132x43 Text 1056x350 16 109 **VGA** 132x25 Text 16 1056x400 Table 4-1: Display Modes (Part 2 of 2) | Mode | Туре | Organization | Resolution | No. of colors | |--------------------|------|---------------------|------------|---------------| | 10B | VGA | 132x50 Text | 1056x400 | 16 | | 10C | VGA | 132x60 Text | 1056x480 | 16 | | 100 | SVGA | Packed-pixel 8 bpp | 640x400 | 256 | | 101 | SVGA | Packed-pixel 8 bpp | 640x480 | 256 | | 110 | SVGA | Packed-pixel 16 bpp | 640x480 | 32K | | 111 | SVGA | Packed-pixel 16 bpp | 640x480 | 64K | | 112 | SVGA | Packed-pixel 32 bpp | 640x480 | 16M | | 102 | SVGA | Multi-plane 4 bpp | 800x600 | 16 | | 103 | SVGA | Packed-pixel 8 bpp | 800x600 | 256 | | 113 | SVGA | Packed-pixel 16 bpp | 800x600 | 32K | | 114 | SVGA | Packed-pixel 16 bpp | 800x600 | 64K | | 115 | SVGA | Packed-pixel 32 bpp | 800x600 | 16M | | 105 | SVGA | Packed-pixel 8 bpp | 1024x768 | 256 | | 116 | SVGA | Packed-pixel 16 bpp | 1024x768 | 32K | | 117 | SVGA | Packed-pixel 16 bpp | 1024x768 | 64K | | 118 <sup>(1)</sup> | SVGA | Packed-pixel 32 bpp | 1024x768 | 16M | | 107 | SVGA | Packed-pixel 8 bpp | 1280x1024 | 256 | | 119 <sup>(1)</sup> | SVGA | Packed-pixel 16 bpp | 1280x1024 | 32K | | 11A <sup>(1)</sup> | SVGA | Packed-pixel 16 bpp | 1280x1024 | 64K | | 11B <sup>(2)</sup> | SVGA | Packed-pixel 32 bpp | 1280x1024 | 16M | | 11C | SVGA | Packed-pixel 8 bpp | 1600x1200 | 256 | | 11D <sup>(1)</sup> | SVGA | Packed-pixel 16 bpp | 1600x1200 | 32K | | 11E <sup>(1)</sup> | SVGA | Packed-pixel 16 bpp | 1600x1200 | 64K | <sup>(1)</sup> Only possible with a frame buffer of 8 megabytes or more. #### **Mode Switching** The BIOS follows the procedure below when switching between video modes: - 1. Wait for the vertical retrace. - 2. Disable the video by using the **scroff** blanking bit (**SEQ1**<5>). - 3. Disable the video by using the **c2en** bit (**C2CTL**<0>) (*only if necessary*). - 4. Select the VGA or SVGA mode by programming the **mgamode** field of the **CRTCEXT3** register. - 5. If a text mode or VGA graphic mode is selected, program the VGA-compatible register to initialize the appropriate mode. - 6. Initialize the CRTC2 (See 'CRTC Programming' on page 4-70) (*only if necessary*). - 7. Initialize the CRTC (See 'CRTC Programming' on page 4-70). - 8. Initialize the DAC and the video PLL for proper operation. - 9. Initialize the frame buffer. - 10. Wait for the CRTC1 vertical retrace. - 11. Enable the video by using the **scroff** blanking bit. <sup>(2)</sup> Only possible with a frame buffer of 4 megabytes or more - 12. Wait for the CRTC2 vertical retrace. - 13. Use the c23n bit to enable the video. - Note: The majority of the registers required for initialization can be accessed via the I/O space. For registers that are not mapped through the I/O space, or if the I/O space is disabled, indirect addressing by means of the MGA\_INDEX and MGA\_DATA registers can be used. This would permit a real mode application to select the video mode, even if the MGABASE1 aperture is above 1M. #### 4.4 **Direct Frame Buffer Access** There are two memory apertures: the VGA memory aperture, and the MGABASE2 memory aperture #### **VGA Mode** The MGABASE2 memory aperture should not be used, due to constraints imposed by the frame buffer organization. The VGA memory aperture operates as a standard VGA memory aperture. •• Note: In VGA Mode, only 1 Mbyte of the frame buffer is accessible. The **Memory Page** bit *must* be set to '0'. ### **Power Graphic Mode** Both memory apertures can be used to access the frame buffer. The full frame buffer memory aperture provides access to the frame buffer without using any paging mechanism. The VGA memory aperture provides access to the frame buffer for real mode applications. The **Memory Page** bit provides an extension to the page register in order to allow addressing of the complete frame buffer. Accesses to the frame buffer are concurrent with the drawing engine, so there is no requirement to synchronize the process which is performing direct frame buffer access with the process which is using the drawing engine. - •• Note: The Matrox G400 has the capacity to perform data swapping for Big-Endian processors (the data swapping mode is selected by the **OPMODE** register's dirdatasiz<1:0> field). - •• *Note:* Plane write masks are *not* available during direct frame buffer accesses. # 4.5 Drawing in Power Graphic Mode This section explains how to program the Matrox G400's registers to perform various graphics functions. The following two methods are available: - Direct access to the register. In this case all registers are accessed directly by the host, using the address as specified in the register descriptions found in Chapter 3. - Pseudo-DMA. In this case, the addresses of the individual registers to be accessed are embedded in the data stream. Pseudo-DMA can be used in four different ways: - The General Purpose Pseudo-DMA mode can be used with any command. - The DMA Vector Write mode is specifically dedicated to polyline operations. - ILOAD operations always use Pseudo-DMA transfers for exchanging data with the frame buffer. - •• *Note:* Only *dword* accesses can be used when initializing the drawing engine. This is true for both direct register access and for Pseudo-DMA operation. # 4.5.1 Drawing Register Initialization Using General Purpose Pseudo-DMA The general purpose Pseudo-DMA operations are performed through the DMAWIN aperture in the MGA control register space, or in the 8 MByte Pseudo-DMA window. It is recommended that host CPU instructions be used in such a way that each transfer increments the address. This way, the PCI bridge can proceed using burst transfers (assuming they are supported and enabled). General Purpose Pseudo-DMA mode is entered when either the DMAWIN space or the 8 MByte Pseudo-DMA window is written to. The DMA sequence can be interrupted by writing to byte 0 of the **OPMODE** register; this mechanism can be used when the last packet is incomplete. The first dword written to the DMA window is loaded into the Address Generator. This dword contains indices to the next four drawing registers to be written, and the next four dword transfers contain the data that is to be written to the four registers specified. When each dword of data is transferred, the Address Generator sends the appropriate 8-bit index to the Bus FIFO. This 8-bit address corresponds to bits 13 and 8:2. Bit 13 represents the DWGREG1 range (refer to Table 2-3 on page 2-4). Bits 1:0 are omitted, since each register is a dword. All registers marked with the FIFO attribute in the register descriptions in Chapter 3 can be initialized in General Purpose Pseudo-DMA mode. When the fourth (final) index has been used, the next dword transfer reloads the Address Generator. ### **DMA General Purpose Transfer Buffer Structure** | 3 | 31 24 | 23 16 | 15 | 8 7 0 | | | |---|--------|-------|-------|-------|--|--| | 0 | indx3 | indx2 | indx1 | indx0 | | | | 1 | | dat | a 0 | | | | | 2 | | dat | a 1 | | | | | 3 | | dat | a 2 | | | | | 4 | data 3 | | | | | | | 5 | indx3 | indx2 | indx1 | indx0 | | | | 6 | | dat | a 0 | | | | | 7 | data 1 | | | | | | | 8 | data 2 | | | | | | | | | | | | | | | | | • | | | | | | | | | | | | | #### 4.5.2 Overview To understand how this programming guide works, please refer to the following explanations: - 1. All registers are presented in a table that lists the register's name, its function, and any comment or alternate function. - 2. The table for each *type* of object (for example, lines with *depth*, *solid* line, *constant-shaded* trapezoid) is presented as a module in a third-level subsection numbered, for example, as 4.5.4.2. - 3. The description of each *type* of object contains a representation of the **DWGCTL** register. The drawing control register illustration is repeated for each object *type* because it can vary widely, depending on the current graphics operation (refer to the **DWGCTL** description, which starts on page 3-132). #### **Legend for DWGCTL Illustrations:** - When a field *must be set to one of several possible values for the current operation*, it appears as plus signs (+), one for each bit in the field. The valid settings are listed underneath. - When a field *can be set to any of several possible valid values*, it appears as hash marks (#), one for each bit in the field. The values must still be valid for their associated operations. - When a field *must be set to a specific value* then that value appears. - 4. You must program the registers listed in the 'Global Initialization (All Operations)' section *for all graphics operations*. Once this initialization has been performed, you can select the various objects and object *types* and program the registers for them accordingly. # 4.5.3 Global Initialization (All Operations) You must initialize the following registers for all graphics operations: | Register | Function | Comment / Alternate Function | | | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | PITCH | Set pitch | Specify destination address linearization ( <b>iy</b> field) | | | | DSTORG | Determine screen origin | _ | | | | MACCESS | Set pixel format (8, 16, 24, 32 bpp), the Z precision (15, 16, 24, or 32 bits) and the stencil format (1 or 8 bits) and sets the dithering mode. | Some limitations apply. Dithering mode is used in the following primitives: (i) lines with depth, (ii) Gouraud shaded trapezoids, (iii) texture mapping, (iv) unformatted ILOAD. | | | | CXBNDRY | Left/right clipping limits | Can use <b>CXLEFT</b> and <b>CXRIGHT</b> instead | | | | YTOP | Top clipping limit | _ | | | | YBOT | Bottom clipping limit | _ | | | | PLNWT | Plane write mask | _ | | | | ZORG | Z origin position | Only required for depth operations | | | # 4.5.4 Line Programming The following subsections list the registers that must be specifically programmed for solid lines, lines that use a linestyle, and lines that have a depth component. Remember to program the registers listed in section 4.5.3 and subsection 4.5.5.1 first. •• *Note:* In order to start the drawing engine, the last register programmed *must* be accessed in the 1D00h-1DFFh range. # 4.5.4.1 Slope Initialization #### **Non Auto-init Lines** This type of line is initiated when the **DWGCTL** register's opcod field is set to either LINE\_OPEN or LINE\_CLOSE. A LINE\_CLOSE operation draws the last pixel of a line, while a LINE\_OPEN operation does not draw the last pixel. LINE\_OPEN is mainly used with polylines, where the final pixel of a given line is actually the starting pixel of the next line. This mechanism avoids having the same pixel written twice | Register | Function | Comment / Alternate Function | |----------|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AR0 | 2b <sup>(1)</sup> | _ | | AR1 | Error term: 2b - a - sdy | _ | | AR2 | Minor axis increment: 2b - 2a | _ | | SGN | Vector quadrant (2) | _ | | XDST | The x start position | _ | | YDSTLEN | The y start position and vector length | Can use <b>YDST</b> and <b>LEN</b> instead; <i>must</i> use <b>YDST</b> and <b>LEN</b> when destination address is linear (i.e. <b>ylin</b> = 1, see <b>PITCH</b> ) | <sup>(1)</sup> Definitions: a = max (|dY|, |dX|), b = min (|dY|, |dX|). ### **Auto-init Lines** <sup>(2)</sup> Sets major or minor axis and positive or negative direction for x and y. This type of line is initiated when the **DWGCTL** register's **opcod** field is set to either AUTOLINE\_OPEN or AUTOLINE\_CLOSE. Auto-init vectors *cannot be used* when the destination addresses are linear (**ylin** = 1). •• *Note:* Auto-init vectors are automatic lines whose major/minor axes and Bresenham parameters (these determine the exact pixels that a line will be composed of) do not have to be manually calculated by the user or provided by the host. | Register | Function | Comment / Alternate Function | |----------|-------------------------------|------------------------------------------| | XYSTRT | The x and y starting position | Can use AR5, AR6, XDST, and YDST instead | | XYEND | The x and y ending position | Can use AR0 and AR2 instead | #### 4.5.4.2 Solid Lines #### DWGCTL: | clipdis | transc | pattern | ı | bltn | noc | d | Reserved | | tra | ns | | | bo | р | | Reserved | shftzero | sgnzero | arzero | solid | zn | noc | de | linear | | atype | | ( | opo | od | | |---------|--------|---------|---|------|-----|---|----------|---|-----|----|---|---|----|---|---|----------|----------|---------|--------|-------|----|-----|----|--------|---|-------|---|---|-----|----|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # | 0 | 0 | 0 | 0 | 1 | 0 | 0 | # | # | # | # | # | # | # | # | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | + | + | + | + | ■ **opcod**: must be set to LINE\_OPEN, LINE\_CLOSE, AUTOLINE\_OPEN, or AUTOLINE\_CLOSE | Register | Function | Comment / Alternate Function | |----------|------------------|------------------------------| | FCOL | Foreground color | _ | ## 4.5.4.3 Lines That Use a Linestyle ### DWGCTL: | clipdis | | pattern | ı | oltn | noc | t | Reserved | | tra | ns | | | bo | эp | | Reserved | shftzero | sgnzero | arzero | solid | zn | noc | de | linear | | atype | | Ć | рс | od | | |---------|---|---------|---|------|-----|---|----------|---|-----|----|---|---|----|----|---|----------|----------|---------|--------|-------|----|-----|----|--------|---|-------|---|---|----|----|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # | # | 0 | 0 | 0 | 1 | 0 | 0 | # | # | # | # | # | # | # | # | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | + | + | + | + | ■ **opcod**: must be LINE\_OPEN, LINE\_CLOSE, AUTOLINE\_OPEN, or AUTOLINE\_CLOSE | Register | Function | Comment / Alternate Function | |----------|--------------------------------------------------------------------------------|-----------------------------------| | SHIFT | Linestyle length (stylelen), linestyle start point within the pattern (funcnt) | _ | | SRC0 | Linestyle pattern storage | _ | | SRC1 | Linestyle pattern storage | If <b>stylelen</b> is from 32-63 | | SRC2 | Linestyle pattern storage | If <b>stylelen</b> is from 64-95 | | SRC3 | Linestyle pattern storage | If <b>stylelen</b> is from 96-127 | | BCOL | Background color | If $transc = 0$ | | FCOL | Foreground color | _ | Note: To set up a linestyle, define the pattern you wish to use, then load it into the 128-bit source register (SRC3-0). Next, program SHIFT to indicate the length of your pattern minus 1 (stylelen). Finally, the SHIFT register's funcnt field is a count-down register with a wrap-around from zero to stylelen, which is used to indicate the point within the pattern at which you wish to start the linestyle. At the end of a line operation, funcnt points to the next value. For a polyline operation (LINE\_OPEN), the pixel style remains continuous with the next vector. With LINE\_CLOSE, the style does not increment with the last pixel. # **Linestyle Illustration** SHIFT: stylelen = 65, funcnt = 24 SRC0: srcreg0 = PIXEL\_STYLE(31:0) SRC1: srcreg1 = PIXEL\_STYLE(63:32) SRC2: srcreg2 = PIXEL\_STYLE(65:64) - The foreground color is written when the linestyle bit is '1' - The background color is written when the linestyle bit is '0' # 4.5.4.4 Lines with Depth ## DWGCTL: | clipdis | pattern | ı | oltn | noc | k | Reserved | tra | ns | | | bo | р | | Reserved | shftzero | sgnzero | arzero | solid | zn | no | de | linear | atype | | оро | cod | | |---------|---------|---|------|-----|---|----------|-----|----|---|---|----|---|---|----------|----------|---------|--------|-------|----|----|----|--------|-------|---|-----|-----|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | # | # | # | # | # | | | | | | # | # | # | 0 | | 1 | | | | ■ atype: must be either ZI or I ■ **opcod**: must be set to LINE\_OPEN, LINE\_CLOSE, AUTOLINE\_OPEN, or AUTOLINE\_CLOSE | Register | Function | Comment / Alternate Function | |---------------------------------------------------------------------------------|----------------------------------------------------------------------------|-------------------------------------------------------------------------| | ALPHACTRL | scrblendf, dstblendf,<br>alphamode, astipple, alpha<br>test mode, alphasel | must set aten = '0' | | ALPHASTART | The Alpha Start value | (1) | | ALPHAXINC | The Alpha Increment on the major axis | (1) | | ALPHAYINC | The Alpha Increment on the diagonal axis | (1) | | DR0 (if zwidth = 00 or 10)<br>DR2_Z32LSB, DR2_Z32MSB,<br>(if zwidth = 01 or 11) | The z start position | Only if zmode <> NOZCMP or atype = ZI | | DR2 (if zwidth = 00 or 10) DR2_Z32LSB, DR2_Z32MSB (if zwidth = 01 or 11) | The z major increment | " | | DR3 (if zwidth = 00 or 10) DR3_Z32LSB, DR3_Z32MSB (if zwidth = 01 or 11) | The z diagonal increment | " | | DR4 | Red start position | _ | | DR6 | Red increment on major axis | | | DR7 | Red increment on diagonal axis | _ | | DR8 | Green start position | _ | | DR10 | Green increment on major axis | _ | | DR11 | Green increment on diagonal axis | _ | | DR12 | Blue start position | _ | | DR14 | Blue increment on major axis | _ | | DR15 | Blue increment on diagonal axis | _ | | FCOL | Alpha value | Only if <b>pwidth</b> = 32, or <b>pwidth</b> = 16 and <b>dit555</b> = 1 | | FOGSTART | The Fog factor Start value | only if <b>fogen</b> $= 1$ | | Register | Function | Comment / Alternate Function | |------------|-------------------------------------------|----------------------------------------| | FOGXINC | The Fog factor Increment on major axis | " | | FOGYINC | The Fog factor Increment on diagonal axis | " | | FOGCOL | The Fog Color | 11 | | STENCIL | smsk, sref, swtmsk | Only if zwidth = '10' or zwidth = '11' | | STENCILCTL | smode, sfailop, szfailop, szpassop | Only if zwidth = '10' or zwidth = '11' | <sup>(1)</sup> Whenever a function in the ALPHACTRL register requires them, alphastart, alphaxinc, or alphayinc are programmed. - •• *Note:* That the MACCESS register's pwidth field must not be set to 24 bits per pixel (PW24) when drawing lines with depth. - ◆ *Note:* Table fogging is *not* supported in lines with depth. - •• Note: When drawing lines with depth, TDUALSTAGE0 and TDUALSTAGE1 must be programmed to '0' except for: TDUALSTAGE0.color0sel = '11' and TDUALSTAGE1.color1sel = '11'. This has no effect on the result. ## 4.5.4.5 Polyline/Polysegment Using Vector Pseudo-DMA mode The sequence for this operation is slightly different than the sequence for the other lines. First, the polyline primitive must be initialized: - The global initialization registers (see Global Initialization (All Operations) on page 4-31) must be set. - Solid lines can be selected by initializing the registers as explained in subsection 4.5.4.2. Lines with linestyle can be selected by initializing the registers as explained in subsection 4.5.4.3. In both cases, AUTOLINE\_OPEN or AUTOLINE\_CLOSE must be selected. - Bits 15-0 of the **OPMODE** register must be initialized to 0008h (for Little-Endian processors) or 0208h (for Big-Endian processors). It is important to access the **OPMODE** register (at least byte 0) since this will reset the state of the address generator. A 16-bit access is required (to prevent modification of the **dirDataSiz** field). The polyline/polysegment will begin when either the DMAWIN space or the 8 MByte Pseudo-DMA window is written to. The *first* dword that is transferred is loaded into the Address Generator. This dword contains one bit of 'address select' for each of the next 32 vector vertices to be sent to the drawing registers. These 32 bits are called the vector tags. The next 32 dword transfers contain the xy address data to be written to the drawing registers. When a tag bit is set to zero (0), the address generator will force the index to the one of the **XYSTRT** registers without setting the bit to start the drawing engine. When the tag bit is set to one (1), the address generator will force the index to the one of the **XYEND** registers with the flag set to start the drawing engine. When each dword of data is transferred, the Address Generator checks the associated tag bit and sends the appropriate 8-bit index to the Bus FIFO. When the 32nd (final) tag has been used, the next dword transfer reloads the Address Generator with the next 32 vector tags. The Pseudo-DMA sequence can be interrupted by writing to byte 0 of the **OPMODE** register; this mechanism can be used when the last packet is incomplete. #### **DMA Vector Transfer Buffer Structure** | 3 | 31 | 16 15 0 | |------|--------|---------| | 0 V | 731 | Vn | | 1 | Y0 | X0 | | 2 | Y1 | X1 | | 3 | Y2 | X2 | | : - | | | | n | Yn + 1 | Xn + 1 | | : | | : | | 31 | Y30 | X30 | | 32 | Y31 | X31 | | 33 V | 731 | Vn V0 | | 34 | Y0 | X0 | | 35 | Y1 | X1 | | 36 | Y2 | X2 | | : | | | # 4.5.5 Trapezoid / Rectangle Fill Programming The following subsections list the registers that must be specifically programmed for constant and Gouraud shaded, patterned, and textured trapezoids, including rectangle and span line fills. Remember to program the registers listed in section 4.5.3 and in the tables in subsection 4.5.5.1 first. •• *Note:* In order to start the drawing engine, the last register programmed *must* be accessed in the 1D00h-1DFFh range. ### 4.5.5.1 Slope Initialization Trapezoids, rectangles, and span lines consist of a flat edge at the top and bottom, with programmable side edge positions at the left and right. When such a primitive is displayed, the pixels at the top and left edge are actually drawn as part of the object, while the bottom and right edges exist just beyond the object's extents. This is done so that when a primitive is completed, the common 'continuity points' that result allow a duplicate adjacent primitive to be drawn without the necessity of re-initializing all of the edges. - Note: That a primitive may have an edge of zero length, as in the case of a triangle (in this case, FXRIGHT = FXLEFT). You could draw a series of joined triangles by specifying the edges of the first triangle, then changing only one edge for each subsequent triangle. - •• *Note:* For trapezoids with subpixel positioning, the **brkleft** bit in the **SGN** register and the **FXLEFT** must be programmed for the bottom-trap in case of a broken-left trapezoid. Figure 4-4: Drawing Multiple Primitives - solid lines represent left, top edges - dotted lines represent right, bottom edges # **Trapezoids** For trapezoid drawing, initialize the following registers: | Register | Function | Comment / Alternate Function | |----------|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AR0 | Left edge major axis increment: dYl yl_end - yl_start | _ | | AR1 | Left edge error term: errl $(\mathbf{sdxl} == XL_NEG)$ ? $dXl + dYl - 1 : - dXl$ | _ | | AR2 | Left edge minor axis increment: - dXl - xl_end - xl_start | _ | | AR4 | Right edge error term: errr $(\mathbf{sdxr} == XR_NEG)$ ? $dXr + dYr - 1 : - dXr$ | _ | | AR5 | Right edge minor axis increment: - dXr - xr_end - xr_start | _ | | AR6 | Right edge major axis increment: dYr yr_end - yr_start | _ | | SGN | Vector quadrant | _ | | FXBNDRY | Filled object x left and right coordinates | Can use <b>FXRIGHT</b> and <b>FXLEFT</b> | | YDSTLEN | The y start position and number of lines | Can use <b>YDST</b> and <b>LEN</b> instead; <i>must</i> use <b>YDST</b> and <b>LEN</b> when destination address is linear (i.e. <b>ylin</b> = 1, see <b>PITCH</b> ) | # **Rectangles and Span Lines** For rectangle and span line drawing, the following registers must be initialized: | Register | Function | Comment / Alternate Function | |----------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------| | FXBNDRY | Filled object x left and right coordinates | Can use <b>FXRIGHT</b> and <b>FXLEFT</b> | | YDSTLEN | The y start position and number of lines | Can use YDST and LEN instead;<br>must use YDST and LEN when destination address is linear (i.e. ylin = 1, see PITCH) | ## 4.5.5.2 Constant Shaded Trapezoids / Rectangle Fills #### **DWGCTL:** | | clipdis | transc | pattern | ŀ | oltn | noc | k | Reserved | | tra | ns | | | bo | ор | | Reserved | shftzero | sgnzero | arzero | solid | zn | no | de | linear | | atype | | | opo | od | | |--------|---------|--------|---------|---|------|-----|---|----------|---|-----|----|---|---|-----|----|---|----------|----------|---------|--------|-------|----|----|----|--------|---|-------|---|---|-----|----|---| | TD 4 D | ,, | _ | | | | | | ^ | | | | | | l . | | | _ | 4 | | | 4 | | _ | | _ | | | | _ | 4 | | _ | | TRAP | # | 1 | U | 0 | U | U | U | U | + | + | + | + | + | + | + | + | 0 | 1 | U | U | 1 | 0 | U | U | U | + | + | + | U | 1 | U | U | | RECT | # | 1 | 0 | 0 | 0 | 0 | 0 | 0 | + | + | + | + | + | + | + | + | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | + | + | + | 0 | 1 | 0 | 0 | ■ trans: if atype is BLK (block mode<sup>(1)</sup>), the transparency pattern is not supported - the value of trans must be '0000' ■ **bop**: uses any Boolean operation if **atype** is RSTR; if **atype** is BLK, **bop** must be loaded with '1100' ■ atype: can be RSTR, or BLK | Register | Function | Comment / Alternate Function | |----------|------------------|------------------------------| | FCOL | Foreground color | | •• *Note:* That the **MACCESS** register's **pwidth** field can be set to 24 bits per pixel (PW24) with the following limitations: • atype is RSTR or • forcol<31:24>, forcol<23:16>, forcol<15:8>, and forcol<7:0> are set to the same value # 4.5.5.3 Patterned Trapezoids / Rectangle Fills #### DWGCTL: | | clipdis | transc | pattern | ŀ | oltn | noc | t | Reserved | | tra | ns | | | bo | ор | | Reserved | shftzero | sgnzero | arzero | solid | zn | noc | de | linear | | atype | | , | opo | cod | 1 | |--------|---------|--------|---------|---|------|-----|---|----------|---|-----|----|---|---|----|----|---|----------|----------|---------|--------|-------|----|-----|----|--------|---|-------|---|---|-----|-----|---| | TD 4 D | ,, | | _ | _ | | | | ^ | | | | | | | | | ^ | | _ | _ | _ | _ | | _ | _ | | | | _ | | _ | _ | | TRAP | # | + | 0 | 0 | 0 | 0 | 0 | 0 | + | + | + | + | + | + | + | + | 0 | # | 0 | 0 | 0 | 0 | 0 | 0 | O | + | + | + | 0 | 1 | 0 | 0 | | RECT | # | + | 0 | 0 | 0 | 0 | 0 | 0 | + | + | + | + | + | + | + | + | 0 | # | 1 | 1 | 0 | 0 | 0 | 0 | 0 | + | + | + | 0 | 1 | 0 | 0 | ■ trans: if atype is BLK, the transparency pattern is not supported - the value of trans must be '0000' ■ **bop**: uses any Boolean operation if **atype** is RSTR; if **atype** is BLK, **bop** must be loaded with '1100' ■ atype: Can be RSTR, or BLK ■ **transc**: if **atype** is BLK, an opaque background is **not** supported - the value of **transc** must be '1' <sup>(1) &#</sup>x27;Block mode' refers to the high bandwidth block mode function of SGRAM. It should be used whenever possible for the fastest performance, although certain restrictions apply (see the **atype** field of the **DWGCTL** register on page 3-125). | Register | Function | Comment / Alternate Function | |----------|------------------------------------|-----------------------------------------| | PAT0 | Pattern storage in Windows format | Use SRC0, SRC1, SRC2, SRC3 for | | PAT1 | r attern storage in windows format | pattern storage in Little-Endian format | | SHIFT | Pattern origin offset | Only if <b>shftzero</b> = $0$ | | BCOL | Background color | Only if $transc = 0$ | | FCOL | Foreground color | | - •• *Note:* The **MACCESS** register's **pwidth** field can be set to 24 bits per pixel (PW24) with the following limitations: - atype is RSTR or - forcol<31:24>, forcol<23:16>, forcol<15:8>, and forcol<7:0> are set to the same value, and backcol<31:24>, backcol<23:16>, backcol<15:8>, and backcol<7:0> are set to the same value. #### **Patterns and Pattern Offsets** Patterns can be comprised of one of two 8 x 8 pattern formats (Windows, or Little-Endian). If required, you can offset the pattern origin for the frame buffer within the register (if no offset is required, program the **shftzero** bit to '1'). In the illustration on the left, the offset position is 5, 2. The corresponding register position's value is moved to the starting point of the pattern array. (This starting point is equivalent to an offset of 0,0.) Refer to the examples on the next page for more details. ### **Screen Representation** The examples below show how the data stored in the pattern registers is mapped into the frame buffer. The numbers inside the boxes represent the register bit positions that comprise the pattern. • Windows format (used to drive Microsoft Windows) stores the pattern in the **PAT0** and **PAT1** (page 3-161) registers. The following illustration shows the **PAT** register pattern usage for offsets of 0,0 and 5,2. Offset = 0,0 Windows Offset = 5,2 Windows | 0<br>1 | 0 | 1 | _ | | | | | | | | | 21 | COOL | dinate | 3 | | | |---------------|----|----|----|----|----|----|----|----|---------------|----|----|----|------|--------|----|----|----| | | | | 2 | 3 | 4 | 5 | 6 | 7 | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | 1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 0 | 18 | 17 | 16 | 23 | 22 | 21 | 20 | 1 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 1 | 26 | 25 | 24 | 31 | 30 | 29 | 28 | 2 | | <u>s</u> 2 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | <u>s</u> 2 | 34 | 33 | 32 | 39 | 38 | 37 | 36 | 3. | | Y coordinates | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | Y coordinates | 42 | 41 | 40 | 47 | 46 | 45 | 44 | 4: | | 2,000 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 | ນ.000 4 | 50 | 49 | 48 | 55 | 54 | 53 | 52 | 5 | | 5 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | <b>⊳</b> 5 | 58 | 57 | 56 | 63 | 62 | 61 | 60 | 5! | | 6 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 6 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | | 7 | 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 7 | 10 | 9 | 8 | 15 | 14 | 13 | 12 | 1 | • Little-Endian format (for non-Windows systems) stores the pattern in the **SRC0**, **SRC1**, **SRC2**, and **SRC3** registers (page 3-186). In this case, the patterning for each line must be duplicated within the register (this simplifies software programming for hardware requirements). Depending on the offset, some pattern bits may come from the original pattern byte, while others may come from the associated duplicate byte. The following illustration shows the **SRC** register pattern usage for offsets of 0,0 and 5,2. Offset = 0,0 Little-Endian Offset = 5,2 Little-Endian | | | | | X | coord | dinate | es. | | | | | | | X | coord | dinate | es. | | | |---------------|---|-----|-----|-----|-------|--------|-----|-----|-----|---------------|---|-----|-----|-----|-------|--------|-----|-----|-----| | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | • | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | | 0 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | 0 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | | | 1 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | | 1 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | | Si | 2 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | S | 2 | 69 | 70 | 71 | 72 | 73 | 74 | 75 | 76 | | Y coordinates | 3 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | Y coordinates | 3 | 85 | 86 | 87 | 88 | 89 | 90 | 91 | 92 | | coor | 4 | 64 | 65 | 66 | 67 | 68 | 69 | 70 | 71 | coor | 4 | 101 | 102 | 103 | 104 | 105 | 106 | 107 | 108 | | <b>X</b> | 5 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | * | 5 | 117 | 118 | 119 | 120 | 121 | 122 | 123 | 124 | | | 6 | 96 | 97 | 98 | 99 | 100 | 101 | 102 | 103 | | 6 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | | | 7 | 112 | 113 | 114 | 115 | 116 | 117 | 118 | 119 | | 7 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | - For both formats, the foreground color is written when the pattern bit is '1' - For both formats, the background color is written when the pattern bit is '0' #### Gouraud Shaded Trapezoids / Rectangle Fills 4.5.5.4 # **DWGCTL**: | | clipdis | transc | pattern | ŀ | oltn | noc | k | Reserved | | tra | ns | | | bo | ор | | Reserved | shftzero | sgnzero | arzero | solid | zn | 100 | de | linear | | atype | | , | opo | cod | l | |------|---------|--------|---------|---|------|-----|---|----------|---|-----|----|---|---|----|----|---|----------|----------|---------|--------|-------|----|-----|----|--------|---|-------|---|---|-----|-----|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | TRAP | # | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # | # | # | # | # | # | # | # | 0 | 1 | 0 | 0 | 0 | # | # | # | 0 | + | + | + | 0 | 1 | 0 | 0 | | RECT | # | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # | # | # | # | # | # | # | # | 0 | 1 | 1 | 1 | 0 | # | # | # | 0 | + | + | + | 0 | 1 | 0 | 0 | must be either ZI or I ■ atype: | Register | Function | Comment / Alternate Function | |----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|----------------------------------------------------------------------------| | ALPHACTRL | scrblendf, dstblendf,<br>alphamode, astipple, alpha<br>test mode, alphasel | must set aten = '0' | | ALPHASTART | The Alpha Start value | (1) | | ALPHAXINC | The Alpha Increment on the x-axis | (1) | | ALPHAYINC | The Alpha Increment on the yaxis | (1) | | <b>DR0</b> (if zwidth = 00 or 10) <b>DR0_Z32LSB, DR0_Z32MSB</b> (if zwidth = 01 or 11) | The z start position | Only if zmode <> NOZCMP or atype = ZI | | <b>DR2</b> (if zwidth = 00 or 10)<br><b>DR2_Z32LSB, DR2_Z32MSB</b><br>(if zwidth = 01 or 11) | The z increment for x | " | | <b>DR3</b> (if zwidth = 00 or 10)<br><b>DR3_Z32LSB, DR3_Z32MSB</b><br>(if zwidth = 01 or 11) | The z increment for y | " | | DR4 | Red start position | _ | | DR6 | Red increment on x axis | _ | | DR7 | Red increment on y axis | _ | | DR8 | Green start position | _ | | DR10 | Green increment on x axis | _ | | DR11 | Green increment on y axis | _ | | DR12 | Blue start position | _ | | DR14 | Blue increment on x axis | _ | | DR15 | Blue increment on y axis | _ | | FCOL | Alpha value | Only if <b>pwidth</b> = 32,<br>or <b>pwidth</b> = 16 and <b>dit555</b> = 1 | | FOGSTART | The Fog factor Start value | only if <b>fogen</b> = 1 | | Register | Function | Comment / Alternate Function | |------------|-------------------------------------------|----------------------------------------| | FOGXINC | The Fog factor Increment on major axis | " | | FOGYINC | The Fog factor Increment on diagonal axis | " | | FOGCOL | The Fog Color | " | | STENCIL | smsk, sref, swtmsk | Only if zwidth = '10' or zwidth = '11' | | STENCILCTL | smode, sfailop, szfailop,<br>szpassop | Only if zwidth = '10' or zwidth = '11' | <sup>(1)</sup> Whenever a function in the **ALPHACTRL** register requires them, **alphastart**, **alphaxinc**, or **alphayinc** are programmed. <sup>◆</sup> *Note:* When drawing Gouraud shaded trapezoids, the MACCESS register's pwidth field must *not* be set to 24 bits per pixel (PW24). *Note:* When drawing Gouraud shaded trapezoids, **TDUALSTAGE0** and **TDUALSTAGE1** *must* be programmed to '0' *except* for **TDUALSTAGE0.color0sel** = '11' and **TDUALSTAGE1.color1sel** = '11'. This has *no* effect on the result. # 4.5.5.5 Texture Mapping # Texture mapping (single texturing) (default) # **DWGCTL** | | clipdis | transc | pattern | k | oltn | noc | k | Reserved | | tra | ns | | | bo | эp | | Reserved | shftzero | sgnzero | arzero | solid | zn | no | de | linear | | atype | | | opo | cod | l | |------|---------|--------|---------|---|------|-----|---|----------|---|-----|----|---|---|----|----|---|----------|----------|---------|--------|-------|----|----|----|--------|---|-------|---|---|-----|-----|---| | TDAD | ш | _ | _ | ^ | _ | ^ | _ | ^ | ш | ш | ш | ш | ш | ш | ш | ш | 0 | 1 | ^ | ^ | ^ | ш | ш | ш | ^ | | | | ^ | 4 | 4 | | | TRAP | # | U | U | U | U | U | U | 0 | # | # | # | # | # | # | # | # | U | ı | U | U | 0 | # | # | # | U | + | + | + | 0 | ı | | U | | RECT | # | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # | # | # | # | # | # | # | # | 0 | 1 | 1 | 1 | 0 | # | # | # | 0 | + | + | + | 0 | 1 | 1 | 0 | ■ atype: must be either ZI or I | Register | Function | Comment / Alternate Function | |--------------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------| | ALPHASTART | The Alpha Start value | see note | | ALPHAXINC | The Alpha Increment on the x-axis | see note | | ALPHAYINC | The Alpha Increment on the y-axis | see note | | ALPHACTRL | srcblendf, dstblendf, alphamode, astipple, alpha test mode, alphasel | _ | | DR0 (if zwidth = 00 or 10)<br>DR0_Z32LSB, DR0_Z32MSB<br>(if zwidth = 01 or 11) | Z start position | Only if <b>zmode</b> <><br>NOZCMP or <b>atype</b> =<br>ZI | | DR2 (if zwidth = 00 or 10) DR2_Z32LSB, DR2_Z32MSB (if zwidth = 01 or 11) | Z increment for x | " | | DR3 (if zwidth = 00 or 10) DR3_Z32LSB, DR3_Z32MSB (if zwidth = 01 or 11) | Z increment for y | " | | DR4 | Red start value | Only if modulate or decal is used | | DR6 | Red increment on x axis | " | | DR7 | Red increment on y axis | " | | DR8 | Green start value | " | | DR10 | Green increment on x axis | " | | DR11 | Green increment on y axis | " | | DR12 | Blue start value | " | | DR14 | Blue increment on x axis | " | | DR15 | Blue increment on y axis | " | | FCOL | Alpha value | Only if <b>pwidth</b> = 32, or <b>pwidth</b> = 16 and <b>dit555</b> = 1. | | FOGCOL | The Fog color | only if <b>fogen</b> = 1 | | FOGSTART | The Fog factor Start value | only if <b>fogen</b> = 1 | | FOGXINC | The Fog factor increment for x | " | | FOGYINC | The Fog factor increment for y | " | | SPECRSTART | Specular Red Start value | only if <b>specen</b> = 1 | | SPECRXINC | Specular Red Increment on major axis | " | | Register | Function | Comment /<br>Alternate Function | |--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------| | SPECRYINC | Specular Red Increment on diagonal axis | " | | SPECGSTART | Specular Green Start value | " | | SPECGXINC | Specular Green Increment on major axis | " | | SPECGYINC | Specular Green Increment on diagonal axis | " | | SPECBSTART | Specular Blue Start value | " | | SPECBXINC | Specular Blue Increment on major axis | " | | SPECBYINC | Specular Blue Increment on diagonal axis | " | | STENCIL | smsk, sref, swtmsk | Only if zwidth = '10' or zwidth = '11' | | STENCILCTL | smode, sfailop, szfailop, szpassop | Only if zwidth = '10' or zwidth = '11' | | ТВИМРЕМТ | bumpmatfmt, bumplsfmt, bumploffset, bumplscale | Only with bump mapping | | ТВИМРМАТ | bumpmat00, bumpmat01, bumpmat10, bumpmat11 | Only with bump mapping | | TDUALSTAGE0 | Color and alpha processing unit 0 programming | See note | | TDUALSTAGE1 | Color and alpha processing unit 1 programming | See note | | TEXBORDERCOL | Texture Border Color | Only if <b>borderen</b> = 1,<br>sampling must be in<br><b>clampmode</b> (U or V) | | TEXCTL | Texel width, texture pitch, texture alpha key, texture alpha mask, palette select, decal with color key, clampmode, tmodulate, strans, itrans, alpha overwrite and keying, alpha extend | _ | | TEXCTL2 | decalblend, idecal, decaldis, decalmod, ckstransdis, borderen, specen | _ | | TEXFILTER | minfilter, maxfilter, filteralpha, fthres, mapnb | _ | | TEXHEIGHT | Texture height, height mask, and round-up factor | _ | | TEXORG | Texture base address and origin of map 0 | _ | | TEXORG1 | | Only when mip-<br>mapping or planar mode<br>is used. | | TEXORG2 | See the following note. | " | | TEXORG3 | | Only when mip-<br>mapping is used. | | TEXORG4 | | " | | TEXTRANS | Transparency color key, texture keying mask | | | TEXTRANSHIGH | Transparency color key high, texture keying mask high | _ | | TEXWIDTH | Texture width, width mask, and round-up factor | _ | | TMR0 | s/wc increment for x | _ | | TMR1 | s/wc increment for y | _ | | TMR2 | t/wc increment for x | _ | | Register | Function | Comment /<br>Alternate Function | |----------|----------------------|---------------------------------| | TMR3 | t/wc increment for y | _ | | TMR4 | q/wc increment for x | _ | | TMR5 | q/wc increment for y | _ | | TMR6 | s/wc start value | _ | | TMR7 | t/wc start value | _ | | TMR8 | q/wc start value | _ | - •• *Note:* The MACCESS register's pwidth field must *not* be set to 24 bits per pixel (PW24) when drawing texture map trapezoids. - ◆ *Note:* If **tformat** = TW4 or TW8, the color palette *must* be initialized. - •• *Note:* Only clamp mode is supported when programming the **twmask** or **thmask** with a value which is not a power of 2. The fields **tw** and **th** *must* be programmed with a "power-of-2" value but s/wc and t/wc can be scaled accordingly. - **◆** *Note:* Each texture can be located in the frame buffer or in the system memory. - •• *Note:* Whenever a function in the **ALPHACTRL** register requires them, **alphastart**, **alphayinc** are programmed. - •• *Note:* When using any mip\_mapping filtering mode, the **thmask**, **twmask** fields *must* be programmed with a multiple of 16 1. - ◆ *Note:* When using any mip\_mapping filtering mode, the **tpitchext** field *must* be programmed with a multiple of 16. - •• *Note:* In single texturing mode, *only* one stage of the alpha processing unit (Figure 3-1) and color processing unit (Figure 3-1) is used. **TDUALSTAGE0** *must* be programmed with the following limitations: - colorblend must be set to '0'. - **coloralphasel** can be set to '000' (diffuse), '001' (fcol) or '010' (current texture) only. - **coloralphasel** can be set to '00' (diffuse), or '01' (fcol) or '10' (fcol) only. - alpa0arg2sel can be set to '00' (diffuse) or '01' (fcol) only. **TDUALSTAGE1** *must* be programmed with the same values as **TDUALSTAGE0**. - •• *Note:* Rev. A only: TDUALSTAGE0 and TDUALSTAGE1 *must* be programmed to '0' to work properly, otherwise unexpected results may occur. - •• *Note:* Rev. A only: Due to a limitation in bump mapping for Rev.0, the luminance *must* be multipled by 4 using *one* of the following solutions: - program color0modbright (in the TDUALSTAGE0) to "10" - use a larger value for the field **bumplscale** and /or the field **bumplsfmt** to createa a luminance value 4 times bigger than the calue intially expected. #### **Texture Trap** When a texture is being created by the drawing engine, a DWGSYNC must be sent to the engine so that the entire texture will be in memory before the next texture\_trap can begin. ## Addressing for an 11-LOD Mip-Map The following defines an OFFSET from one TEXORG. Since all subsequent LOD's are scaled down by 4, it is simple to obtain every offset from the programmed OFFSET. offsetselect[3:0]: Select from which texorg the offset is to be used. offset[26:5]: Base offset selected from **offsetselect**. The following table shows the supported **offsetselect** combinations: | offsetselect[3:0] | offset | |-------------------|---------| | ,0000, | - | | 'XXX1' | TEXORG1 | | 'XX10' | TEXORG2 | | 'X100' | TEXORG3 | | '1000' | TEXORG4 | Where offsetselect[3:0] is mapped on the following bits: offsetselect[0] = TEXORG[2] offsetselect[1] = TEXORG1[2] offsetselect[2] = TEXORG2[2] offsetselect[3] = TEXORG3[2] •• *Note:* The field offset must be programmed with the restriction that only one bit can be at '1'. The following tables demonstrate how the base address is calculated depending on the offsetselect and mip-map. The signal mip-map represents the selected map for each pixel: *Table 4-2: offsetselect = '0000'* | Mip-Map | Map Base Origin | |---------|-----------------| | ,0000, | TEXORG | | '0001' | TEXORG1 | | '0010' | TEXORG2 | | '0011' | TEXORG3 | | '0100' | TEXORG4 | | '0101' | not supported | | ⊃ | | | '1111' | | Table 4-3: offsetselect = 'XXX1' | Mip-Map | Map Base Origin | |-----------|--------------------------------------------------------------------| | '0000' | TEXORG | | '0001' | TEXORG + (TEXORG1) | | '0010' | TEXORG + (TEXORG1 TEXORG1 >> 2) | | '0011' | TEXORG + (TEXORG1 TEXORG1 >> 2 TEXORG1 >> 4) | | | | | '1010' | TEXORG + (TEXORG1 TEXORG1 >> 2 TEXORG1 >> 4 TEXORG1 >> 18) | | $\supset$ | not supported | | '1111' | not supported | # *Table 4-4: offsetselect = 'XX10'* | Mip-Map | Map Base Origin | |-----------|--------------------------------------------------| | '0000' | TEXORG | | '0001' | TEXORG1 | | '0010' | TEXORG1 + (TEXORG2) | | '0011' | TEXORG1 + (TEXORG2 TEXORG2 >> 2) | | '0100' | TEXORG1 + (TEXORG2 TEXORG2 >> 2 TEXORG2 >>4) | | | | | '0101' | TEXORG1 + (TEXORG2 TEXORG2 >> 2 TEXORG2 >> 4 | | 0101 | TEXORG2 >> 16) | | $\supset$ | not supported | | '1111' | not supported | *Table 4-5: offsetselect = 'X100'* | Mip-Map | Map Base Origin | |-----------|--------------------------------------------------| | ,0000, | TEXORG | | '0001' | TEXORG1 | | '0010' | TEXORG2 | | '0011' | TEXORG2 + (TEXORG3) | | '0100' | TEXORG2 + (TEXORG3 TEXORG3 >> 2) | | '0101' | TEXORG2 + (TEXORG3 TEXORG3 >> 2 TEXORG3 >>4) | | $\supset$ | | | '1010' | TEXORG2 + (TEXORG3 TEXORG3 >> 2 TEXORG3 >> 4 | | 1010 | TEXORG3 >> 14) | | | not supported | | '1111' | not supported | *Table 4-6: offsetselect = '1000'* | Mip-Map | Map Base Origin | |---------|--------------------------------------------------| | '0000' | TEXORG | | '0001' | TEXORG1 | | '0010' | TEXORG2 | | '0011' | TEXORG3 | | '0100' | TEXORG3 + (TEXORG4) | | '0101' | TEXORG3 + (TEXORG4 TEXORG4 >> 2) | | '0110' | TEXORG3 + (TEXORG4 TEXORG4 >> 2 TEXORG4 >>4) | | | | | '1010' | TEXORG3 + (TEXORG4 TEXORG4 >> 2 TEXORG4 >> 4 | | 1010 | TEXORG4 >> 12) | | ••• | not supported | | '1111' | not supported | Note: In the equation: physical\_address = a + c Where, for example, offsetselect = '1000' for each term is defined with the following ranges: .a = TEXORG3 .d = (TEXORG4) | (TEXORG4 >> 2) | (TEXORG4 >> 4) | ... | (TEXORG4 >> 12) .c = d(31:5) | d(4:2) .physical\_address(31:5) .a(31:5) .d(31:2) .c(31:5) ## **Texture mapping (dual texturing)** In Dual Texturing, **dualtex** in **TEXCTL2** should be programmed to '1'. In this mode, there are two cascaded color and alpha processing units (stage0 and stage 1). There are no restrictions in programming **TDUALSTAGE0** and **TDUALSTAGE1**, and they are programmed independently. Dual Texturing is done in two programming steps: First step: - tmap0dis *must* have the value '0' - program all the registers pertaining to the operation being executed - program the registers specific to texture 1, when different than texture 0 (see the following list) #### Second step: - tmap0dis must have the value '1' - program only the registers specific to texture 1, when different than texture 0 (see following list) List of registers specific to textures: | TMR0 | TEXORG | TEXBORDERCOL | |------|-----------|-----------------| | TMR1 | TEXORG1 | TEXCTL | | TMR2 | TEXORG2 | TEXCTL2 | | TMR3 | TEXORG3 | TEXFILTER | | TMR4 | TEXORG4 | <b>TEXTRANS</b> | | TMR5 | | TEXTRANSHIGH | | TMR6 | TEXWIDTH | ALPHACTRL | | TMR7 | TEXHEIGHT | | | TMR8 | | | - ◆ *Note:* Start the drawing engine at the end of the second programming step only. - ◆ *Note:* For the second alpha test, the following fields will take the value of the second pass of the register programming: in ALPHACTRL: alphasel atref atmode astipple alphamode dstblenddf srcblendf •• *Note:* The following fields should have the same value for both programming passes: in **TEXCTL**: tmodulate in **TEXCTL2**: bumpmapping decalblend dualtex specen tablefog •• *Note:* In dual texturing, use diffuse and specular values in dual blender stage 1 (TDUALSTAGE1) *only* when multiplication or addition (either color or alpha) is programmed for stage 0. When in dual texturing mode stage 1, do not program - TDUALSTAGE1.color1alphasel to '000' (diffuse) - TDUALSTAGE1.color1arg2sel to '00' (diffuse) or '01' (specular) - TDUALSTAGE1.alpha1arg2sel to 00 (diffuse) unless one of the following is programmed for stage 0: • TDUALSTAGE0.color0sel is programmed to '10' (ADD) or '11' (MUL) or • TDUALSTAGE0.alpha0sel is programmed to '10' (ADD) or '11' (MUL) Diffuse and specular can be used in dual blender stage 0 (TDUALSTAGE0); they can also be used in single texturing. ## **Texture mapping (bump mapping)** In Bump Mapping the **TEXCTL2** fields **dualtex** and **bumpmapping** must be set to '1'. - ◆ *Note:* Only RGB is affected by the luminance. Alpha is unchanged. - •• *Note:* This operation will be done by the dual texture blender. The luminance (L) is input Tn-1 of stage0's alpha (of the color processing unit). # 4.5.5.6 Zbuffer Direct Access Procedure when Zbuffer is in AGP Space Do the following when the Zbuffer needs to be accessed directly when the Zbuffer is in AGP space. This procedure will ensure that direct access will pass after all accesses done by the graphics engine. When direct access is needed: - 1. Software must add this primitive to force all Zdata to be pushed into the AGP space memory: - follow the programming for a TRAP RECTANGLE with DWGCTL.trans = '1111' - DSTORG.dstmap = 1 and DSTORG.dstacc = 1 - FXBNDRY = 0 - YDSTLEN = 1 + GO This primitive sends an AGP FLUSH command to the AGP bus. The drawing engine will return idle only when the acknowledge to this command has been received by the drawing engine. 2. Software then polls for bus mastering and dwgengsts to ensure that the drawing engine is idle. It then processes the direct access. ## **4.5.5.7 TABLEFOG** Write into memory a texture which will be used as a LUT for the fogging factor. The alpha part of the texture (LUT) will be used as the fogging factor. **FOGCOL** has to be programmed with the fogging color. The fogging module should be active. **FOGSTART**, **FOGXINC**, and **FOGYINC** do not need to be programmed since they are *not* used in table fogging. ## **Texture Trap** To do table fogging while doing texture mapping, the engine should be programmed for dual texturing. - Texture 0 will be used as a texture - Texture 1 will be used as the fogging factor LUT (Alpha). Programming *must* include: - DWGCTL2.opcod = TEXTURE TRAP - TEXTCTL2.dualtex = 1 Dual texturing - TEXCTL2.tablefog = 1 Alpha of the texture as fogging factor - TEXCTL.tformat = TW8A (for texture 1) - •• *Note:* In this mode, dual-texturing in one pass is *not* possible. #### **Trap Non-Texture** To do table fogging without using a texture the engine should be programmed fo single texturing. Texture will be used as the fogging factor LUT (alpha). Programming must include: • DWGCTL.opcod = TEXTURE TRAP For fogging factor • TEXTCTL2.dualtex = 0 Fogging factor on both TMAPs • TEXCTL2.tablefog = 1 Alpha of the texture as fogging factor # MGI Confidential • TEXCTL.tformat = TW8A (for texture) • ALPHACTRL.alphasel = 01 Alpha from interpolation In this configuration, the texture is not used as is, but as the fogging factor (alpha). The following registers must be correctly initialized: ALPHASTART DR4 DR8 DR12 ALPHAXINC DR6 DR10 DR14 ALPHAYINC DR7 DR11 DR15 #### 4.5.5.8 Video Scaler As a video scaler, the perspective effect must be disabled, this is done by programming the following register. - TMR4 = 0x000000000 - TMR5 = 0x000000000 - TMR8 = 0x00010000 When used as a video scaler, texture engine quality depends on the filter selected. Bilinear filtering will give quality output at good speed. Mip-mapping will give high quality but with lower speed. The texture engine supports both up and down scaling. The video source can be any format defined by texformat, but typically a video source will be one of these formats. #### 4.5.5.9 Video Scaler When the selected filter includes *bilinear* filtering (a least 4 texels are needed to generate a pixel) and the texture width is *greater* than 512 texels, and the texel format is TW32 or TW422, the texture cache fills before the end of a texture line resulting in cache misses for the next line. Performances can be affected due to the extra memory bandwidth required. One way to improve performance is to split the operation into two parts and keep the texels mapped at 512 or less for each TRAP. For the second TRAP, re-adjust the S/wc and T/wc parameters to continue scanning the texture where the first TRAP stopped. Use the same precision as that of the hardware for the second trap's S and T start values or artifacts could occur. - Note: This technique may *not* always improve the drawing speed depending on memory bandwidth available at the time of the operation. - **Example:** The texture is a 720x720 YUV422 image that is to be drawn with a 1:1 ratio. ### FIRST TEXTURE\_TRAP: | Tw | $= \log 2(1024)$ | |---------|------------------| | Th | $= \log 2(1024)$ | | Sstart | = 0 | | Sxinc | = 1/1024 | | Syinc | = 0 | | Tstart | = 0 | | Txinc | = 0 | | Tyinc | = 1/1024 | | YDST | = 0 | | LENGTH | = 720 | | FXLEFT | = 0 | | FXRIGHT | = 512 | # **SECOND TEXTURE\_TRAP:** Sstart = 512 \* Sxinc Tstart = 0 YDST = 0 LENGTH = 720 FXLEFT = 512 FXRIGHT = 720 # 4.5.6 Sub-Pixel Trapezoids ## **DWGCTL** | clipdis | | pattern | ı | oltr | noc | d | Reserved | | tra | ns | | | bo | р | | Reserved | shftzero | sgnzero | arzero | solid | zn | 100 | de | linear | | atype | | | opo | od | l | |---------|---|---------|---|------|-----|---|----------|---|-----|----|---|---|----|---|---|----------|----------|---------|--------|-------|----|-----|----|--------|---|-------|---|----------|-----|----|---| | | | | | | | | F | | _ | | | | | | | | | | | | | | | | | | | <u> </u> | | | | | # | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # | # | # | # | # | # | # | # | 0 | 1 | 0 | 0 | 0 | # | # | # | 0 | + | + | + | + | + | + | + | ■ atype: must be either ZI or I ■ opcod: must be TRAP or TEXTURETRAP | Register | Field | Function | Comment /<br>Alternate Function | |----------|-------|-----------------------------------------------------------------------------------------|---------------------------------| | YDST | | 1/16 precise sub-pixel Y coordinate of the initial vertex (smallest Y value)(xy format) | 16.4 bit signed | | FXLEFT | | 1/16 precise sub-pixel X coordinate of the initial left edge vertex | 16.4 bit signed | | AR2 | | 1/16 or 1/32 precise sub-pixel delta X of the left edge | 18 bit signed | | AR0 | | 1/16 or 1/32 precise sub-pixel delta Y of the left edge | 18 bit signed | | FXRIGHT | | 1/16 precise sub-pixel X coordinates of the initial right edge vertex | 16.4 bit signed | | AR5 | | 1/16 or 1/32 precise sub-pixel delta X of the right edge | 18 bit signed | | AR6 | | 1/16 or 1/32 precise sub-pixel delta Y of the right edge | 18 bit signed | | SGN | | Vector quadrant | | | | bl | Defines the "broken' topology of the triangle (set to '1' for broken left triangle) | | | | sse | Sub-pixel engine setup the shared edge (according to <b>bl</b> ) | | | Register | Field | Function | Comment /<br>Alternate Function | | | | | | |----------|------------|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | | sbe | Sub-pixel engine setup the broken edge (according to <b>bl</b> ) | | | | | | | | | us | APU updates the start values in sub-pixel steps mode. | The start values are multiplied by 16 (integer value) after this adjustment, before the trap is processed. | | | | | | | | brkleft | APU updates the start values in integer steps mode | | | | | | | | | subpixen | Enables sub-pixel mode. | | | | | | | | | centersnap | Sample pixel at half integer coordinates (set to '1' for OpenGL mode, otherwise D3D mode) | | | | | | | <sup>••</sup> *Note:* The **SGN** register starts the sub-pixel engine when the **subpixen** is set to '1'. The sub-pixel engine re-programs the registers in the following table depending on **sse**, **sbe**, and **bl** in **SGN**. | sse | sbe | bl | adjusted registers | |-----|-----|----|----------------------------------------------------------| | 0 | 0 | X | None | | 0 | 1 | 0 | YDST, FXRIGHT, AR4, AR5, AR6, SGN | | 0 | 1 | 1 | YDST, FXLEFT, AR0, AR1, AR2, SGN | | 1 | 0 | 0 | YDST, FXLEFT, AR0, AR1, AR2, SGN | | 1 | 0 | 1 | YDST, FXRIGHT, AR4, AR5, AR6, SGN | | 1 | 1 | X | YDST, FXLEFT, AR0, AR1, AR2, FXRIGHT, AR4, AR5, AR6, SGN | All ALU increments must be programmed with 1/16 precise values when the **us** bit is set to '1'. The start value will be multiplied by 16 (integer value) after the sub-pixel adjustment, and before the trap is processed. | Register | Function | Comment /<br>Alternate Function | |--------------------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------------------------| | LENGTH | Number of lines | | | ALPHASTART | The Alpha Start value | | | ALPHAXINC | 1/16 precise sub-pixel alpha increment for X | | | ALPHAYINC | 1/16 precise sub-pixel alpha increment for Y | | | ALPHACTRL | srcblendf, dstblendf, alphamode, astipple, alpha test mode, alphasel | _ | | DR0 (if zwidth = 00 or 10)<br>DR0_Z32LSB, DR0_Z32MSB<br>(if zwidth = 01 or 11) | Z start position | Only if <b>zmode</b> <><br>NOZCMP or <b>atype</b> =<br>ZI | | DR2 (if zwidth = 00 or 10)<br>DR2_Z32LSB, DR2_Z32MSB<br>(if zwidth = 01 or 11) | 1/16 precise sub-pixel Z increment for X | " | <sup>••</sup> *Note:* If **sbe** and **sse** are set to '0', the sub-pixel engine is *not* started, therefore, the values in the working registers will *not* be correct. | Register | Function | Comment /<br>Alternate Function | |----------------------------------------------------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------------------------------| | <b>DR3</b> (if zwidth = 00 or 10)<br><b>DR3_Z32LSB, DR3_Z32MSB</b><br>(if zwidth = 01 or 11) | 1/16 precise sub-pixel Z increment for Y | >> | | DR4 | Red start value | When opcod = TEXTURE_TRAP: only if modulate or decal is used | | DR6 | 1/16 precise sub-pixel red increment for X | " | | DR7 | 1/16 precise sub-pixel red increment for Y | " | | DR8 | Green start value | " | | DR10 | 1/16 precise sub-pixel green increment for X | " | | DR11 | 1/16 precise sub-pixel green increment for Y | " | | DR12 | Blue start value | " | | DR14 | 1/16 precise sub-pixel blue increment for X | " | | DR15 | 1/16 precise sub-pixel blue increment for Y | " | | FCOL | Alpha value | Only if <b>pwidth</b> = 32,<br>or <b>pwidth</b> = 16 and<br><b>dit555</b> = 1. | | FOGCOL | The Fog color | only if <b>fogen</b> = 1 | | FOGSTART | The Fog factor Start value | only if <b>fogen</b> = 1 | | FOGXINC | 1/16 precise sub-pixel fog factor increment for X | " | | FOGYINC | 1/16 precise sub-pixel fog factor increment for Y | " | | SPECRSTART | Specular Red Start value | Only if opcod = TEXTURE_TRAP and specen = 1 | | SPECRXINC | 1/16 precise sub-pixel specular red increment for X | " | | SPECRYINC | 1/16 precise sub-pixel specular red increment for Y | 27 | | SPECGSTART | Specular Green Start value | " | | SPECGXINC | 1/16 precise sub-pixel specular green increment for X | >> | | SPECGYINC | 1/16 precise sub-pixel specular green increment for Y | >> | | SPECBSTART | Specular Blue Start value | " | | SPECBXINC | 1/16 precise sub-pixel specular blue increment for X | " | | SPECBYINC | 1/16 precise sub-pixel specular blue increment for Y | " | | STENCIL | smsk, sref, swtmsk | Only if zwidth = '10' or zwidth = '11' | | STENCILCTL | smode, sfailop, szfailop, szpassop | Only if zwidth = '10' or zwidth = '11' | | Register | Function | Comment /<br>Alternate Function | |--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------| | ТВИМРМАТ | bumpmat00, bumpmat01, bumpmat10, bumpmat11 | Only if opcod = TEXTURE_TRAP and bump mapping | | ТВИМРЕМТ | bumpmatfmt, bumplsfmt, bumploffset, bumplscale | 27 | | TEXBORDERCOL | Texture Border Color | Only if opcod = TEXTURE_TRAP and borderen = 1, sampling must be in clampmode (U or V) | | TEXCTL | Texel width, texture pitch, texture alpha key, texture alpha mask, palette select, decal with color key, clampmode, tmodulate, strans, itrans, alpha overwrite and keying, alpha extend | Only if opcod = TEXTURE_TRAP | | TEXCTL2 | decalblend, idecal, decaldis, decalmod, ckstransdis, borderen, specen | _ | | TEXFILTER | minfilter, maxfilter, filteralpha, fthres, mapnb | _ | | TEXHEIGHT | Texture height, height mask, and round-up factor | _ | | TEXORG | Texture base address and origin of map 0 | _ | | TEXORG1 | | Only if opcod = TEXTURE_TRAP and mip-mapping or planar mode is used. | | TEXORG2 | See mip-mapping in texture trapezoids | " | | TEXORG3 | | Only if opcod = TEXTURE_TRAP and mip-mapping is used. | | TEXORG4 | | " | | TEXTRANS | Transparency color key, texture keying mask | Only if opcod = TEXTURE_TRAP | | TEXTRANSHIGH | Transparency color key high, texture keying mask high | _ | | TEXWIDTH | Texture width, width mask, and round-up factor | _ | | TMR0 | 1/16 precise sub-pixel s/wc increment for X | | | TMR1 | 1/16 precise sub-pixel s/wc increment for Y | _ | | TMR2 | 1/16 precise sub-pixel t/wc increment for X | | | TMR3 | 1/16 precise sub-pixel t/wc increment for Y | _ | | TMR4 | 1/16 precise sub-pixel q/wc increment for X | _ | | TMR5 | 1/16 precise sub-pixel q/wc increment for Y | _ | | TMR6 | s/wc start value | _ | | TMR7 | t/wc start value | _ | | TMR8 | q/wc start value | _ | <sup>••</sup> *Note:* All valid restrictions for trapezoids or texture mapped trapezoids are also valid for subpixel trapezoids. ## 4.5.7 Bitblt Programming The following subsections list the registers that must be specifically programmed for Bitblt operations. Remember to program the registers listed in section 4.5.3 and subsection 4.5.7.1 first. Also, the last register you program must be accessed in the 1D00h-1DFFh range in order to start the drawing engine. #### 4.5.7.1 Address Initialization ### **XY Source Addresses** | Register | Function | Comment / Alternate Function | |----------|------------------------------------------|----------------------------------| | AR0 | Source end address | The last pixel of the first line | | AR3 | Source start address | _ | | AR5 | Source y increment | _ | | FXBNDRY | Destination boundary (left and right) | Can use FXRIGHT and FXLEFT | | DSTORG | Origin of the destination | _ | | SRCORG | Origin of the same source surface | _ | | YDSTLEN | The y start position and number of lines | Can use YDST and LEN instead | #### **Linear Source Addresses** | Register | Function | Comment / Alternate Function | |----------|------------------------------------------|------------------------------------------------------------------------------------------------------------------| | AR0 | Source end address | The last pixel of the source | | AR3 | Source start address | _ | | FXBNDRY | Destination boundary (left and right) | Can use FXRIGHT and FXLEFT | | SRCORG | Origin of the source surface | _ | | YDSTLEN | The y start position and number of lines | Must use <b>YDST</b> and <b>LEN</b> when destination address is linear (i.e. <b>ylin</b> = 1, see <b>PITCH</b> ) | <sup>◆</sup> *Note:* AR0 comprises 22 bits, therefore, a maximum of 4 Mpixels can be blitted. ### **Patterning Operations** | Register | Function | Comment / Alternate Function | |----------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FXBNDRY | Destination boundary (left and right) | Can use FXRIGHT and FXLEFT | | YDSTLEN | | Can use <b>YDST</b> and <b>LEN</b> instead; <i>must</i> use <b>YDST</b> and <b>LEN</b> when destination address is linear (i.e. <b>ylin</b> = 1, see <b>PITCH</b> ) | # 4.5.7.2 Two-operand Bitblts ## **DWGCTL**: | | clipdis | transc | pattern | k | oltn | noc | k | Reserved | | tra | ns | | | bo | оp | | Reserved | shftzero | sgnzero | arzero | solid | zn | noc | de | linear | | atype | | | opo | cod | 1 | |------|---------|--------|---------|---|------|-----|---|----------|---|-----|----|---|---|----|----|---|----------|----------|---------|--------|-------|----|-----|----|--------|---|-------|---|---|-----|-----|---| | XY | # | + | 0 | | Λ | 1 | Λ | Λ | # | # | # | # | # | # | # | # | 0 | 1 | | 0 | 0 | 0 | | Λ | ^ | 0 | Λ | 1 | 1 | Λ | 0 | Λ | | Λ1 | # | + | U | U | U | | U | U | # | # | # | # | # | # | # | # | U | ' | + | U | U | 0 | U | U | U | U | U | ' | ' | U | U | U | | LIN. | # | + | 0 | 0 | 1 | 1 | 1 | 0 | # | # | # | # | # | # | # | # | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | ■ transc: *must* be '0' if the MACCESS register's pwidth field is set to 24 bits/pixel (PW24) | Register | Function | Comment / Alternate Function | |----------|------------------------|------------------------------------------------| | SGN | Vector quadrant (1) | Only needs to be set when <b>sgnzero</b> = '0' | | FCOL | Transparency color key | Only when <b>transc</b> = '1' | | BCOL | Color key plane mask | Only when <b>transc</b> = '1' | $<sup>^{\</sup>left(1\right)}$ Sets major or minor axis and positive or negative direction for x and y. ## 4.5.7.3 Color Patterning 8 x 8 ### **DWGCTL:** | clipdis | transc | pattern | . 1 | bltn | noc | d | Reserved | | tra | ns | | | bo | р | | Reserved | shftzero | sgnzero | arzero | solid | zn | no | de | linear | | atype | | ( | opo | cod | l _ | | |---------|--------|---------|-----|------|-----|---|----------|---|-----|----|---|---|----|---|---|----------|----------|---------|--------|-------|----|----|----|--------|---|-------|---|---|-----|-----|-----|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # | + | 1 | 0 | 0 | 1 | 0 | 0 | # | # | # | # | # | # | # | # | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | ■ transc: must be '0' if the MACCESS register's pwidth field is set to 24 bits/pixel (PW24) | Register | Function | Comment / Alternate Function | |----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------| | AR0 | When <b>pwidth</b> = PW8, PW16, or PW32:<br><b>AR0</b> <21:3> = <b>AR3</b> <21:3><br><b>AR0</b> <2:0> = <b>AR3</b> <2:0> + 4<br>When <b>pwidth</b> = PW24:<br><b>AR0</b> <21:0> = <b>AR3</b> <21:0> + 7 | _ | | AR3 | Pattern address + x offset + (y offset * 32) | _ | | AR5 | 32 | _ | | FCOL | Transparency color key | Only when <b>transc</b> = '1' | | BCOL | Color key plane mask | Only when <b>transc</b> = '1' | Note: The AR3 register performs a dual function: it sets the pattern's address, and it is also used to determine how the pattern will be pinned in the destination. Refer to 'Patterns and Pattern Offsets' on page 4-39; color patterning is performed in a similar manner to monochrome patterning (except that the SHIFT register is not used for pinning). - **Note:** 8, 16, 32 bit/pixel pattern storage hardware restrictions: - The first pixel of the pattern must be stored at a pixel address module 256 + 0, 8, 16, or 24. - Each line of 8 pixels is stored continuously in memory for each pattern, but there must be a difference of 32 in the pixel address between each line of the pattern. To do this efficiently, four patterns should be stored in memory in an interleaved manner, in a block of 4 x 8 x 8 pixel locations. The following table illustrates such a pattern storage (the numbers in the table represent the pixel addresses, modulo 256): | | | | | F | atte | ern | 0 | | | | | F | Patte | ern | 1 | | | | | F | Patt | ern | 2 | | | | | F | Patte | ern | 3 | | | |--------|---------|-----|---|---|------|-----|---|---|-----|-----|---|----|-------|-----|----|----|-----|-----|----|----|------|-----|----|----|-----|-----|----|----|-------|-----|----|----|-----| | | Pixels: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | | 0 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | | 1 | 32 | | | | | | | 39 | 40 | | | | | | | 47 | 48 | | | | | | | 55 | 56 | | | | | | | 63 | | | 2 | 64 | | | | | | | 71 | 72 | | | | | | | 79 | 80 | | | | | | | 87 | 88 | | | | | | | 95 | | es: | 3 | 96 | | | | | | | 103 | 104 | | | | | | | 111 | 112 | | | | | | | 119 | 120 | | | | | | | 127 | | Lines: | 4 | 128 | | | | | | | 135 | 136 | | | | | | | 143 | 144 | | | | | | | 151 | 152 | | | | | | | 159 | | | 5 | 160 | | | | | | | 167 | 168 | | | | | | | 175 | 176 | | | | | | | 183 | 184 | | | | | | | 191 | | | 6 | 192 | | | | | | | 199 | 200 | | | | | | | 207 | 208 | | | | | | | 215 | 216 | | | | | | | 223 | | | 7 | 224 | | | | | | | 231 | 232 | | | | | | | 239 | 240 | | | | | | | 247 | 248 | | | | | | | 255 | - **Note:** 24 bit/pixel pattern storage hardware restrictions: - The first pixel of the pattern must be stored at a pixel address module 256 + 0, or 16. - Each line of 8 pixels is stored continuously in memory for each pattern, but there must be a difference of 32 in the pixel address between each line of the pattern. To do this efficiently, two patterns should be stored in memory in an interleaved manner, in a block of 2 x 16 x 8 pixel locations. The following table illustrates such a pattern storage (the numbers in the table represent the pixel addresses, modulo 256): | | | | | | | | | F | Patte | ern | 0 | | | | | | | | | | | | | I | Patt | ern | 1 | | | | | | | |--------|---------|-----|---|---|---|---|---|---|-------|-----|---|----|----|----|----|----|-----|-----|----|----|----|----|----|----|------|-----|----|----|----|----|----|----|-----| | ľ | Pixels: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | | 0 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | | 1 | 32 | | | | | | | | | | | | | | | 47 | 48 | | | | | | | | | | | | | | | 63 | | | 2 | 64 | | | | | | | | | | | | | | | 79 | 80 | | | | | | | | | | | | | | | 95 | | es: | 3 | 96 | | | | | | | | | | | | | | | 111 | 112 | | | | | | | | | | | | | | | 127 | | Lines: | 4 | 128 | | | | | | | | | | | | | | | 143 | 144 | | | | | | | | | | | | | | | 159 | | | 5 | 160 | | | | | | | | | | | | | | | 175 | 176 | | | | | | | | | | | | | | | 191 | | | 6 | 192 | | | | | | | | | | | | | | | 207 | 208 | | | | | | | | | | | | | | | 223 | | | 7 | 224 | | | | | | | | | | | | | | | 239 | 240 | | | | | | | | | | | | | | | 255 | # 4.5.7.4 BitBlts With Expansion (Character Drawing) 1 bpp DWGCTL: ■ trans: if atype is BLK, the transparency pattern is *not* supported - the value of trans must be '0000' ■ bop: uses any Boolean operation if atype is RSTR; if atype is BLK, must be loaded with '1100' ■ **bltmod**: can be BMONOLEF *or* BMONOWF ■ atype: can be RSTR or BLK ■ transc: if atype is BLK, an opaque background is *not* supported - the value of transc must be '1' | Register | Function | Comment / Alternate Function | |----------|------------------|------------------------------| | BCOL | Background color | Only when transc = '0' | | FCOL | Foreground color | _ | **►►** Note: The MACCESS register's pwidth field can be set to 24 bits per pixel (PW24) with the following limitations: • atype is RSTR • forcol<31:24>, forcol<23:16>, forcol<15:8>, and forcol<7:0> are set to the same value, and backcol<31:24>, backcol<23:16>, backcol<15:8>, and backcol<7:0> are set to the same value. # 4.5.7.5 BitBlts With Expansion (Character Drawing) 1 bpp Planar DWGCTL: | clipdis | | pattern | ı | oltr | noc | d | Reserved | | tra | ns | | | bo | ор | | Reserved | shftzero | sgnzero | arzero | solid | zn | noc | de | linear | | atype | | | opo | od | I | |---------|---|---------|---|------|-----|---|----------|---|-----|----|---|---|----|----|---|----------|----------|---------|--------|-------|----|-----|----|--------|---|-------|---|---|-----|----|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # | # | 0 | 0 | 0 | 0 | 1 | 0 | # | # | # | # | # | # | # | # | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | # | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | Register | Function | Comment / Alternate Function | |----------|------------------|-------------------------------| | SHIFT | Plane selection | _ | | BCOL | Background color | Only when <b>transc</b> = '0' | | FCOL | Foreground color | _ | •• *Note:* For **MACCESS** the planar bitblts are *not* supported with 24 bits/pixel (PW24). # 4.5.8 ILOAD Programming The following subsections list the registers that must be specifically programmed for ILOAD (image load: Host $\rightarrow$ RAM) operations. You must take the following steps: **Step 1.** Initialize the registers. Remember to program the registers listed in section 4.5.3 and subsection 4.5.8.1. Depending on the type of operation you wish to perform, you must also program the registers in subsection 4.5.8.2 or subsection 4.5.8.3. - **Step 2.** The last register you program must be accessed in the 1D00h-1DFFh or 2000h-2DFFh range in order to start the drawing engine. - **Step 3.** Write the data in the appropriate format to either the DMAWIN or 8 MByte Pseudo-DMA memory ranges. After the drawing engine is started, the next successive BFIFO locations are used as the image data until the ILOAD is completed. Since the ILOAD operation generates the addresses for the destination, the addresses of the data are not used while accessing the DMAWIN or 8 MByte Pseudo-DMA window. It is recommended that host CPU instructions be used in such a way that each transfer increments the address. This way, the PCI bridge can proceed using burst transfers (assuming they are supported and enabled). - •• Note: It is important to transfer the exact number of pixels expected by the drawing engine, since the drawing engine will not end the ILOAD operation until all pixels have been received. A deadlock will result if the host transfers fewer pixels than expected to the drawing engine (the software assumes the transfer is completed, but meanwhile the drawing engine is waiting for additional data). However, if the host transfers more pixels than expected, the extra pixels will be interpreted by the drawing engine as register accesses. - •• *Note:* The ILOAD command must not be used when no data is transferred. The total number of dwords to be transferred will differ, depending on whether or not the source is linear: ■ When the source is *linear*: the data is padded at the end of the source. $$Total = INT ((psiz * width * Nlines + 31) / 32)$$ ■ When the source is *not linear*: the data is padded at the end of every line. $$Total = INT ((psiz * width + 31) / 32) * Nlines$$ #### Legend: Total: The number of dwords to transfer width: The number of pixels per line to write Nlines: The number of lines to write psiz: The source size, according to Table 4-8 Table 4-7: ILOAD Source Size | bltmod | pwidth | psiz | |----------|-------------|------| | | PW8 | 8 | | DECOL | PW16 | 16 | | BFCOL | PW24 | 24 | | | PW32 | 32 | | BMONOLEF | <del></del> | 1 | | BMONOWF | _ | 1 | | BU24RGB | _ | 24 | | BU24BGR | _ | 24 | | BU32RGB | _ | 32 | | BU32BGR | _ | 32 | ## 4.5.8.1 Address Initialization ### **Linear Addresses** | Register | Function | Comment / Alternate Function | |----------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OPMODE | Data format | A 16-bit access is required to prevent modification of the <b>dirDataSiz</b> field (bits 17:16), since direct frame buffer access may be concurrent | | AR0 | Total number of source pixels - 1 | _ | | AR3 | Must be 0 | _ | | FXBNDRY | Destination boundary (left and right) | Can use <b>FXLEFT</b> and <b>FXRIGHT</b> | | YDSTLEN | The y start position and length | Can use <b>YDST</b> and <b>LEN</b> instead; <i>must</i> use <b>YDST</b> and <b>LEN</b> when destination address is linear (i.e. <b>ylin</b> = 1, see <b>PITCH</b> ) | ## **XY Addresses** | Register | Function | Comment / Alternate Function | |----------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OPMODE | Data format | A 16-bit access is required to prevent modification of the <b>dirDataSiz</b> field (bits 17:16). | | AR0 | Number of pixels per line - 1 | _ | | AR3 | Must be 0 | _ | | AR5 | Must be 0 | _ | | FXBNDRY | Destination boundary (left and right) | Can use <b>FXLEFT</b> and <b>FXRIGHT</b> | | YDSTLEN | The y start position and length | Can use <b>YDST</b> and <b>LEN</b> instead; <i>must</i> use <b>YDST</b> and <b>LEN</b> when destination address is linear (as in: <b>ylin</b> = 1, see <b>PITCH</b> ) | ## 4.5.8.2 ILOAD of Two-operand Bitblts ### **DWGCTL**: | | clipdis | transc | pattern | . 1 | bltr | noc | t | Reserved | | tra | ns | | | bo | р | | Reserved | shftzero | sgnzero | arzero | solid | zn | noc | de | linear | | atype | | ( | opo | cod | | |---|---------|--------|---------|-----|------|-----|---|----------|---|-----|----|---|---|----|---|---|----------|----------|---------|--------|-------|----|-----|----|--------|---|-------|---|---|-----|-----|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Γ | # | + | 0 | + | + | + | + | 0 | # | # | # | # | # | # | # | # | 0 | 1 | + | 0 | 0 | 0 | 0 | 0 | + | 0 | 0 | 1 | 1 | 0 | 0 | 1 | ■ **transc:** must be '0' if the **MACCESS** register's **pwidth** field is set to 24 bits/pixel (PW24); must be '0' when the **bltmod** field is anything other than BFCOL ■ **bltmod**: for a linear source, must be BFCOL. For an xy source, can be any of the following: BFCOL, BU32BGR, BU32RGB, BU24BGR, or BU24RGB. ■ **sgnzero**: can be set to '0' when **bltmod** is BFCOL, or when the **MACCESS** register's **pwidth** field is PW32; otherwise, must be '1' ■ linear: for an xy source, must be '0'; for a linear source, must be '1' | | Function | Comment / Alternate Function | |------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FCOL | Foreground color | For the BU32BGR and BU32RGB formats, depending on the <b>MACCESS</b> register's <b>pwidth</b> setting, the following bits from <b>FCOL</b> are used: PW32: Bits 31:24 originate from <b>forcol</b> <31:24> PW16: Bit 15 originates from <b>forcol</b> <15> when <b>dit555</b> = 1 | | SGN | Scanning direction | Must be set only when <b>sgnzero</b> = '0' | | FCOL | Transparency color key | Only when <b>transc</b> = '1' | | BCOL | Color key plane mask | Only when <b>transc</b> = '1' | There are some restrictions in the data formats that are supported for this operation Table 4-8 shows all the valid format combinations. The structure of the buffers to be transferred is defined for each data format (as shown in the 'Pixel Formats' illustrations starting on page 4-9). Table 4-8: ILOAD Supported Formats | Processor Type | bltmod | dmaDataSiz | pwidth | Data Format | |----------------|---------|------------------|--------|-------------| | | | | PW8 | 8-bit A | | | BFCOL | ·00 <sup>,</sup> | PW16 | 16-bit A | | | BFCOL | 00 | PW24 | 24-bit A | | | | | PW32 | 32-bit A | | | | | PW8 | 24-bit A | | | BU24RGB | '00' | PW16 | 24-bit A | | | | | PW32 | 24-bit A | | Little-Endian | | | PW8 | 24-bit B | | Little-Englan | BU24BGR | '00' | PW16 | 24-bit B | | | | | PW32 | 24-bit B | | | | | PW8 | 32-bit A | | | BU32RGB | '00' | PW16 | 32-bit A | | | | | PW32 | 32-bit A | | | | | PW8 | 32-bit B | | | BU32BGR | '00' | PW16 | 32-bit B | | | | | PW32 | 32-bit B | | | | '00' | PW8 | 8-bit B | | | BFCOL | '01' | PW16 | 16-bit B | | | | '10' | PW32 | 32-bit A | | | | | PW8 | 32-bit A | | Big-Endian | BU32RGB | '10' | PW16 | 32-bit A | | | | | PW32 | 32-bit A | | | | | PW8 | 32-bit B | | | BU32BGR | '10' | PW16 | 32-bit B | | | | | PW32 | 32-bit B | # 4.5.8.3 ILOAD with Expansion (Character Drawing) DWGCTL: | olindia | transc | pattern | ŀ | oltr | noc | t | Reserved | | tra | ns | | | bo | р | | Reserved | shftzero | sgnzero | arzero | solid | zn | noc | de | linear | | atype | | ( | opo | od | | |---------|--------|---------|---|------|-----|---|----------|---|-----|----|---|---|----|---|---|----------|----------|---------|--------|-------|----|-----|----|--------|---|-------|---|---|-----|----|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # | + | 0 | + | + | + | + | 0 | + | + | + | + | # | # | # | # | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | + | + | + | 1 | 0 | 0 | 1 | ■ **bltmod**: must be set to either BMONOLEF or BMONOWF ■ trans: if atype is BLK, the transparency pattern is not supported - the value of trans must be '0000' ■ bop: uses any Boolean operation if atype is RSTR; if atype is BLK, bop must be loaded with '1100' ■ atype: RSTR, or BLK ■ transc: if atype is BLK, an opaque background is *not* supported - the value of transc must be '1' | Register | Function | Comment / Alternate Function | |----------|------------------|-------------------------------| | BCOL | Background color | Only when <b>transc</b> = '0' | | FCOL | Foreground color | _ | • Note: The MACCESS register's pwidth field can be set to 24 bits per pixel (PW24) with the following limitations: - atype is either RPL or RSTR - forcol<31:24>, forcol<23:16>, forcol<15:8>, and forcol<7:0> are set to the same value, and backcol<31:24>, backcol<23:16>, backcol<15:8>, and backcol<7:0> are set to the same value. There are some restrictions in the data formats that are supported for this operation. Table 4-9 shows all the valid format combinations. The structure of the buffers to be transferred is defined for each data format (as shown in the 'Pixel Formats' illustrations starting on page 4-9). Table 4-9: Bitblt with Expansion Supported Formats | Processor Type | bltmod | dmaDataSiz | Data Format | |----------------|----------|------------|-------------| | Little-Endian | BMONOLEF | '00' | MONO A | | Little-Eliqian | BMONOWF | '00' | MONO B | | Big-Endian | BMONOWF | '00' | MONO C | ## 4.5.9 Loading the Texture Color Palette This operation is similar to a normal BITBLT or ILOAD operation. In this case, a source texture color palette is loaded into the destination 256 x 16 bpp LUT (Look-Up Table) that is used in texture mapping. Any portion of the LUT can be programmed independently. This color palette is used to perform color expansion during texture mapping when textures are in 4 or 8 bpp format. When 4 bpp textures are used, 16 palettes are available in the LUT. The choice of the palette used to do color expansion is determined by the **palsel** field of the **TEXCTL** register. #### DWGCTL: | | Reserved | transc | pattern | k | oltn | noc | t | Reserved | | tra | ns | | | bo | эp | | Reserved | shftzero | sgnzero | arzero | solid | zn | 100 | de | linear | | atype | | ( | opo | od | l | |--------|----------|--------|---------|---|------|-----|---|----------|---|-----|----|---|---|----|----|---|----------|----------|---------|--------|-------|----|-----|----|--------|---|-------|---|---|-----|----|---| | BITBLT | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | ILOAD | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | | Register | Function | Comment / Alternate Function | |----------|------------------------------------------------------------------------------------------------------|------------------------------| | AR0 | Source end address | _ | | AR3 | Source start address | _ | | PITCH | <b>iy</b> = 1024 | _ | | YDSTLEN | yval: Start position in the LUT (0 to 255) length: Number of locations to fill in the LUT (1 to 256) | _ | | SRCORG | Origin of the source | For BLIT only | | DSTORG | 0 | _ | | FXBNDRY | 0 | _ | | MACCESS | pwidth = PW16, tlutload = 1 | _ | | OPMODE | dmamod = 01,<br>dmadatsiz = 00 (Little-Endian)<br>dmadatsiz = 01 (Big-Endian) | For ILOAD only | •• Note: The PITCH and MACCESS registers are not normally modified during drawing operations, and may have to be re-programmed after this operation in order to return the drawing engine to its original state. •• Note: Expansion of the texture to a non-palettized format: After sending a GO to this primitive, a **DWGSYNC** must be sent to the engine so that all the texture will be in memory before another texture\_trap can begin. •• *Note:* The texture in TW4 and TW8 should be expended prior to mapping. This is done by drawing an intermediate texture-mapped trapezoid using the above texture and programming the registers in the following table: | Register | Field | Value | |-------------|-----------------|-------| | ALPHACTRL | alphamode | '01' | | | alphasel | ,00, | | | astipple | Ю, | | | aten | Ю, | | | dstblendf | ZERO | | | srcblendf | ONE | | MACCESS | dit555 | Ю, | | | fogen | Ю, | | | nodither | '1' | | | pwidth | PW16 | | TDUALSTAGE1 | alpha1arg1inv | Ю, | | | alpha1sel | ARG1 | | | color1arg1alpha | Ю, | | | color1arg1inv | Ю, | | | color1sel | ARG1 | | TEXCTL | tmodulate | Ю, | | TEXCTL2 | decalblend | Ю, | | | decaldis | Ю, | | | dualtex | '1' | | | map1 | Ю, | | | specen | Ю, | | TEXFILTER | filteralpha | Ю, | | | minfilter | NRST | | | magfilter | NRST | | TEXHEIGHT | map1 | Ю, | | TEXWIDTH | map1 | Ю, | #### **CRTC Programming** 4.6 The CRTC can be programmed in one of two modes: VGA Mode or Power Graphic Mode. The **mgamode** field of the **CRTCEXT3** register is used to select the operating mode. CRTC registers 0 to 7 can be write-protected by the **crtcprotect** field of the **CRTC11** register. In VGA Mode, all of the **CRTC** extension bits must be set to '0'. The **page** field of **CRTCEXT4** can be used to select a different page of RAM in which to write pixels. #### 4.6.1 **Horizontal Timing** **HDISPEN HBLANK HSYNC** Horizontal Display End Horizontal Total Start Horizontal blank End Horizontal Blank Start Horizontal Retrace End Horizontal Retrace Figure 4-5: CRTC Horizontal Timing In VGA Mode, the horizontal timings are defined by the following VGA register fields: | htotal<7:0> | Horizontal total. Should be programmed with the total number of displayed characters plus the non-displayed characters minus 5. | | | |---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | hdispend<7:0> | Horizontal display end. Should be loaded with the number of displayed characters minus 1. | | | | hblkstr<7:0> | Start horizontal blanking | | | | hblkend<6:0> | End horizontal blanking. Should be loaded with ( <b>hblkstr</b> + Horizontal Blank signal width) AND 3Fh. Bit 6 is not used in VGA Mode ( <b>mgamode</b> = 0) | | | | hsyncstr<7:0> | Start horizontal retrace | | | | hsyncend<4:0> | End horizontal retrace. Should be loaded with ( <b>hsyncstr</b> + Horizontal Sync signal width) AND 1Fh. | | | | hsyncdel<1:0> | Horizontal retrace delay | | | In Power Graphic Mode, the following bits are extended to support a wider display area: | htotal<8:0> | Horizontal total | |---------------|---------------------------| | hblkstr<8:0> | Start horizontal blanking | | hsyncstr<8:0> | Start horizontal retrace | The horizontal counter can be reset to **hsyncstr** (CRTC4) in Power Graphic Mode by a rising edge on the VIDRST pin, if the **hrsten** bit of the **CRTCEXT1** register is set to '1'. The units of the horizontal counter are *character clocks* for VGA Mode, or 8 pixels in Power Graphic Mode. The **scale** field of the **CRTCEXT3** register is used to bring the VCLK clock down to an 8 *pixel* clock. The suggested scale factor settings are shown in the following table: | Bits/Pixel | scale | |------------|-------| | 8 | ,000, | | 16 | '001' | | 24 | '010' | | 32 | '011' | ## 4.6.2 Vertical Timing Figure 4-6: CRTC Vertical Timing In VGA Mode, the vertical timings are defined by the following VGA register fields: | vtotal<9:0> | Vertical total. Should be programmed with the total number of displayed lines plus the non-displayed lines minus 2. | | |---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--| | vdispend<9:0> | Vertical display end. Should be loaded with the number of displayed lines minus 1. | | | vblkstr<9:0> | Start vertical blanking. The programmed value is one less than the horizontal scan line count at which the vertical blanking signal becomes active. | | | vblkend<7:0> | End vertical blanking. Should be loaded with ( <b>vblkstr</b> -1 + Vertical Blank signal width) AND FFh. | | | vsyncstr<9:0> | Start vertical retrace | | | vsyncend<3:0> | End vertical retrace. Should be loaded with ( <b>vsyncstr</b> + Vertical Sync signal width) AND 0Fh. | | | linecomp<9:0> | Line compare | | In Power Graphic Mode, the following fields are extended to support a larger display area: | vtotal<11:0> | Vertical total | |----------------|-------------------------| | vdispend<10:0> | Vertical display end | | vblkstr<11:0> | Vertical blanking start | | vsyncstr<11:0> | Start vertical retrace | | linecomp<10:0> | Line compare | The units of the vertical counter can be 1 or 2 scan lines, depending on the value of the **hsyncsel** bit of the **CRTC17** register. The vertical counter can be reset to **vsyncstr** (**CRTC10**) in Power Graphic Mode by the **VIDRST** pin if the **vrsten** bit of the **CRTCEXT1** register is set to '1'. The **vinten** and **vintclr** fields of the **CRTC11** register can be used to control the vertical interrupt. ## 4.6.3 Memory Address Counter In VGA Mode, the following registers are used to program the memory address counter and the cursor/underline circuitry: | startadd<15:0> | Start address | | |----------------|-----------------------------------------------------------------------------------------------------------------------|--| | offset<7:0> | Logical line width of the screen. This is programmed with the number of double or single words in one character line. | | | curloc<15:0> | Cursor location | | | prowscan<4:0> | Preset row scan | | | maxscan<4:0> | Maximum scan line | | | currowstr<4:0> | Row scan cursor begins | | | currowend<4:0> | Row scan cursor ends | | | curoff<4:0> | Cursor off | | | undrow<4:0> | Horizontal row scan where underline will occur | | | curskew<1:0> | Cursor skew control | | - The row scan counter can be clocked by the horizontal sync signal or by the horizontal sync signal divided by 2, depending on the value of the **conv2t4** (200 to 400 line conversion) field of the **CRTC9** register. - The memory address counter clock is controlled by **count4 (CRTC14)** and **count2 (CRTC17)**. These fields have no effect in Power Graphic Mode. - The memory address can be modified by the dword (CRTC14), wbmode, addwrap, selrowscan, and cms (CRTC17) fields. In Power Graphic Mode, the following fields are extended in order to support a larger display. | startadd<20:0> | Start address. | |----------------|------------------------------------------------------------------------------------------------------------| | offset<9:0> | Logical line width of the screen. This is programmed with the number of double slices in one display line. | - The display can be placed in interlace mode if the **interlace** bit of the **CRTCEXTO** register is set to '1'. - The curloc, prowscan, currowstr, currowend, curoff, undrow and curskew registers are not used in Power Graphic Mode. - The **maxscan** field of the **CRTC9** register is used to zoom vertically in Power Graphic Mode. - Horizontal zooming can be achieved by dividing the pixel clock period and re-programming the horizontal registers. ## 4.6.4 Programming in VGA Mode The VGA CRTC of the Matrox G400 chip conforms to VGA standards. The limitations listed below need only be taken into account when programming extended VGA modes. #### Limitations: - **htotal** must be greater than 0. - **vtotal** must be greater than 0. - htotal hdispend must be greater than 0 - htotal bytepan + 2 must be greater than hdispend - hsyncstr must be greater than hdispend + 2 #### **CRTC Latency Formulas** This section presents several rules that must be followed in VGA Mode in order to adhere to the latency constraints of the Matrox G400's CRTC. The display modes are controlled by the **SEQ1** register's **dotmode** and **dotclkrt** fields and the **ATTR10** register's **pelwidth** field as shown below: | Display Mode | dotmode | dotclkrt | pelwidth | cc | |-----------------------------------|---------|----------|----------|----| | Character mode: 8 | 1 | 0 | 0 | 8 | | Character mode: 9 | 0 | 0 | 0 | 9 | | Zoomed character: 16 | 1 | 1 | 0 | 16 | | Zoomed character: 18 | 0 | 1 | 0 | 18 | | Graphics (non-8 bit/pixel) | 1 | 0 | 0 | 8 | | Zoomed graphics (non-8 bit/pixel) | 1 | 1 | 0 | 16 | | Graphics (8 bit/pixel) | 1 | 0 | 1 | 4 | | Zoomed graphics (8 bit/pixel) | 1 | 1 | 1 | 8 | In VGA Mode, Tvclk is equivalent to Tpixclk. - 1. Tmclk >= 2 Tvclk - 2. (36)Tpixclk $\geq = (93)$ Tmclk (VGA TEXT MODE) (32)Tpixclk >= (57) Tmclk (VGA GRAPHICS MODE) - 3. HTOTAL HSYNCSTART >= (141)Tpix (VGA TEXT MODE) HTOTAL - HSYNCSTART >= (69)Tpix (VGA GRAPHICS MODE) - ◆ *Note:* In VGAMODE, both **HIPRILVL** and **MAXHIPRI** must be set to '000'. #### 4.6.5 **Programming in Power Graphic Mode** The horizontal and vertical registers are programmed as for VGA Mode, and they can use the CRTC extension fields. The memory address mapper must be set to byte mode and the **offset** register value (**CRTC13**) must be programmed with the following formula: $$offset = \frac{videopitch \times bpp \times fsplit}{128}$$ #### Where: - 'bpp' is the pixel width, expressed in bits per pixel - 'video pitch' is the number of pixels per line in the frame buffer (including pixels that are not visible - 'fsplit' = 2 in split mode; 1 in all other modes For example, for a 16 bit/pixel frame buffer at a resolution of 1280 x 1024 and a memconfig value of 01: **offset** = $$(1280 \times 16)/128 = 160$$ Depending on the pixel width (bpp), the video pitch *must* be a multiple of one of the following: | bpp | multiple of | |-----|-------------| | 8 | 16 | | 16 | 8 | | 24 | 16 | | 32 | 4 | The **startadd** field represents the number of pixels to offset the start of the display by: Depending on the pixel depth, the following *factor*s must be used: | bpp | factor | |-----|--------| | 8 | 8 | | 16 | 4 | | 24 | 8 | | 32 | 2 | For example, to program **startadd** to use an offset of 64 with a 16 bit/pixel frame buffer, **startadd** = 64/4 = 16. With a 24 bit/pixel frame buffer, **startadd** = 64/8 = 8. Note: When accessing the three-part startadd field, the portion which is located in CRTCEXTO must always be written; it must always be written after the other portions of startadd, which are located in CRTCC and CRTCD). The change of start address will take effect at the beginning of the next horizontal retrace following the write to CRTCEXTO. Display will continue at the next line, using the new startadd value. This arrangement permits page flipping at any line, with no tearing occurring within the line. To avoid tearing between lines within a frame, software can poll either **vcount** or the **vretrace** field of **INSTS1**, or use the VSYNC interrupt to update **CRTCEXT0** between frames. •• Note: The Attributes Controller (ATC) is not available in Power Graphic Mode. There is no overscan in Power Graphic mode, therefore: $$htotal + 5 == hblkend + 1$$ $hdispend + 1 == hblkstr + 1$ The End Horizontal Blank value must always be greater that **hsyncstr** + 1, so that the start address latch can be loaded before the memory address counter. A composite sync (block sync) can be generated on the HSYNC pin of the chip if the **csyncen** field of the **CRTCEXT3** register is set to '1'. The VSYNC pin will continue to carry the vertical retrace signal. - •• *Note:* The composite sync is always active low. The following values must be programmed in Power Graphic Mode. - hsyncdel = 0 - hdispskew = 0 - hsyncsel = 0 - bytepan = 0 - $\blacksquare$ conv2t4 = 0 - $\blacksquare$ dotclkrt = 0 - **dword** = 0, **wbmode** = 1 (refer to the 'Byte Access' table in the **CRTC17** register description) - $\blacksquare$ selrowscan = 1, cms = 1 #### Interlace Mode If interlace is selected, the offset value *must* be multiplied by 2. - The **vtotal** value must be the total number of lines (of both fields) divided by 2. For example, for a 525 line display, **vtotal** = 260. - The **vsyncstr** value must be divided by 2 - The **vblkstr** values must be divided by 2 - The **hvidmid** field must be programmed to become active exactly in the middle of a horizontal ### Zooming Horizontal zooming is achieved using the hzoom field of the **XZOOMCTRL** register. To implement the zoom function, pixels are duplicated within the DAC, and the memory address generator advances at a reduced rate. Vertical zooming is achieved by re-scanning a line 'n' times. Program the **CRTC9** register's **maxscan** field with the appropriate value, n-1, to obtain a vertical zoom. $\blacksquare$ For example, set **maxscan** = 3 to obtain a vertical zoom rate of x4. #### Limitations: - **htotal** *must* be greater than 0 (because of the delay registers on the **htotal** comparator) - htotal hdispend must be greater than 0 - In interlace mode, **htotal** must be equal to or greater than **hsyncend** + 1 - htotal bytepan + 2 must be greater than hdispend - $\blacksquare$ hsyncstr must be greater than hdispend + 2 - vtotal must be greater than 0 (because of the delay registers on the vtotal comparator) - In interlace mode, **vtotal** must be an even number - In HZOOM = 00, (Horizontal Total) MOD 8 *must not* be '7' - In HZOOM = 01, (Horizontal Total) MOD 16 *must not* be '15' - In HZOOM = 1X, (Horizontal Total) MOD 32 *must not* be '31' ## **CRTC Latency Formulas** This section presents several rules that must be followed in Power Graphic Mode in order to adhere to the latency constraints of the CRTC. ## >>> When the CRTC1 is in VGAMODE Set the following fields to "000". ``` HIPRILVL = "000" • MAXHIPRI = "000" • C2HIPRILVL = "000" • C2MAXHIPRI = "000" ``` ## >>> When the CRTC2 is in YUV or GRABBACK MODE Set the following fields to "000". ``` = "000" HIPRILVL • MAXHIPRI = "000" • C2HIPRILVL = "010" ``` #### • **C2MAXHIPRI** = "001" ## >>> When the CRTC1 and CRTC2 are in RGB MODE Tmclk = The number of nanoseconds in an MCLK cycle. (i.e. if MCLK = 143 MHz, then use 7 in the above equation) Tpix = The number of nanoseconds in a PIXCLK cycle. Tc2pix = The number of nanoseconds in a C2PIXCLK cycle. C1DEP = The number of CRTC1 pixels that fit into 128 bits. (depends on the color depth! i.e. at 32BPP use 4, at 8BPP use 16) C2DEP = The number of CRTC2 pixels that fit into 128 bits. (depends on the color depth! i.e. at 32BPP use 4, at 16BPP use 8) This resolution is a *violation* when ever you get a number *outside* the programming range of these fields (less than 0 or greater than 7). | HIPRILVL | MAXHIPRI | |-------------|----------| | 7, 6, 5, 4, | 2 | | 3, 2, 1 | 1 | | 0 | 0 | | C2HIPRILVL | C2MAXHIPRI | |-------------|------------| | 7, 6, 5, 4, | 2 | | 3, 2, 1 | 1 | | 0 | 0 | For a default setting use, • **HIPRILVL** = "000" • **MAXHIPRI** = "000" • C2HIPRILVL = "000" • C2MAXHIPRI = "000" ## 4.7 Video Interface ## 4.7.1 Operation Modes The Matrox G400's RAMDAC can operate in one of seven modes, depending on the values of the **mgamode** field of the **CRTCEXT3** register and the **depth** field of the **XMULCTRL** RAMDAC register, as shown below: | mgamode | depth | Mode Selected | |---------|-------|-------------------------| | 0 | 000 | VGA | | 1 | 000 | Pseudo Color (BPP8) | | 1 | 001 | True Color (BPP15) | | 1 | 010 | True Color (BPP16) | | 1 | 011 | True Color (BPP24) | | 1 | 100 | Direct Color (BPP32DIR) | | 1 | 101 | True Color (BPP32PAL) | ## 4.7.1.1 VGA Mode In VGA mode, the data to be displayed comes from the Matrox G400's VGA Attribute Controller (ATC). The data from the ATC is used as an address for the three-LUT RAM. The pixel read mask can be applied to the data before it passes through the palette. The hardware cursor and keying functions are not supported in VGA mode. | Red LUT | P7 | P6 | P5 | P4 | P3 | P2 | P1 | P0 | |-----------|----|----|----|----|----|----|----|----| | Green LUT | P7 | P6 | P5 | P4 | P3 | P2 | P1 | P0 | | Blue LUT | P7 | P6 | P5 | P4 | P3 | P2 | P1 | P0 | - The frequency of the pixel PLL is determined by the **clksel** field of the VGA **MISC** register, which selects the proper set of registers for the PLL. The frequency can also be changed via the **XPIXPLLM**, **XPIXPLLN**, and **XPIXPLLP** registers. - Horizontal zooming is not supported in VGA mode. #### 4.7.1.2 Pseudo Color Mode In Pseudo Color mode (BPP8), the data from the memory is sent to the RAMDAC's internal FIFO via the memory controller. The data is then used as an address for the three-LUT RAM (as in VGA mode). A hardware cursor is available. - The pixel PLL should use register set 'C' register set, so as to not change the frequency of the VGA PLL sets. - Horizontal zooming is supported in pseudo color mode. #### 4.7.1.3 True Color Mode The four true color modes supported by Matrox G400 are BPP15, BPP16, BPP24, and BPP32PAL. In these modes, the pixel data from the internal RAMDAC's FIFO is mapped to the LUT addresses as shown in the following illustrations: #### 15-Bit True Color (BPP15) | Red LUT | P15 | 0 | 0 | P14 | P13 | P12 | P11 | P10 | |-----------|-----|---|---|-----|-----|-----|-----|-----| | Green LUT | P15 | 0 | 0 | P9 | P8 | P7 | P6 | P5 | | Blue LUT | P15 | 0 | 0 | P4 | P3 | P2 | P1 | P0 | ■ Bit 15 can be used as an overlay color (it selects another LUT table in the RAM) and can be masked out by the **alphaen** field of the **XGENCTRL** register (when at '0'). ## 16-bit True Color (BPP16) | Red LUT | 0 | 0 | 0 | P15 | P14 | P13 | P12 | P11 | |-----------|---|---|-----|-----|-----|-----|-----|-----| | Green LUT | 0 | 0 | P10 | P9 | P8 | P7 | P6 | P5 | | Blue LUT | 0 | 0 | 0 | P4 | P3 | P2 | P1 | P0 | ## 24-bit True Color (BPP24 and BPP32PAL) | Red LUT | P23 | P22 | P21 | P20 | P19 | P18 | P17 | P16 | |-----------|-----|-----|-----|-----|-----|-----|-----|-----| | Green LUT | P15 | P14 | P13 | P12 | P11 | P10 | P9 | P8 | | Blue LUT | P7 | P6 | P5 | P4 | P3 | P2 | P1 | P0 | In BPP24, the pixel data in the FIFO is unpacked before it enters the pixel pipeline, since each slice contains 5 1/3 24-bit pixels. In BPP32PAL, each pixel is 32 bits wide, but the eight MSBs are not used since they do not contain any color information. - The hardware cursor and horizontal zooming are supported. - Register set 'C' should be used to program the pixel PLL. ## 4.7.1.4 Direct Color Mode (BPP32DIR) In direct color mode, each pixel in the FIFO is composed of a 24-bit color portion and an 8-bit alpha portion. The 24-bit portion is sent directly to the RAMDAC (that is, each color is directly applied on each DAC input). The alpha portion of the pixel can be used for color keying (refer to the **XCOLKEY** register description) and may be displayed as a pseudo color pixel, depending on the outcome of the color comparison. - As in all non-VGA modes, the hardware cursor and horizontal zooming are available. - Register set 'C' should be used to program the pixel PLL. ## 4.7.2 Palette RAM (LUT) The Matrox G400's RAMDAC uses three 256x8 dual-ported RAMs for its color LUT. The use of a dual-ported RAM allows for asynchronous operation of the RAM, regardless of the current display state. The RAM is addressed by an 8-bit register/counter (**PALWTADD**) and selection among the three LUTs is done using a modulo 3 counter. To write the red, green, and blue components of a pixel to a location in the RAM, three writes to the **PALDATA** RAMDAC register must occur. Each byte will be transferred to the RAM when it is written. The modulo 3 counter will track the color being written. When the last byte (the blue component) of a RAM location is written, the address register is incremented, the modulo 3 counter is cleared, and the circuit is ready to write the red component of the next location. This allows the entire RAM to be updated with only one access to the **PALWTADD** register. To read a complete location in the palette RAM, three reads of the **PALDATA** RAMDAC register must occur. The palette address register will then be incremented to the next location. As with writes, the RAM can be completely read with only one write to the **PALRDADD**. Note: When changing the **ramcs** bit of the **XMISCCTRL** RAMDAC register, the pixel clock *must* be disabled (that is, **pixelkdis** = '1'). ## 4.7.3 Hardware Cursor A hardware cursor has been defined for all non-VGA modes. This cursor will be displayed over any other display information on the screen, either video or graphics. The cursor position is relative to the end of the blanking period. Refer to the **curposx** and **curposy** field descriptions (**CURPOS**). The cursor is not zoomed when horizontal and/or vertical zooming is selected. The cursor pattern is stored in the off-screen memory of the frame buffer at the location defined by the **XCURADDH** and **XCURADDL** RAMDAC registers. In Big Endian mode, the cursor pattern must be swapped according to section 4.1.7 before being written to the frame buffer. The **CURPOSY**, **CURPOSY**, **XCURADDH**, **XCURADDL** registers are double-buffered (that is, they are updated at the end of the vertical retrace period). In interlaced mode, if the cursor Y position is greater than 64, the first line of the cursor to appear on the screen will depend on the state of the internal field signal. - If the value of **curposy** is an odd number, the data for row 0 of the cursor will be displayed in the odd field. Rows 2, 4, ... 62 will then be displayed on the subsequent lines. The data for row 1 of the cursor will be displayed in the even field, followed by rows 3, 5, ... 63. - If the value of **curposy** is an even number, the data for row 0 of the cursor will be displayed in the even field. Rows 2, 4, ... 62 will then be displayed on the subsequent lines. The data for row 1 of the cursor will be displayed in the odd field, followed by rows 3, 5, ... 63. - If the value of **curposy** is less than 64, the cursor is partially located off the top of the screen. The first cursor row (row N) to be displayed will always be on scan line 0, which is the first line of the even field, and therefore the topmost scan line of the screen. Rows N+2, N+4, and so on will follow. The data in cursor row N+1 will be displayed on the first line of the odd field, followed by row N+3, N+5, and so on. In order for the cursor to function properly, the following rules must be respected: ``` Hblank_width (ns) >= 7 * Tmclk + 58 * Tmclk where: Tmclk = MCLK cycle time (ns) ``` # 4.7.4 Keying Functions Color keying can occur in any non-VGA color depth and resolution. The color key comparison occurs on the index of the palette. The corresponding color key and mask *must* match the pixel format used by the RAMDAC. These formats are shown in section 4.7.1.2 - 4.7.1.4. Refer to the **XCOLKEY** and **XCOLMSK** sets of registers for more details and to the Backend Scaler Programmer's Guide, section 4.10.4. In True Color BPP15 (1:5:5:5), the alpha bit can be disabled or enabled by using the ALPHAEN field of the XGENCTRL register. In Direct Color BPP32DIR (RGB-alpha), color keying comparisons can be done on the alpha byte and on the RGB bytes. The order of precedence is as follows: ``` if (alpha byte <> XCOLKEY) then display 'alpha-byte'; else if (RGB=XCOLKEY0) then display 'BackEnd Scaler Video'; else display 'RGB direct'; end if; ``` The keying on the alpha byte is not restricted to the Backend Scaler Video Window. Refer to the **XCOLKEY** and **XCOLMSK** registers for more details. #### 4.7.5 Zooming Horizontal zooming is achieved by changing the **hzoom** field of the **XZOOMCTRL** register. The CRTC1 Memory Address Counter clock will automatically be changed accordingly. No other CRTC1 register need be changed. The supported zoom factors are x1 (no zoom), x2, and x4. Vertical zooming is performed by the CRTC1 and nothing need be done in the RAMDAC section of the Matrox G400. #### 4.7.6 **Feature Connector** The Matrox G400's MAFC (Matrox Advanced Feature Connector) Video Output Port is supported for all non-VGA display modes up to a dot clock of 100 MHz in MAFC12 mode, and 112 MHz in PanelLink mode. The MAFC port is a 12-bit wide data bus and, depending on the operating mode, can provide vsync, hsync, blank, and clock outputs as well as control bits in PanelLink mode. In all modes, either the CRTC1 or CRTC2 can drive the MAFC port. The two CRTCs are completely independent of each other, and the main display. There are three main modes of operation supported by the MAFC Video port: 1. MAFC RGB 2. MAFC YCbCr: VIN BYPASS CRTC2 3. PANELLINK: Standard PanelLink Master PanelLink Slave PanelLink #### **MAFC RGB** MAFC RGB mode is supported with both CRTC's, regardless of which one is driving the main display. In this mode, Matrox G400 operates as a slave to the MGA-TVO chip, via the VIDRST pin. The proper reset enable bits must be set in order for the VIDRST to properly affect the desired CRTC. The data is output on the VDOUT pins on both edges of the clock. The clock comes from MGA-TVO into the VDOCLK pin, is gated with the blank so that it toggles just in the display and remains high during the blank. After being gated it is output on the VOBLANKN pin. The input clock is also used as the frequency source for the CRTC driving the MAFC interface. | Pin Name | I/O | Purpose | |----------|--------|------------------| | VDOUT | Output | Used for data | | VOBLANKN | Output | Gated Clock | | VDOCLK | Input | Master Clock | | VIDRST | Input | Genlocking reset | Programming steps permitting the Matrox G400 to enter MAFC RGB mode: - 1. Disable CRTC memory transactions by programming **scroff** for CRTC1 or **c2en** for CRTC2. - 2. Program clock source selection and all derived clocks i.e. VCLK. Follow clock programming guidelines. - 3. Program **mfcsel**, **vdoutsel**, and **panelsel** appropriately and in this order. | field name | CRTC1 | CRTC2 | |------------|-------|-------| | mfcsel | 01 | 01 | | vdoutsel | 000 | 100 | | panelsel | 0 | 0 | 4. Re-enable memory transactions, during the Vertical Blank is strongly recommended. #### MAFC YCbCr MAFC YCbCr mode is supported with CRTC2 and with the VIN module. If the VIN is being used in bypass mode the CRTC2 cannot operate. In this mode, the timing codes are embedded. There is no VIDRST used in this mode, and thus no master. The clock may come from MGA-TVO or an internal clock source may be used. The data is output on the 8 LSBs of the VDOUT bus, on the rising edge of the clock only. | Pin name | I/O | Purpose | |----------|--------|---------------------------------------------------| | VDOUT | Output | Used for data | | VOBLANKN | Output | Source Clock (either VDCLK from VIN, or C2PIXCLK) | | VDOCLK | Input | Master Clock | | VIDRST | Input | Field bit for CRTC2 | Programming steps permitting the Matrox G400 to enter MAFC YCbCr mode: For VIN Bypass: Program **mfcsel**, **vdoutsel**, and **panelsel** appropriately and in this order. | field name | VIN | |------------|-----| | mfcsel | 01 | | vdoutsel | 001 | | panelsel | 0 | #### For CRTC2 YCbCr: - 1. Disable CRTC2 memory transactions by programming **c2en** for CRTC2. - 2. Program clock source selection and all derived clocks i.e. C2VCLK. Follow clock programming guidelines. 3. Program **mfcsel**, **vdoutsel**, and **panelsel** appropriately and in this order. | field name | CRTC2 | |------------|-------| | mfcsel | 01 | | vdoutsel | 101 | | panelsel | 0 | •• *Note:* The CRTC1 is unaffected in this mode. #### PanelLink mode PanelLink mode is supported with both CRTC's, regardless of which one is driving the main display. In this mode, the Matrox G400 operates as a master to the PanelLink chip. The data is output on the VDOUT pins on both edges of the clock. The clock can be output on either the VIDRST pin or the VDOCLK pin, the clock source can be the VDOCLK pin, P1PLL or P2PLL, all depending on which PanelLink mode we are in. There are three PanelLink modes: Standard PanelLink mode, Master PanelLink mode, and Slave PanelLink mode. Standard PanelLink Mode. In this mode only the first CRTC drives both the MAFC port and the desktop with the same resolution and same information. | Pin name | I/O | Purpose | |----------|--------|------------------------------------| | VDOUT | Output | Used for data | | VOBLANKN | Output | active low blank | | VDOCLK | Output | Master Clock | | VHSYNC | Output | inverted polarized horizontal sync | | VVSYNC | Output | inverted polarized vertical sync | Also available in this mode are the muxed HSYNC, VSYNC and control bits, on VDOUT(0), VDOUT(1) and VDOUT(4:2) respectively. They are active during the blank only. The syncs have independent enables and inversion from the primary display. #### Master PanelLink Mode: It is in this mode that P1PLL is used to drive one CRTC and the P2PLL is used to drive another. All system clocks are derived from the AGPPLL. This allows completely independent resolutions and information between the MAFC port and the main display. | Pin name | I/O | Purpose | |----------|--------|------------------| | VDOUT | Output | Used for data | | VOBLANKN | Output | active low blank | | VDOCLK | Output | Master Clock | Also available in this mode are the muxed HSYNC, VSYNC and control bits, on VDOUT(0), VDOUT(1) and VDOUT(4:2) respectively. They are active during the blank only. The syncs have independent enables and inversion from the primary display. #### Slave PanelLink Mode: The third mode is Slave PanelLink mode. In this mode, a PLL is used to drive a CRTC and the second video clock comes from an external source through the VDOCLK pin. This allows independent resolutions and it also allows more flexibility in the SYSTEM clocks. What differentiates this mode from the previous two modes is that **panelsel** must be programmed to '1'. | Pin name | I/O | Purpose | |----------|--------|------------------| | VDOUT | Output | Used for data | | VOBLANKN | Output | active low blank | | VDOCLK | Input | Video Clock | | VIDRST | Output | Master Clock | Programming steps enabling the Matrox G400 to enter PanelLink mode: - 1. Disable CRTC memory transactions by programming **scroff** for CRTC1 or **c2en** for CRTC2. - 2. Program clock source selection and all derived clocks i.e. VCLK. Follow clock programming guidelines. - 3. Program **mfcsel**, **vdoutsel**, and **panelsel** appropriately and in this order. | field name | CRTC1 | CRTC2 | |------------|-------|------------------------------------| | mfcsel | 10 | 10 | | vdoutsel | 000 | 100 | | panelsel | 0 | 0 (or '1' in slave PanelLink mode) | - 4. Re-enable memory transactions, during the Vertical Blank is strongly recommended. - •• *Note:* You *must* follow the clock re-programming guidelines whenever switching a clock source or reprogramming a PLL. For more details, refer to the **mfcsel** and **vdoutsel** fields of the **XMISCCTRL** register. •• Note: The VHSYNC/ and VVSYNC/ always drive the vsync and hsync for the CRTC driving the DAC. If CRTC1 is driving the DAC and CRTC2 is driving the MAFC port, then the sync pins will be related to CRTC1. ## 4.7.7 Test Functions A 16-bit CRC is provided to verify video integrity at the input of the DACs. The CRC can be read via the **XCRCREMH** and **XCRCREML** registers when the vertical sync is active. The CRC is cleared at the end of the vertical retrace period, and calculated only when the video is active. The **crcsel** field determines which of the 24 bits will be used in the calculation. The output of the sense comparator can be read via the **XSENSETEST** RAMDAC register. This provides a means to check for the presence of the CRT monitor and determine if the termination is correct. The sense bits are latched at the start of the blanking interval. In order to ensure a stable value at the input of the comparator, the input of the DACs should remain constant during the visible display period. The sense amplifiers can be powered down by setting the **sensepdN** bit to '0'. ## 4.7.8 Clock Generator Circuit The Matrox G400's RAMDAC has two independent programmable Phase Locked Loops (PLLs), named P1 and P2. These two PLLS will be defined as the PIXPLL or SYSPLL depending on the programming of the **pllsel** field in the **OPTION** register. | PLLSEL | PIXPLL | SYSPLL | |--------|--------|--------| | 0 | P1 PLL | P2 PLL | | 1 | P2 PLL | P1 PLL | There is a third PLL used for the AGP interface. These PLLs are used as frequency sources for clock generation. The PIXPLL is used to generate the Video clocks, and the SYSPLL or AGPPLL are used to generate the SYSTEM clocks. | Video Clocks | Purpose | Max. Supported Speed<br>(in MHz) | |--------------|-----------------------------|----------------------------------| | PIXCLK | CRTC1 Pixel Clock | 270 | | VCLK | CRTC1 Quadword Clock | 135 | | BESCLK | Backend Scaler Clock | 270/135<br>(270 in 2X MODE) | | C2PIXCLK | CRTC2 Pixel Clock | 135 | | C2VCLK | CRTC2 Address Clock | 67.5 | | C2D8CLK | CRTC2 Synchronization Clock | 16.875 | | System Clocks | Purpose | Max. Supported Speed (in MHz) | |---------------|------------------------|-------------------------------| | MCLK | Memory Interface Clock | 150 | | GCLK | Drawing Engine Clock | 90 | | WCLK | Setup Engine Clock | 100 | | CODCLK | CODEC/VIN clock | 90 | <sup>◆</sup> *Note:* The values in these table are *preliminary*. The final values may vary. Figure 4-8: System Clocks MGI Confidential ## 4.7.8.1 System PLL The system PLL is programmed through the **XSYSPLLM**, **XSYSPLLN** and **XSYSPLLP** registers. The frequency output of the Voltage Controlled Oscillator (VCO) is defined by: ``` Fvco = Fref * (XSYSPLLN + 1) / (XSYSPLLM + 1) Where Fref = 27.000 MHz. 1 \le N \le 127 (feedback divider) 1 \le M \le 31 (input divider) P = \{0,1,3,7\} (post-divider) 0 \le S \le 3 The PLL output frequency is then: Fo = Fvco / (XSYSPLLP + 1) ``` The *maximum* frequency supported by the PLL is 310 MHz. On reset, the system clock is derived from the PCI bus clock. This permits the Matrox G400 to boot-up properly. The system PLL resets to its oscillating frequency when the SYSPLLPDN bit is set to '1'. Power consumption can be reduced by programming syspllpdn to '0'. This will shut down the system PLL and all clocks using it as a source. If MCLK issuing the system PLL and it is powered down, all contents will be lost. •• Warning: Not following the correct power-down and reprogramming sequence will create unpredictable results, including the possibility of damaging the ASIC. Although all the system clocks share a single clock source, they all have independently controlled clock dividers on the SYSTEM PLL frequency. the divider works according to the following tables. ## 4.7.8.2 System Clocks The system clocks are listed in section 4.7.8 | Clock Name | Clock source Select Field | Clock Divider Field | |---------------------------|---------------------------|---------------------| | CODCLK (in OPTION2) | codclksel | codprediv/codpstdiv | | GCLK (in OPTION3) | gclksel | gclkdiv/gclkdcyc | | MCLK (in <b>OPTION3</b> ) | mclksel | mclkdiv/mclkdcyc | | WCLK (in <b>OPTION3</b> ) | wclksel | wlckdiv/wclkdcyc | All the system clocks have a two-bit field that allows them to chose a clock source (see **OPTION3** for a definition of **gclksel**, **mclksel**, **wclksel**, and **OPTION2** for a definition of **codclksel**). The MCLK, GCLK, and WCLK share the same divider choices (refer to **OPTION3** for a definition of m, g, and W). For the CODCLK the divider works differently: there are two cascaded dividers, a divide by 2 (**codprediv**) and a divide by 3/2 (**codpstdiv**). These two CODCLK fields allow the following to be achieved: | codprediv | codpstdiv | Final Output Frequency | |-----------|-----------|------------------------| | 0 | 0 | Source frequency | | 0 | 1 | 2/3 * Source frequency | | 1 | 0 | 1/2 * Source frequency | | 1 | 1 | 1/3 * Source frequency | The GCLK, MCLK and WCLK have an additional field called **gclkdcyc**, **mclkdcyc** and **wclkdcyc** respectively. This field adds a duty cycle correction factor to the clock cycle in order to maintain a 45/55 duty cycle. The proper correction factor must be selected by finding in which range the OUTPUT frequency falls. The duty cycle correction circuitry is designed to be process variation and environment condition tolerant. There is no duty cycle correction for the CODCLK. ### Example: GCLK is using the system PLL as a clock source. The PLL output frequency is 200 MHz. The **gclksel** field is set to divide the source frequency by 3/2. The GCLK frequency will be 133 MHz, therefore, the **gclkdcyc** field must be programmed to (133 MHz)^-1, 7.52 ns, which corresponds to '0110'. Programming the duty cycle correction field to '0000' will remove any effect of duty cycle correction. At frequencies smaller than 97.5 MHz, this field should be programmed to '1011'. •• *Note:* The duty cycle circuitry will *only* work with the 2/3 and 4/9 selection from the divider fields. The duty cycle circuitry will have *no* effect on other dividers. All four system clocks are completely independent of each other. This means that changing a divider or clock source for MCLK will not affect the GCLK frequency. This is also true for the duty cycle correction. The dividers are only available for SYSPLL or AGPPLL clock sources. The test clock or PCI clock cannot be divided. The system clocks are *all* gated *off* when the **sysclkdis** field is set to '1'. (regardless of the clock source). #### Limitations: When setting the divider for GCLK, MCLK, and WCLK, the following relations must be followed, otherwise problems may occur: - PCLK < WCLK - GCLK < 2 X MCLK - PCLK < MCLK #### 4.7.8.3 Pixel PLL The pixel PLL is programmed through the **XSYSPLLM**, **XSYSPLLN** and **XPIXPLLP** registers. The frequency output of the Voltage Controlled Oscillator (VCO) is defined by: Fvco = Fref \* (XSYSPLLN + 1) / (XSYSPLLM + 1)Where Fref = 27.000 MHz. $7 \le N \le 127$ (feedback divider) 1 <= M <= 31 (input divider) $P = \{0,1,3,7\}$ (post-divider) $0 \le S \le 3$ The PLL output frequency is then: Fo = Fvco / (XPIXPLLP + 1) The maximum frequency supported by the PLL is 310 MHz. On reset, the pixel frequency is derived from the PCI bus clock. This permits the Matrox G400 to boot-up properly. Power consumption can be reduced by programming **pixpllpdn** to '0'. This will shut down the pixel PLL and all clocks using it as a source. •• Warning: Not following the correct power-down and reprogramming sequence will create unpredictable results, including the possibility of damaging the ASIC. #### 4.7.8.4 Video Clocks The video clocks are listed in section 4.7.8. The video clocks can be broken-down into two main clocks from which all other clocks are derived. There is PIXCLK from which BESCLK and VCLK are derived, and there is C2PIXCLK from which C2VCLK and C2D8CLK are derived (and VDCLK, or VIN clock, during grab-back mode.) The relation of VCLK to PIXCLK is a function of the display mode of CRTC1: | mgamode | depth | Video Clock | |---------|----------|--------------| | 0 | XXX | PIXCLK | | 1 | 000 | PIXCLK/8 | | 1 | 001 | PIXCLK/4 | | 1 | 010 | PIXCLK/4 | | 1 | 011 | PIXCLK/(3/8) | | 1 | 100 | PIXCLK/2 | | 1 | Reserved | Reserved | | 1 | Reserved | Reserved | | 1 | 111 | PIXCLK/2 | When the Backend Scaler is in 2X mode, the PIXCLK will be two times BESCLK, otherwise, they are equal. The PIXCLK can be obtained from 3 sources, the PCI clock for boot-up purposes, the PIXPLL and the VDOCLK pin in slave mode. The selection is done via the **pixclksl** field. The PIXCLK and its derived clocks will be disabled when the **pixclkdis** field is programmed to '1'. This field does NOT affect CRTC2. The relation of C2VCLK to C2PIXCLK is a function of the display mode of CRTC2. | C2DEPTH | YUV mode | RGB mode | |----------|-------------|------------| | Reserved | Reserved | Reserved | | 001 | C2PIXCLK/16 | C2PIXCLK/8 | | 010 | C2PIXCLK/16 | C2PIXCLK/8 | | Reserved | Reserved | Reserved | | 100 | C2PIXCLK/8 | C2PIXCLK/4 | | 101 | C2PIXCLK/16 | Reserved | C2D8CLK is the C2PIXCLK divided by 8. The C2PIXCLK can be obtained from 3 sources, the PCI clock for boot-up purposes, the PIXPLL and the VDOCLK pin in slave mode. The selection is done via the **c2pixclksl** field. ### 4.7.8.5 Clock Source Selection / PLL Reprogramming To change a clock source, frequency, divider, or duty cycle correction factor, the following procedure must be observed. The programming of the PIXPLL is completely independent of the SYSPLL. ### (A) Video Clocks To program any of the XPIXPLLM, XPIXPLLN, XPIXPLLP, XPIXCLKCTRL, or XC2PIXCLKCTRL registers, the memory clock *must* be running and enabled (**sysclkdis** = '0'). - 1. Force the CRTC1 screen off (only if required<sup>(1)</sup>). - 2. Force the CRTC2 enable off (only if required<sup>(1)</sup>). - 3. Set **pixclkdis** to '1' (disable the PIXCLK). - 4. reprogram the desired pixel PLL registers by changing the values of the registers, by changing the clock select field, or by selecting a different clock source. - 5. Wait until the clock source becomes stable. Either the **pixlock** field becomes '1', if the source is the PIXPLL, or the VDOCLK<sup>(2)</sup> is in input mode and stable. - 6. Set **pixclkdis** to '0' (enable the PIXCLK). - 7. Resume normal operation (enable the displays) #### (B) System Clocks When reprogramming the SYSPLL frequency: - 1. Set **sysclkdis** to '1' (disable the SYSCLK). - 2. Select the PCI bus clock for the system clocks SYSPLL. - 3. Set **sysclkdis** to '0' (enable the SYSCLK). - 4. Re-program the desired SYSPLL registers. - 5. Wait until the SYSPLL becomes stable, the SYSLOCK bit becomes '1'. - 6. Select the new source clock or change the appropriate dividers. (This step can be done afterwards as detailed below.) - 7. Set **sysclkdis** to '1' (disable the SYSCLK). - 8. Select the SYSPLL clock for the system clocks. - 9. Set **sysclkdis** to '0' (enable the SYSCLK). - 10. Resume normal operation. When selecting a new source frequency or clock divider: - 1. Set **sysclkdis** to '1' (disable the SYSCLK). - 2. Select the new source clock or change the appropriate dividers. - 3. Set **sysclkdis** to '0' (enable the SYSCLK). - 4. Resume normal operation Although GCLK, WCLK, and CODCLK are independent, they all share the same **sysclkdis** bit. If no changes are needed for the other clocks, then they do not need to be changed to PCI clock. However, certain clock relations must be respected. - MCLK should not be less than the PCI bus clock - MCLK should not be less than CODCLK, GCLK or WCLK. <sup>(1)</sup> If the CRTC1 is on a different source, then the CRTC2, and only the CRTC2's source will be changing, then the CRTC1 will continue to function normally and does not need to be disabled. <sup>(2)</sup> When using the VDOCLK as a clock source, be sure to set the VIDRST enable/disable bits correctly. This means that if the CRTC2 is using the VDOCLK and CRTC1 is using PIXPLL, disable the VIDRST from the affected CRTC1. #### 4.8 **Video Input Interface** #### 4.8.1 Overview of the Video-Grabber The Matrox G400's field based Video-Grabber captures VIP compliant video streams to the device frame buffer. Active video may be captured to four different programmable address pointers. VBI data may be captured to two different programmable address pointers in RAW or SLICED format. The programmable features of the Video-Grabber device are: - Bypass mode (VD redirected to VDOUT) - Four different capture modes (including C-Cube compatibility) - UYVY/YUY2 formatted output - Task based VBI detection - Field/Task determined interrupt generation - Horizontal downscaling by 1/2 of input stream - CRTC2 as selectable input source - Maximum height defined The Video-Grabber programming sequence includes a setup step to program static feature parameters, followed by iterative steps to manage the capture buffers after each vsync interrupt. #### 4.8.2 MAFC Mode Selection See the **XMISCCTRL** register to allow video in data to be driven back out the **VDOUT**(7:0) pins. The video-in data is registered once with **VDCLK**, so there will be a one cycle delay between the input data and the output data. The Video In interface does not have to be enabled in order for this pass-through mode to work, but it can be enabled if the stream is desired to be captured. #### 4.8.3 Vertical Blanking and VBI Count The Vertical Blanking, VBI and Active Video intervals of each field are defined by the settings in VBICOUNT When the input video stream makes a V-bit transition from '0' to '1', the present state of the Field bit is used to load the appropriate **VBICOUNT** parameters into the control structure. #### Note: #### Interlaced streams Because the Field bit transition always follows the V-bit rising edge event in an interlaced stream, vinvbcnt0 and vbicnt0 values will be effective on Field1 intervals. Similarly, the vinvbcnt1 and **vbicnt1** values will be effective on Field0 intervals. #### Vertical Blanking Interval The first **vinvbcnt-vbicnt** lines after a V-bit rising edge are defined as the Vertical Blanking interval. The Task and Field bit states are updated on every SAV/EAV during the Vertical Blanking interval. No data is captured for this interval. #### VBI Interval The **vbicnt** lines following the Vertical Blanking Interval are defined as the VBI interval. The Task and Field bits are not sampled outside the Vertical Blanking interval. Data is captured according to the settings of the **vbicap** and the **vbitasken** parameters. #### **AV Interval** The active Video interval is defined as all the lines following the first **vinvbcnt** lines in the field. The Task and Field bits are not sampled outside the Vertical Blanking interval. Data in the active video range is captured according to the settings of the **vincap** and the **vinheight** parameters. ## 4.8.4 Capture Modes / C-Cube Compatibility Four different capture modes are available to the programmer: 1Xmode, 1Xautomode, 2Xmode, and C-Cube mode. The different modes are programmed using the **vinautoen** and **vin2xen**, **vinfimfixen**, and **vingenfbinv** bits of the **VINCTL** register. | MODE | vinautoen | vin2xen | vinfimfixen | vingenfbinv | |-------------|-----------|---------|-------------|-------------| | 1Xmode | 0 | 0 | X | X | | 1Xautomode | 1 | 0 | X | X | | 2Xmode | 0 | 1 | X | X | | C-Cube NTSC | 0 | 1 | 1 | 0 | | C-Cube PAL | 0 | 1 | 1 | 1 | | Reserved | 1 | 1 | X | X | #### 1Xmode 1Xmode uses only two of the available active video addresses. Address pointer selection is field based. A field 0 is always captured to **vinaddr0** and a field 1 is always captured to **vinaddr1**. The VBI address is selected according to the field bit sampled during the current vbank interval. vininttsel = 0, vinintenf0 = 1, vinintenf1 = 1, vinintenta = X, vinintentb = X: #### 1Xautomode 1Xautomode uses all four available address pointers. The LSB of the pointer is equivalent to the present field bit. The MSB of the pointer is toggled whenever the sampled field bit makes a transition from '1' to '0'. The VBI address is selected according to the field bit sampled during the current vblank interval. vininttsel = 0, vinintenf0 = 1, vinintenf1 = 1, vinintenta = X, vinintentb = X: #### 2Xmode 2Xmode uses all four available address pointers. The LSB of the pointer is equivalent to the current sampled Field bit. The MSB is equivalent to the inverse of the present sampled Task bit. The VBI address is selected according to the sampled Field bit. vininttsel = 1, vinintenf0 = X, vinintenf1 = X, vinintenta = 1 vinintentb = 0: vininttsel = 1, vinintenf0 = X, vinintenf1 = X, vinintenta = 0, vinintentb = 1: vininttsel = 0, vinintenf0 = 1, vinintenf1 = 0, vinintenta = X, vinintentb = X: #### vininttsel = 0, vinintenf0 = 0, vinintenf1 = 1, vinintenta = X, vinintentb = X: #### C-Cube mode C-Cube interface requires the use of the VIP stream's Field bit for task selection and the generation of an internal field bit for field selection. The Video Grabber is in C-Cube mode when **vinfimfixen** is set to '1'. When in this mode, the stream's Field bit is inverted to generate a task selection. The internal field bit is obtained by using a 1-bit hblank counter. On each V-bit rising edge the counter is reset to '0'. On each following H-bit rising edge the counter is toggled. On every V-bit rising edge the counter value is sampled and held until the next V-bit event. The internally generated field bit is inverted when **vingenfbinv** is set to '1'. #### 4.8.5 UYVY and YUY2 Formats Grabbed data may be formatted in a UYVY or a YUY2 format. For a stream traveling from left to right: Input: U0 Y0 V0 Y1 U2 Y2 V2 Y3 ... U6 Y6 V6 Y7 **Output:** UYVY: U0 Y0 V0 Y1 U2 Y2 V2 Y3 ... U6 Y6 V6 Y7 YUY2: Y0 U0 Y1 V0 Y2 U2 Y3 V2 ... Y6 U6 Y7 V6 ### 4.8.6 Task Based VBI Detection When **vbitasken** is asserted and the field's respective **vbicap** parameter is programmed to RAW or SLICED, only lines for which the Task bit is '0' (Task B) in the VBI interval are captured. All other lines are ignored. When **vbitasken** in **VINCTL** is '0', all lines in the VBI interval are captured. ## 4.8.7 Field/Task Generated Interrupts The programmer may choose to generate Field or Task based interrupts by programming **vininttsel**. All interrupts are generated at the end of the respective field or task. ## 4.8.8 Horizontal Downscaling by 1/2 Input streams may be down-scaled by a factor of 2 by programming vinhdsen in VINCTL. For downscaling to be performed correctly, the following are *required*: - active video streams should have a line width which is a multiple of 4 pixels - lines of active video should not be interleaved with invalid data bytes Padding at the head or tail of an active video line with invalid bytes 0xFF or 0x00 is supported when prescaling is performed. The downscaling algorithm is described as follows: #### **Input 8 Pixels:** ### **Output 4 Pixels:** •• *Note:* special case for the first pixel, 3/4 of Y0 + 1/4 of Y1 #### 4.8.9 Feedback Path from Second CRTC Data generated by the CRTC2 may be captured through an internal feedback path to the Video In interface. This is handled by programming **vinc2graben** to '1'. •• *Note:* Any input data on the **VDCLK** or VD[7:0] pins is ignored under this condition. The **VDCLK** and VD[7:0] pins may be used as output pins for the CRTC2's clock and data by enabling the **vinvdclkoe** and **vinvdoe** bits in **VINCTL**. •• *Note:* When in output mode the state of **vinc2graben** is irrelevant because the feedback path is forced. This bit should be programmed to '1' to ensure the proper functioning of the readback path. # 4.8.10 Maximum Height Definition To protect the frame buffer from runaway video streams, the **VINHEIGHT** register should be programmed to the maximum allowable number of lines of active video per field. - •• *Note:* All lines that exceed the programmed height are ignored. - ◆ *Note:* The height counter is reset on every V-bit rising edge event. ## 4.8.11 Programming Sequence #### **Static Programming** - The Video input device should be reset by toggling **vinen** from '0' to '1'. Step 1. - All parameters in VINCTL, VINHEIGHT, and VBICOUNT should be programmed. Step 2. - vinvsyncien should be enabled in VIEN Step 3. - The pointer addresses should be programmed. (VINADDR0, VINADDR1, VINADDR2, Step 4. VINADDR3, VBIADDR0, VBIADDR1) - The vinpitch, vincap, and vbicap parameters should be programmed. (VINCTL0, VINCTL1, Step 5. VINCTL2, VINCTL3) - Wait for a vsync interrupt. Capturing begins. Step 6. ### **Dynamic Programming** - Clear vsync interrupt using **vinvsynciclr** in **VICLEAR**. Step 7. - Step 8. The pointer addresses may be reprogrammed for the next field. (VINADDR0, VINADDR1, VINADDR2, VINADDR3, VBIADDR0, VBIADDR1) - The **vinpitch**, **vincap**, and **vbicap** parameters may be reprogrammed for the next field. Step 9. (VINCTL0, VINCTL1, VINCTL2, VINCTL3) - **Step 10.** Wait for a vsync interrupt. Read the **VSTATUS** register. The vingrabptr indicates which address pointer was used for the last field. The fieldcapd and **taskdetd** indicate the values of the sampled Field and Task bits for the last field. The **vincapd** bit indicates whether the Active Video interval was reached in the last field. The **rawvbicapd** and **slcvbicapd** bits respectively indicate whether the VBI interval was reached in the last field and if raw or sliced VBI data was programmed to be captured. •• *Note:* For invalid data (0x00, 0xFF) the **vincapd** and **rawvbicapd** bits may be set even if no data was written to the frame buffer #### Repeat from Step 7 ### 4.8.12 Programming Table Programming table for the vinvbcnt0, vbicnt0, vinvbcnt1, and vbicnt1 fields for the various video streams. | speed | format | vinvbcnt0 | vbicnt0 | vinvbcnt1 | vbicnt1 | |-------|---------------|-----------|---------|-----------|---------| | | NTSC | 19 | 10 | 20 | 11 | | 1X | PAL | 25 | 17 | 24 | 17 | | IA | HD0-1280x720P | 30 | 0 | 30 | 0 | | | HD0704x480P | 42 | 0 | 42 | 0 | | | NTSC | vinvbcnt1 | 0 | 20 | 0 | | 2V | PAL | vinvbcnt1 | 0 | 25 | 0 | | 2X | HD0-1280x720P | vinvbcnt1 | 0 | 32 | 0 | | | HD0704x480P | vinvbcnt1 | 0 | 42 | 0 | ### 4.9 CODEC Interface A CODEC can be used in conjunction with the Matrox G400 chip to compress and decompress a video stream in real time. Note: When programming CODECHOSTPTR for compression/decompression, the Codec Interface will not stop transferring data when the PTR value is reached. Software should suspend the Codec Interface's memory accesses until more data is put into memory (or more space is available) by setting codectransen of CODECCTL to a '0' ## 4.9.1 Memory Organization Three main sections of memory are reserved for Codec Interface usage. The **CODECADDR** register is used to set the location of the buffer in the off-screen memory area. Table 4-10 shows the organization of the CODEC interface #### Compressed data area The compressed data area is used both for compression and decompression operations. This buffer size is selectable between 128Kbytes or 256Kbytes. The functions of **CODECHARDPTR** differ for compression and decompression (refer to the register definitions in Chapter 3 for more details). The compressed data area acts as a circular queue. Data from the beginning of one field is loaded into the dword which follows the last data from the previous field. It is the sole responsibility of the software to ensure that the compressed data area never overflows. The Codec Interface engine does not verify that there is valid compressed data in the buffer before reading, nor does it check to see that there is enough free space in the buffer before writing. The buffer level interrupt has been provided to help the software to ensure that overflows never occur. Decompression Compression CODECADDR CODECHARDPTR Compressed Data Arec Compressed Data Arec Valid Data Valid Data CODECHOSTPTR CODECHARDPTR -CODECHOSTPTR CODECADDR + 2<sup>(17 + codecbufsize)</sup> Command Area Command Area CODECADDR + 2(17 + codecbufsize) + 200h Read Data Area Read Data Area CODECADDR + 2<sup>(17 + codecbufsize)</sup> +3Ffh Figure 4-10: CODEC Interface Organization #### Command area The *command area* is used to store the commands to be sent to the CODEC. The organization of these commands and their execution is explained in more detail in the 4.9.2 section. The command area is set to a fixed size of 512 bytes. #### Read data area The *read data area* is used to store the data which has been read from the CODEC. When more than one location is read with a single command, the data is packed to take full advantage of the 8-byte wide memory locations. However, if only a single CODEC location is read, the remaining 7 bytes of the qword will be unused. The read data is always stored beginning with the LSB. The read data area is set to a fixed size of 512 bytes. #### 4.9.2 Command Execution Register read and write commands are stored in an off-screen command buffer. Each qword in the buffer may contain either a command or, in the case of a write command, write data. Each command, with its accompanying data, is stored one after the other in the command buffer. ◆ *Note:* The first *qword* in the queue *must always* contain a command. The format of a command, with its accompanying data, is shown in Figure 4-11. Figure 4-11: CODEC Command Format | 63 | | 16 | 15 0 | |--------------|----------------|----------------|----------------| | | | | Command | | write data 4 | write data3 | write data2 | Write data1 | | : | : | : | : | | : | : | : | : | | write data n | write data n-1 | write data n-2 | write data n-3 | The command word itself is composed of several control bits which affect command execution: #### **Command Word Definition:** | read | Reserved | | ao | ldr | | stop | pause | | | | CO | unt | | | | |------|----------|----|----|-----|----|------|-------|---|---|---|----|-----|---|---|---| | | | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | *count* <7:0> The *count* specifies the number of registers to be written to or read from the CODEC. When executing writes, the count will refer to how many words in Write Data qword(s) will be processed. When executing reads, the count will refer to how many times the address **addr** in the Command Word will be read. pause <8> The **pause** bit is used for *compression* only. It is active high. The command word in which it is contained is executed. Once this command is completed, register read/writes are suspended until the next end-of-field marker is detected in the compressed data stream. ◆ *Note:* The pause bit does *not* reset the command buffer pointer. stop <9> The **stop** bit is used to halt *register accesses*. It is active high. The command word in which it is contained is executed. Once this is completed, register accesses are complete, and the **cmdcmplpen** field in the **VSTATUS** register is set. When software triggers command execution once again, the command buffer pointer is reset and execution begins from the first qword in the command buffer. Here is an example of how the *pause* and *stop* bits are used in compression: ### **Pre-compression:** During the vertical blanking interval, software loads the off-screen command buffer with register transfer commands. The first set of instructions are used to setup the CODEC for the next field. The last instruction in the register setup sequence has its pause bit set high. The CODEC Interface Engine will execute all of the register read/write commands until it reaches the pause bit. At this point, the CODEC begins data compression transfers. ### **Post-compression:** In the command buffer, the pre-compression sequence should be followed by a set of post-compression instructions (to read field status information from CODEC or setup the next compression). When the end-of-field indication is detected in the compressed data stream, register read/write execution automatically resumes at the command immediately following the last pre-compression command (the one with the pause bit set high). Commands will be executed until the next active pause bit or stop bit is encountered. In the case where an active stop bit is encountered, register transfers are considered complete and software is interrupted. *addr* <13:10> Address to access for register reads When executing read commands, **addr**<13:10> will indicate which address the Codec Interface will read from in the Codec address space. This address will be read as many times as was programmed in **count<7:0>**. When executing register writes, these 4 bits are unused. When transferring compressed data, the address asserted is programmed by software in the **CODECCTL** register. When in VMI mode, <13:10> are output. When in I33 mode, <11:10> are output. Figure 4-12: Address Space of I33 CODEC in Code Slave Mode *read* <15> This bit indicates the direction of transfer for reads or writes, with respect to the CODEC. Read and write commands may be interleaved in any manner. - 0: write data to the CODEC registers - 1: read data from the CODEC registers ### Write data: | ι | unused ac | | | ad | dr | | | | d | ata | byt | e | | | | |----|-----------|----|----|----|----|---|---|---|---|-----|-----|---|---|---|---| | | | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | databyte <7:0> Data byte to be written to the indirect register. addr <11:8> Indicates which segment of the CODEC address space the CODEC Interface will write too. - The Codec Interface engine begins executing commands when the CODECCTL register is written with an access that sets the cmdexectrig field (the command execution trigger field does not need to be cleared by software). When software triggers command execution, the Codec Interface engine resets its Command Area pointer and Read Data Area pointer. - The *first* pointer (command area pointer) selects the next qword to be read. This pointer is reset to point to the beginning of the command area when the **cmdexectrig** field is set. - The *second* pointer (read data area pointer) selects the next qword to be written in the read data area. This pointer is reset to the beginning of the read data area when the **cmdexectrig** field is set. - 2. The Codec Interface engine then fetches the *first* command. - If the command is a write, the appropriate number of qwords are read from the command area and written to the CODEC. After one qword of data is read from the command area, the data is written to the CODEC one word at a time, starting with word 0, then word 1, and so on to word 3. If the write command completes before all 4 words are written, the remaining data is dropped and not used. On the next write command, data is again fetched and sent to the CODEC, starting with word 0. - If the command is a read, the appropriate number of bytes are read and stored in the read data area. The data is read from the CODEC one byte at a time, and is accumulated until a complete qword has been received. The first byte read is loaded into byte 0, the second into byte 1, and so on to byte 7 (the eighth byte). The resulting qword is then written to the next available location of the read data area. If the read command completes before all 8 bytes are filled, the data is written to the off-screen buffer as is (unfilled). On the next read command, data is again filled, starting with byte 0. - 3. Upon completing the read or write command, the Codec Interface engine fetches the next command from the command buffer; the process repeats until a STOP command is executed. #### **Examples** Table 4-10 shows the contents of a command area, while Table 4-11 shows the contents of the read data area after the execution of all commands has taken place. Table 4-10: Contents of the Command Area | Location | Contents | Meaning | |----------|--------------------|-------------------------------| | + 8000h | XXXXXXXXXXXX8401h | Read address "0001", count=1 | | + 8008h | xxxxxxxxxxxx0002h | Write 2 locations | | + 8010h | XXXXXXXX03FF02AAh | Write addresses and data | | + 8018h | xxxxxxxxxxxx0003h | Write 3 locations | | + 8020h | XXXX06BB057504EEh | Write addresses and data | | + 8028h | XXXXXXXXXXXX0104h | Write 4 locations, pause | | + 8030h | 07DD06CC05BB04AAh | Write addresses and data | | + 8038h | XXXXXXXXXXX9E04h | Read address "0111", count=4, | | + 603611 | AAAAAAAAXXXXYEU4II | stop | Table 4-11: Contents of the Read Data Area | Location | Contents | Meaning | |----------|---------------------|-------------------------------| | + 8200h | xxxxxxxxxxxxxx00h | Read data from address "0001" | | + 8208h | xxxxxxxxxdddddddddh | Read data from address "0111" | The first command read 1 byte from address 01h. The data, 00h, was written to memory at address +8200h. The next command was a write of 2 locations. The data is fetched in memory and written as data AAh to address 02h, and data FFh to address 03h. The next command is a write to 3 locations. The data is fetched from memory and written as data EEh to address 04h, data 75h to address 05h, and data BBh to address 06h. The next command is a write to 4 locations with a pause. The data is fetched and written as data AAh to address 04h, data BBh to address 05h, data CCh to address 06h, and data DDh to address 07h. Since the pause bit was asserted in this command, the Codec Interface engine will *not* fetch its next command until it receives the end-of-field indication from the CODEC. *At this point, compressed data transfers begin*. When the end-of-field is detected, the interface engine proceeds with the next command, which is a read from address 07h, count of 4, with stop. The data is read as DDh, DDh, DDh, DDh, and put into location +8208h. Since the stop bit was asserted in this command, the interface engine will not send any further commands to the CODEC and will assert the **cmdcmplpen** field of **VSTATUS**. ## 4.9.3 Output mode The Codec Interface may operate in 3 possible output modes: VMI Mode A, VMI Mode B, and Zoran I33 compatible mode. The mode is programmed in the **CODECCTL** register. All examples set forth assume I33 mode. All programming procedures are identical in all modes (except for setting the proper mode in the **CODECCTL** register. #### 4.9.4 CODEC Interface RESET to IDLE Procedure All PCI accesses to the CODECCTL register should be byte-wise when resetting the device. #### Procedure: - 1. DISABLED: - To disable the CODEC Interface after a compression or decompression cycle the **codecen** field should be programmed to ϑ. This automatically sets byte0, byte1 and byte2 of the **CODECCTL** register to ϑ. - 2. ENABLED: - When enabling the device interface **codecen** should be set to '1'. All the fields in byte0 except **cmdexectrig** and **codectransen** should be set appropriately on this PCI transfer. - The previous step should be repeated once to ensure correct setting of all fields in byte0. - 3. IDLE: - The fields in byte1 of **CODECCTL** (**codecfifoaddr** and **codecrwidth**) should then be set. The device is now considered to be in the active IDLE state. - 4. ACTIVE: - Then the **cmdexectrig** and **codectransen** fields should be programmed in a single PCI access to byte0 to trigger command execution and data transfer. | | CODECCTL BYTE0 | | | | | | | | | | | | |----------|----------------|---------|------|---------|--------|---------|------|--------|--|--|--|--| | state | reserved | transen | stop | vmimode | datain | cmdexec | mode | enable | | | | | | DISABLED | 0 | X | X | X | X | X | X | 0 | | | | | | ENABLED | 0 | 0 | P | P | P | 0 | P | 1 | | | | | | | 0 | 0 | P | P | P | 0 | P | 1 | | | | | | IDLE | D | D | D | D | D | D | D | D | | | | | | ACTIVE | 0 | 1 | P | P | P | С | P | 1 | | | | | #### Where: X = "Don't care" P = Program bit according to desired transfer type. C = 1 when command execution desired. D = "Don't touch" # 4.9.5 Recovery Width Programming The strobe recovery pulse width in the Codec Interface engine is programmable in the **CODECCTL** register. The **codecrwidth** should be programmed before the Codec Interface is enabled (with **codecen**) to begin transfers to the CODEC. If the **codecrwidth** is reprogrammed during data transfers, data corruption may occur. The formula to compute the optimal recovery time, Trec (in *ns*), is: $$Trec = N * Tgclkbuf$$ and Trec > Tcodecrec #### Where: Trec = minimum recovery time Tgclkbuf = the period of gclkbuf Tcodecrec = the CODEC's minimum required recovery width #### Given: ``` gclkbuf (internal graphic clock) = 72 \text{ Mhz}, thus Tgclkbuf = 13.9 \text{ ns} for I33, Tcodecrec = 55.5 \text{ ns} ``` #### Then: Trec = $55.6 \, ns$ , which is less that Tcodecrec = $55.5 \, ns$ Thus, Trec should be greater than 55.5 ns, corresponding to 4 gclkbuf cycles. Thus, **codecrwidth** should be programmed with "00" 4 gclkbuf cycles. ## 4.9.6 Miscellaneous Control Programming The **miscctl** byte located in the **CODECCTL** register is used to program an 8 bit flip-flop on the graphics card. The values of the **miscctl** field are used to set various inputs to the CODEC and MPEG2 chips like SLEEP, START, etc. By writing to the **miscctl** field, software triggers a sequence to program the onboard flip-flop with the corresponding data. Note: In order for this automated sequence to be executed, the Codec Interface engine must be enabled and in one of the following modes/states: IDLE, COMPRESSION, or DECOMPRESSION. For example, if the chip select for a CODEC is connected to bit 0 of the on-board flip-flop, and is active low, then software could enable the CODEC as follows: 1.write "00000000" b to the lower byte of the **CODECCTL** register (to reset it, woptional) 2.write "00000001" b to the lower byte of the **CODECCTL** register (to enable it) 3.write "1111110" b to the **miscctl** field of the **CODECCTL** register (to set the chip select to the CODEC). If the Codec Interface is in the process of compression or decompression when the **miscctl** field is written to, then the Interface will wait until the current byte transfer is complete. At that point the onboard flip-flop will be programmed, and then data transfers will resume with the next byte. No data will be lost or corrupted during this process. ## 4.9.7 Compressing data Data being compressed comes from the video decoder. The compressed video frame is returned to the frame buffer through the Codec Interface channel. Figure 4-13: Compression of a Live Video Source Two interrupts are used while the CODEC is compressing data. The *buffer level* interrupt is used to tell software the current fill state of the frame buffer. The *command execution completed* interrupt is used to request host services in order to adjust the compression factors. ### The following must be performed to compress video: - **Step 1.** Program the video decoder according to its specification. - **Step 2.** Software *must* reset the CODEC Interface engine by following the procedure specified in section (see 'CODEC Interface RESET to IDLE Procedure' on page 4-107): | Register | Function | Comment / Alternate Function | |----------|----------------------------------|----------------------------------------------------------------------------| | CODECCTL | Reset the Codec Interface engine | Write 00h to Byte0 | | CODECCTL | Enable the Codec Interface | Write all fields of Byte0 except cmdexectrig and codectransen. codecen = 1 | | CODECCTL | Repeat previous step | Write all fields of Byte0 except cmdexectrig and codectransen. codecen = 1 | | CODECCTL | Program byte 1 | Write all fields in Byte1 | **Step 3.** Software must then initialize the following registers in the Codec Interface engine: | Register | Function | Comment / Alternate Function | |-----------|------------------------------|------------------------------| | CODECADDR | Address of off-screen buffer | _ | - **Step 4.** The CODEC must be initialized with the mode and other parameters shown below. To do this, software must transfer CODEC register write commands into off-screen memory. Typically, the registers to be written are: - Mode Control - FIFO Control - HSTART - HEND - VSTART - VEND - Compression Ratio (See 'Command Word Definition:' on page 4-103 to set the **stop** bit) - •• *Note:* The CODEC specification will have detailed information regarding which registers need to be programmed. - **Step 5.** Trigger the execution of commands to the CODEC: Example: - Codec mode = '1' I33 mode - Codecdatain = '1' Compression (receiving data from the codec) | Register | Function | Comment / Alternate Function | |----------|-----------------------------------|------------------------------| | CODECCTL | Enable the Codec Interface engine | 00001111b | **Step 6.** At the completion of this command, the Codec Interface engine will set the **cmpcmplpen** field A of **VSTATUS**. The host will read the status in order to know when the command has been executed. The host must also clear the **cmdcmplpen** flag. | Register | Function | Comment / Alternate Function | |----------|-----------------|------------------------------| | VICLEAR | Clear interrupt | 02h | **Step 7.** The host must then transfer the following commands to off-screen memory: - program registers in CODEC (set the *pause* bit) - read field information from CODEC - read the FIFO status for the error conditions (if necessary, see CODEC specification) (set the **stop** bit) **Step 8.** The host must then enable all interrupt bits. | Register | Function | Comment / Alternate Function | |--------------|----------------------|-------------------------------| | CODECHOSTPTR | Next level interrupt | value desired by the software | **Step 9.** Trigger the execution of commands to the CODEC and enable the transfer of compressed data: | Register | Function | Comment / Alternate Function | |----------|--------------------------------------------|------------------------------| | CODECCTL | Reset the Codec Interface engine 01001111b | | - **Step 10.** The Codec Interface engine will then begin to transfer data from the CODEC to the compressed data area. - ◆ *Note:* Since the first field will probably be corrupted, software should discard it. - Step 11. The Codec Interface engine will interrupt the host every time CODECHARDPTR is equal to CODECHOSTPTR. The host can detect this situation by reading the blvlpen field of the VSTATUS register. As part of the interrupt routine, the host must perform transfers from the compressed data area to the system memory or hard disk. The host must also clear the blvlpen flag and update its pointer. | Register | Function Comment / Alternate Function | | |--------------|---------------------------------------|-----| | CODECHOSTPTR | Next level interrupt | _ | | VICLEAR | Clear Codec Status Register | 04h | - **Step 12.** When the CODEC asserts EOI (connected to misc[2] when codec engine is enabled), this informs the Codec Interface engine that its current read is the last byte of the field. The Codec Interface engine will write all remaining data in its memory interface buffer to the compressed data area and resume command execution. - Step 13. The Codec Interface engine will then interrupt software when the command is completed. The host can detect this situation by reading the **cmdcmplpen** field of the **VSTATUS** register. Based on the statistics, software must calculate new specs for compression field, and update the write commands in the off-screen buffer (see Step 6). The host must also clear the **cmdcmplpen** flag and restart command execution. | Register | Function Comment / Alternate Function | | | |----------|---------------------------------------|-----------|--| | VSTATUS | Status of memory commands 00000010b | | | | VICLEAR | Clear all CODEC interrupts | 06h | | | CODECCTL | Reset the Codec Interface engine | 00000000ь | | ### 4.9.8 Decompressing data When data is being decompressed, the compressed information is sent to the CODEC through the Codec Interface port. From there, the data is sent to the decoder and back to the Matrox G400 to be displayed on the monitor or TV (through MGA-TVO): Figure 4-14: Decompressing Data from the Memory Two interrupts are used when the Codec Interface is decompressing data. The *buffer level* interrupt is used to request more data from the host. The *decompression end of image* interrupt is used to notify software when the end of the field has been detected. When **stopcodec** is set to a '1' in the **CODECCTL** register, and decompression is enabled, the Codec Interface will look for the FFD9h end of image marker in the compressed data. When the end of image is detected, the Codec Interface will stall and post the **dcmpeoipen** interrupt (if enabled). At this point, software has 2 options: - reset the Codec DMA engine - use **cmdexectrig** of the **CODECCTL** to trigger command execution. If this method is used, the software *must* set **codectransen** to a '0', preventing decompression transfers from continuing after the commands have been completed. If **stopcodec** is set to a '0' for decompression transfers, then the Codec Interface will *not* detect the FFD9h end of image marker in the stream. It is up to software to stop the Codec Interface engine when it has determined that the desired field is complete (by polling the buffer level interrupt). The following steps *must* be performed in order to decompress video: - **Step 1.** Program the video decoder according to its specification. - **Step 2.** Software *must* reset the CODEC Interface engine by following the procedure specified in section (see 'CODEC Interface RESET to IDLE Procedure' on page 4-107): | Register | Function | Comment / Alternate Function | |----------|----------------------------------|----------------------------------------------------------------------------| | CODECCTL | Reset the Codec Interface engine | Write 00h to Byte0 | | CODECCTL | Enable the Codec Interface | Write all fields of Byte0 except cmdexectrig and codectransen. codecen = 1 | | CODECCTL | Repeat previous step | Write all fields of Byte0 except cmdexectrig and codectransen. codecen = 1 | | CODECCTL | Program byte 1 | Write all fields in Byte1 | **Step 3.** Software must then initialize the following registers in the Codec Interface engine: | Register | Function | Comment / Alternate Function | |-----------|---------------------------------------|------------------------------| | CODECADDR | Start address of buffer in off-screen | | | | memory | _ | - **Step 4.** The CODEC must be initialized with the mode and other parameters shown below. To do this, software must transfer CODEC register write commands into off-screen memory. Typically, the registers to be written are: - Mode Control - FIFO Control - HSTART - HEND - VSTART - **VEND** (See 'Command Word Definition:' on page 4-103 to set the **stop** bit) - Note: The CODEC specification will have detailed information regarding which registers need to be programmed. **Step 5.** Trigger the execution of commands to the CODEC: | Register | Function | Comment / Alternate Function | |----------|-----------------------------------|------------------------------| | CODECCTL | Enable the Codec Interface engine | 00000111b | **Step 6.** The host must then fill at least half of the compressed data area and write its pointer Example: • Codec mode = '1' I33 mode | Register | Function | Comment / Alternate Function | |--------------|----------------------|------------------------------| | CODECHOSTPTR | Next level interrupt | _ | **Step 7.** At the completion of the command, the Codec Interface engine will set the **cmpcmplpen** field. The host will read the status in order to know when the command has been executed. The host must also clear the **cmdcmplpen** flag. | Register | Function | Comment / Alternate Function | |----------|-----------------|------------------------------| | VICLEAR | Clear interrupt | 02h | **Step 8.** The host must then enable the buffer level interrupt and enable the transfer of compressed data. | Register | Function | Comment / Alternate Function | | |----------|-----------------------------------|------------------------------|--| | CODECCTL | Enable the Codec Interface engine | 01000011b | | - **Step 9.** The Codec Interface engine will then begin to transfer data from the compressed data area to the CODEC. - **Step 10.** The Codec Interface engine will interrupt the host every time **CODECHARDPTR** is equal to **CODECHOSTPTR**. At that time, the host should add more data to the compressed data area. The host must also clear the **blvlpen** flag and update its pointer. | Register | Function | Comment / Alternate Function | |--------------|---------------------------|------------------------------| | CODECHOSTPTR | Next level interrupt | _ | | VICLEAR | Status of memory commands | 04h | ## 4.9.9 Error Recovery The Codec Interface gives *highest priority* to command execution. When transferring data, if software determines there is an error condition with the CODEC, software can trigger command execution and preempt data transfers. If the Codec Interface is triggered to execute commands while it is the process of transferring data, the Codec Interface engine will disregard any data presently in its 4 qword fifo and load and execute the first command in the command data buffer. When the interface engine has completed all the commands (signalled by a STOP in the last command), it will resume data transfers wherever it left off (the **CODECHARDPTR** does not reset under these conditions). •• *Note: Any* data already loaded in the 4 qword fifo (either from the CODEC or from the frame buffer) when command execution is triggered will be *lost*. ### 4.10 Backend Scaler ### 4.10.1 Introduction #### 4.10.1.1 Overview The Backend Scaler supports one window. The supported video formats of source data taken from the frame buffer are: YCbCr in 4:2:2; 4:2:0 2-planes; and 4:2:0 3-planes. The window performs independent horizontal and vertical scaling. Bilinear filtering is *only* available on Y-component. *However*, horizontally interpolated upsampling of the chroma component is available. For magnification: replicate or bilinear filters are possible. For *minification*: drop, fixed 0.25 coefficient or normal bilinear filters are possible. The normal bilinear filter uses the next adjacent pixel or line to perform interpolation. The Backend Scaler also supports: complete source cropping; video de-interlace conversion with subpixel compensation; horizontal mirroring, and proc. amp. control on the Y-component. The Backend Scaler registers are double-buffered: they are internally updated once per frame when the **besvcnt** field compares with the CRTC vertical counter. If more than one register of a window must be modified, *ensure* that they are all reprogrammed during the same frame: the vertical counter should *not* reach the programmed **besvcnt** in the middle of reprogramming (this can result in unexpected intermediate video images or unwanted artifacts appearing on the screen). Four offscreen buffers are available to the window. In *software manual mode*, the field selection is under the control of software. In *hardware automatic field select*, the video input port selects the buffer to be displayed then toggles after each field received, so that it is not necessary to interrupt the software at each field. The Backend Scaler takes data from the selected buffer, performs scaling, then sends it to the ramdac. The keying circuitry then decides to display it to the screen. *No* memory writes are made. Two modes of keying are available: color keying and (inside the Backend Scaler window) coordinates keying. Color keying is done on the graphic color. The scaling factors are limited to 1/32 in downscaling and 16384/(source width) in upscaling. The Backend Scaler includes a YCbCr-to-RGB converter which permits it to send full 24-bit RGB color to the screen. The Backend Scaler is *not* supported when the CRTC is programmed in interlace mode. Virtual desktop and hardware zoom are supported *only* in software (which means that software must reprogram the Backend Scaler according to the changing desktop situation). The Backend Scaler can also do the composition on an RGB surface. The supported source data formats, taken from the frame buffer, are RGB15, RGB16, and RGB32. #### 4.10.1.2 Notation A fixed-point representation; it is important to apply this specification [real number]: immediately where specified. Do *not* use more precision than specified. Do not round-off any value. >> : A logical shift to the right. ## 4.10.1.3 Backend Scaler Control Backend Scaler control results from the following registers: | Register | Function | | |------------|----------------------------------------------------------|------------------------------------------| | | This register sets t | the following <i>global</i> controls: | | | | | | | beshzoom | accelerated 2X horizontal zoom enable | | | beshzoomf | accelerated 2X horizontal zoom filtering | | | bescorder | chroma sample order | | BESGLOBCTL | besreghup | update on horizontal sync. for test | | BESSEODCIE | bes3plane | 4:2:0 3-plane data format | | | besuyvyfmt | uyvy format enable | | | besprocamp | proc. amp. enable | | | besrgbmode | RGB mode | | | besvcbcrsingle | vertical cbcr single enable | | | besvcnt | vertical counter register update | | | | | | | This register sets the following <i>window</i> controls: | | | | besen | Backend Scaler enable | | | beshfen | horizontal filtering enable | | | besvfen | vertical filtering enable | | | beshfixc | horizontal fixed coefficient enable | | | bescups | chroma upsampling enable | | BESCTL | bes420pl | 4:2:0 planar data format | | | besdith | dither enable | | | beshmir | horizontal mirror enable | | | besbwen | black and white enable | | | besblank | blank enable | | | besfselm | field select mode | | | besfsel | field select | | | | | ## 4.10.1.4 Backend Scaler Status The status indicates the buffer currently being displayed (A1, A2, B1, B2) | Register | Fields | Comment / Alternate Function | |-----------|---------|------------------------------| | BESSTATUS | besstat | status of window | ### 4.10.1.5 Window Coordinates The horizontal and vertical coordinates of the window in the desktop are defined as follows: The fields are combined in registers: | Register | Fields | Comment / Alternate Function | |-----------|---------------------|------------------------------------------------------------------------------| | BESHCOORD | besleft<br>besright | <b>besright</b> <i>must</i> be greater than <b>besleft</b> 0 to max. desktop | | BESVCOORD | bestop<br>besbot | <b>besbot</b> <i>must</i> greater than <b>bestop</b> 0 to max. desktop | ### 4.10.1.6 Bases Address and Origin Address The *base address* is the first byte of the source image in the frame buffer without source cropping or desktop offset. The *origin address* is the first byte of the first line (source image) used to produce the destination image (with source cropping and desktop offset). The source image (below) is displayed in xy, this occurs even if stored linearly in the frame buffer. | | ••• | A00AFD | A00AFE | A00AFF | |----------------|--------|--------|--------|--------| | base_address | A00B00 | A00B01 | A00B02 | A00B03 | | • | A00B04 | A00B05 | A00B06 | A00B07 | | | A00B08 | A00B09 | A00B0A | A00B0B | | origin_address | A00B0C | A00B0D | A00B0E | A00B0F | | · | A00B10 | A00B12 | A00B13 | | Legend: Data dropped by source cropping and /or desktop offset. Data used to produce destination image. <sup>◆</sup> *Note:* The base and origin addresses are useful for vertical source positioning. #### 4.10.1.7 Pitch The *pitch* is the offset (in numbers of pixels) from the beginning of one line to the next in the field currently read from the source data. The pitch must be programmed in the **BESPITCH** register, must be a multiple of 8 in 4:2:2 format and a multiple of 32 in 4:2:0 planar format. The *maximum* value for pitch is 4088 pixels in 4:2:2 format and 4072 pixels in 4:2:0 format. ### 4.10.2 Horizontal Scaling The following illustrations demonstrate the source and desktop considerations for horizontal scaling: Source with left and right cropping Destination window with left and right offset The last horizontal coordinate of the source must be programmed in the **BESHSRCLST** register: | Register | Field | Function | |------------|------------|--------------| | BESHSRCLST | beshsrclst | srcwidth - 1 | ### 4.10.2.1 Horizontal Inverse Scaling Factor The *Horizontal Inverse Scaling Factor* is the ratio of the source width to the destination width. To calculate this inverse factor (taking into account the above parameters), do the following: **Step 1.** Set the interval representation of source and destination variable. | | Filtering mode ON beshfen = 1 | Filtering mode OFF beshfen = 0 | | |-------------------------------------------------|-------------------------------|--------------------------------|--------------------------| | | besilien = 1 | Downscaling <sup>(1)</sup> | Upscaling <sup>(1)</sup> | | Interval representation value ( <i>intrep</i> ) | 1 <sup>(2)(3)</sup> | 1 <sup>(3)</sup> | 0 | <sup>(1)</sup> Upscaling is used when the destination width is greater than or equal to the source width (with source width reduced by cropping values) #### **Step 2.** Inverse Scaling Factor **Inverse Scaling Factor:** Inverse Scaling Factor with better precision: $$\textit{ifactorbetter} = \underbrace{ \begin{array}{c} \textit{srcwidth - cropleft - cropright - intrep} \\ \textit{destwidth - intrep} \end{array} }_{5.20} + (\textit{intrep} >> 20)$$ #### **Step 3.** Set the Round-off Variable $\textit{Condition:} \ (\textit{ifactorbetter} * (\textit{destwidth} - 1))_{FLOOR} > (\textit{ifactor} * (\textit{destwidth} - 1))_{FLOOR} :$ | | Filtering mode ON | Filtering mode OFF beshfen = 0 | | |----------------------------|-------------------|--------------------------------|-------| | | beshfen = 1 | Conditi | on: | | | | True | False | | Round-off value (roundoff) | 0 | 1 | 0 | **Step 4.** Set the Accelerated 2X Zoom Variable | | Accelerated 2x zoom ON | Accelerated 2x zoom OFF | |-------------------------------|------------------------|-------------------------| | | beshzoom = 1 | beshzoom = 0 | | Accelerated 2x zoom (acczoom) | 2 | 1 | <sup>(2)</sup> If the destination width is equal to the source width, *intrep* = 0 (with source width reduced by cropping values). <sup>(3)</sup> If the destination width is less than 2, intrep = 0. #### **Step 5.** Program the Inverse Scaling Factor The Inverse Scaling Factor *must* be programmed with the following formula: The **beshiscal** value *must* be in the following interval: $$\frac{\textit{srcwidth}}{16384} <= \text{beshiscal} < 32$$ | Register | Field | |-----------|-----------| | BESHISCAL | beshiscal | ### 4.10.2.2 Horizontal Source Positioning The horizontal starting source position (**BESHSRCST**) is the first source pixel that will contribute to the left first destination pixel. *Without* horizontal mirroring (**beshmir** = 0): *With* horizontal mirroring (**beshmir** = 1): The horizontal ending source position (**BESHSRCEND**) is the last source pixel that will contribute to the last right destination pixel. | Register | Field | |------------|------------| | BESHSRCST | beshsrcst | | BESHSRCEND | beshsrcend | # 4.10.3 Vertical Scaling The following illustration demonstrates the source and desktop considerations for vertical scaling: Source with top and bottom cropping Destination window with top and bottom offset ### 4.10.3.1 Vertical Inverse Scaling Factor The *Vertical Inverse Scaling Factor* is the ratio of the source height to the destination height. To calculate this inverse factor, (taking into account the above parameters) do the following: Note: For de-interlace conversion, the source is a field **Step 1.** Set the interval representation of source and destination. | | Filtering mode ON besvfen = 1 | Filtering mode OFF besvfen = 0 | | |-------------------------------------------------|-------------------------------|--------------------------------|--------------------------| | | | Downscaling <sup>(1)</sup> | Upscaling <sup>(1)</sup> | | Interval representation value ( <i>intrep</i> ) | 1 <sup>(2)(3)</sup> | 1 <sup>(3)</sup> | 0 | <sup>(1)</sup> Upscaling is used when the destination height is greater than or equal to the source height (with source height reduced by cropping values) ### **Step 2.** Inverse Scaling Factor Inverse Scaling Factor: Inverse Scaling Factor with better precision: $$\textit{ifactorbetter} = \underbrace{ \begin{array}{c} \textit{srcheight-croptop-cropbot-intrep} \\ \textit{destheight-intrep} \end{array} }_{5.20} + (\textit{intrep} >> 20)$$ #### **Step 3.** Set the Round-off Variable *Condition:* (ifactorbetter \* (destheight - 1))<sub>FLOOR</sub> > (ifactor \* (destheight - 1))<sub>FLOOR</sub>: | | Filtering mode ON | Filtering mode OFF<br>beshfen = 0 | | |----------------------------|------------------------|-----------------------------------|-------| | | $\mathbf{beshfen} = 1$ | Conditi | on: | | | | True | False | | Round-off value (roundoff) | 0 | 1 | 0 | #### **Step 4.** Program the Inverse Scaling Factor The Inverse Scaling Factor must be programmed with the following formula: The **besviscal** value must be in the following interval: $$\frac{\textit{srcheight}}{16384} <= \textit{besviscal} < 32$$ | Register | Field | |-----------|-----------| | BESVISCAL | besviscal | <sup>(2)</sup> If the destination height is equal to the source height, *intrep* = 0 (with source height reduced by cropping values). <sup>(3)</sup> If the destination height is less than 2, *intrep* = 0. ### 4.10.3.2 Vertical Subpixel Compensation For de-interlaced conversion, subpixel compensation is applied on the lower field. ### Subpixel Compensation Value ( $S_C$ ): ### Downscaling: Upper Field: $$S_C = 0$$ Lower Field: $$S_C = \begin{bmatrix} 2 * besviscal - 1 \\ \hline 2 \end{bmatrix}$$ 5.14 ### Upscaling: Upper Field: $$S_C = 0$$ Lower Field: $$S_C = \left[ \frac{\textit{destheight - intrep}}{2*(\textit{srcheight - croptop - cropbot - intrep)}} \right]_{5.14}$$ ### 4.10.3.3 Vertical Source Positioning Vertical Source Positioning is created in relation to subpixel compensation, source cropping, desktop offset and data format. Upscaling and Downscaling are presented separately. The following table shows how to set the round-off variables affecting the inverse scaling factor calculation: | | Data format 4:2:0 <b>bes420pl</b> = 1 | Data format 4:2:2 <b>bes420pl</b> = 0 | |--------------------------|---------------------------------------|---------------------------------------| | Data Format (dataformat) | 1 | 2 | | | Data format 4:2:0 | Data format 4:2:0 | |-----------------------------------|-------------------|-------------------| | | 3-plane | 2-plane | | | bes3plane = 1 | bes3plane = 0 | | 4:2:0 Format ( <i>420format</i> ) | 2 | 1 | ## 4.10.3.3.1 Downscaling ### **Origin Address** The Origin Address of buffer A and B for fields 1 and 2 is achieved by: $$origin\_address = [croptop + offsettop * besviscal + S_C]_{25.0} * BESPITCH * dataformat + base\_address + beshmir * (srcwidth * dataformat - 1)$$ | Register | Function | Comment | |----------|-------------------|----------------------------------------------| | BESA1ORG | | When de-interlace conversion is desired, | | BESA2ORG | [ origin_address] | the subpixel compensation value ( $S_C$ ) is | | BESB1ORG | | applied to the registers that contain the | | BESB2ORG | | lower field. | ### **Chroma Plane Origin Address** The Chroma Plane Origin address of buffer A and B for fields 1 and 2 is achieved by $$chroma\_plane\_origin\_address = \left[\frac{croptop + offsettop*besviscal + S_C}{2*420 format}\right]_{25.0}*BESPITCH + chroma\_plane\_base\_address$$ + beshmir\* $$\left[ srcwidth* \frac{dataformat}{420 format} \right]_{Floor} - 1 \right]$$ | Register | Function | Comment | |-----------|-------------------------------------------------|-------------------------------------------------| | BESA1CORG | | When <i>de-interlace conversion</i> is desired, | | BESA2CORG | [ chroma_plane_origin_address ] <sub>25.0</sub> | the subpixel compensation value ( $S_C$ ) is | | BESB1CORG | | applied to the registers that contain the | | BESB2CORG | | lower field. | ### **Chroma 3-Plane Origin Address** $$chroma\_3plane\_origin\_address = \begin{bmatrix} \frac{croptop + offsettop*besviscal + S_C}{4} \\ + \frac{chroma\_3plane\_base\_address} \\ + \frac{srcwidth}{2} \\ \end{bmatrix}_{Floor} *BESPITCH}$$ | Register | Function | Comment | |------------|------------------------------------------------|----------------------------------------------| | BESA1C3ORG | | When de-interlace conversion is desired, | | BESA2C3ORG | [ obrama 2nlana arigin address] | the subpixel compensation value ( $S_C$ ) is | | BESB1C3ORG | chroma_3plane_origin_address ] <sub>25.0</sub> | applied to the registers that contain the | | BESB2C3ORG | | lower field. | ### **Vertical Weight Starting Value** The Vertical Weight Starting Value registers are programmed as follows (the weight is the same for buffer A and B): **If** de-interlaced conversion is desired and is the lower field **then**: $\begin{aligned} & \textbf{If} & \textit{offsettop} = 0 \\ & \textbf{Then} & \textit{weight} = \textbf{-}(0.5 + \textbf{[besviscal]}_{0.14}) \end{aligned}$ Else weight = -0.5 + offsettop \* besviscal **Else** *weight* = *offsettop* \* **besviscal** | Register | Fields | Function | Comment | |-------------|-----------|----------------------------|-----------------------------------------------------------------------------------------| | BESV1WGHT | bes1wght | [ weight ] <sub>0.14</sub> | 3371 1 1 1 1 1 1 1 | | BESVIVVGIII | bes1wghts | I SION OF WEIGHT | When <i>de-interlace conversion</i> is desired, the subpixel compensation is applied to | | BESV2WGHT | bes2wght | II Walaht I | the registers that contain the lower field. | | BLSVZWGIII | bes2wghts | sign of weight | the registers that contain the 10 wer field. | ### **Vertical Source Last Position** The vertical source last position for field 1 or 2 is achieved by: $$\textit{vsrclst} = \textit{srcheight} - 1 - [\textit{croptop} + \textit{offsettop} * \textit{besviscal} + S_C]_{10.0}$$ | Register | Fields | Function | Comment | |-------------|-------------|------------------------------------|----------------------------------------------------------------------------------------------| | BESV1SRCLST | besv1srclst | [ <i>vsrclst</i> ] <sub>10.0</sub> | When <i>de-interlace conversion</i> is desired, the subpixel compensation value ( $S_C$ ) is | | BESV2SRCLST | besv2srclst | [ V3/0/31 ][0.0 | applied to the registers that contain the lower field. | ### **Vertical Source Start Polarity** The vertical source start polarity for field 1 or 2 is achieved by: | Register | Fields | Function | |----------|-------------|-----------------------------------------------------------------------------| | BESCTL | besv1srcstp | Set if [ $croptop + offsettop * besviscal + S_C$ ] <sub>FLOOR</sub> is odd. | | BESCIE | besv2srcstp | Set if [croptop + onsettop + besviscal + SC JFLOOR is odd. | ### 4.10.3.3.2 Upscaling ### **Origin Address** The Origin Address of buffer A and B for fields 1 and 2 is achieved by: $$origin\_address = \left[ (croptop + (offsettop - S_C)_{abs}) * besviscal \right]_{25.0} * BESPITCH* dataformat + base\_address + beshmir*(srcwidht* dataformat - 1)$$ | Register | Function | Comment | |----------|------------------------------------|-------------------------------------------------| | BESA1ORG | | When <i>de-interlace conversion</i> is desired, | | BESA2ORG | [ origin_address ] <sub>25.0</sub> | the subpixel compensation value ( $S_C$ ) is | | BESB1ORG | | applied to the registers that contain the | | BESB2ORG | | lower field. | ### **Chroma Plane Origin Address** The Chroma Plane Origin address of buffer A and B for fields 1 and 2 is achieved by: $$chroma\_plane\_origin\_address = \left[\frac{croptop + (offsettop - S_C)_{abs}*besviscal}{2*420 format}\right]_{25.0}*BESPITCH \\ + chroma+plane\_base\_address \\ + beshmir* \left(\left[srcwidth*\frac{dataformat}{420 format}\right]_{Floor}^{} - 1\right)$$ | Register | Function | Comment | |-----------|-------------------------------------------------|-------------------------------------------------| | BESA1CORG | | When <i>de-interlace conversion</i> is desired, | | BESA2CORG | [ chroma_plane_origin_address ] <sub>25.0</sub> | the subpixel compensation value ( $S_C$ ) is | | BESB1CORG | | applied to the registers that contain the | | BESB2CORG | | lower field. | #### **Chroma 3-Plane Origin Address** | Register | Function | Comment | |------------|----------|-------------------------------------------------| | BESA1C3ORG | | When <i>de-interlace conversion</i> is desired, | | BESA2C3ORG | | the subpixel compensation value ( $S_C$ ) is | | BESB1C3ORG | | applied to the registers that contain the | | BESB2C3ORG | | lower field. | ### **Vertical Weight Starting Value** The Vertical Weight Starting Value registers are programmed as follows (the weight is the same for buffer A and B): If de-interlaced conversion is desired and is the lower field, then lf offsettop \* besviscal $\ge 0.5$ Then weight = -0.5 + offsettop weight = -(0.5 + offsettop \* besviscal)Else **Else** weight = offsettop \* besviscal | Register | Fields | Function | Comment | |-------------|-----------|--------------------|----------------------------------------------| | BESV1WGHT | bes1wght | [weight] $_{0.14}$ | When de-interlace conversion is desired, | | BESVIVVOIII | bes1wghts | sign of weight | the subpixel compensation value ( $S_C$ ) is | | BESV2WGHT | bes2wght | 0 3 0.14 | applied to the registers that contain the | | BLSVZVVGIII | bes2wghts | sign of weight | lower field. | ### **Vertical Source Last Position** The vertical source last position for field 1 or 2 is achieved by: $$\textit{vsrclst} = \textit{srcheight} - 1 - [\textit{croptop} + (\textit{offsettop} - \textit{S}_{\textit{C}})_{abs} * \textit{besviscal}]_{10.0}$$ | Register | Fields | Function | Comment | |-------------|-------------|--------------------------------------|---------------------------------------------------------------------------------------| | BESV1SRCLST | besv1srclst | - [ <i>vsrclst</i> ] <sub>10.0</sub> | When de-interlace conversion is desired, the subpixel compensation value ( $S_C$ ) is | | BESV2SRCLST | besv2srclst | [VSICIST] <sub>10.0</sub> | applied to the registers that contain the lower field. | ### **Vertical Source Start Polarity** The vertical source start polarity for field 1 or 2 is achieved by: | Register | Fields | Function | | |----------|-------------|--------------------------------------------------------------------------|--| | BESCTL | besv1srcstp | Set if [creation (offsetten S.) * hespiscal ] is | | | | besv2srcstp | Set if $[croptop + (offsettop - S_C)_{abs} * besviscal]_{FLOOR}$ is odd. | | # 4.10.4 Keying ◆ *Note:* Refer to the CRTC section for bandwidth usage when enabling the Backend Scaler. ## 4.10.4.1 Color Keying The field **colkeyen** of **XKEYOPMODE** register selects the type of display for the video window. In color keying mode **colkeyen** = 1. Color keying works by first comparing to see if the pixel color should be used or masked. If the pixel color matches the key color; a single bit is generated signifying a match or no match. Coordinate keying is used at the end to verify that the current coordinate is inside the Backend Scaler window. The color key mask registers (**XCOLMSKRED**, **XCOLMSKGREEN**, **XCOLMSKBLUE**) mask bit-to-bit with the color index of the palette. Some LSB of the mask value can be set to '0' when range keying is required. The color key registers (**XCOLKEYRED**, **XCOLKEYGREEN**, **XCOLKEYBLUE**) must be programmed with the appropriate color. ### 4.10.4.2 Overlay Keying The field **colkeyen** of **XKEYOPMODE** register selects the type of display for the video window. In overlay keying mode **colkeyen** = 0. The overlay keying uses only the coordinates of the Backend Scaler window to perform keying between graphic and video data, regardless of keying color. # 4.10.5 Miscellaneous Functions # 4.10.5.1 Horizontal Mirroring Horizontal mirroring is set by **beshmir** control bit and the origin address must be pointing to the top right corner of the source. ## **Horizontal Mirroring:** Horizontal mirroring affects the horizontal source positioning registers **BESHSRCST** and **BESHSRCEND**, and horizontal inverse scaling factor register **BESHISCAL**. # 4.10.6 BES Parameter Example: The following figure is an example of a source window with full source cropping and full destination offset: ## Source Image: # 4.11 Interrupt Programming The Matrox G400 has 11 interrupt sources: 7 Graphics Engine Interrupts and 4 Video Interrupts. #### **Graphics Engine Interrupts:** #### 1. Soft Trap interrupt This interrupt is generated when a write to the **SOFTRAP** register is executed (refer to 'Programming Bus Mastering for DMA Transfers' on page 4-12 and to the **SOFTRAP** register description). #### 2. Pick interrupt This interrupt is used to help with item selection in a drawing. A rectangular pick region is programmed using the clipper registers (YTOP, YBOT, CXLEFT, CXRIGHT). All planes must be masked by writing FFFFFFFFh to the PLNWT register. The drawing engine then redraws every primitive in the drawing. When pixels are output in the clipped region, the pick pending status is set. After a primitive has been initialized, the STATUS register's pickint bit can be polled to determine if some portion of the primitive lies within the clipping region. #### 3. Vertical Sync interrupt This interrupt is generated every time the vsync signal goes active. It can be used to synchronize a process with the video raster such as frame by frame animation, etc. The **vsync** interrupt enable and clear are both located in the **CRTC11** VGA register. #### 4. Vertical Line interrupt This interrupt is generated when the value of the **linecomp** field of **CRTC18** equals the current vertical count value. This interrupt is more flexible than the vertical sync interrupt because it allows interruption on any horizontal line (including blank and sync lines). #### 5. External interrupt This interrupt is generated when the external interrupt line is driven active. It is the responsibility of the external device to provide the clear and enable functions. #### 6. Warp interrupt This interrupt is generated when there is a memory miss. (One in each warp.) #### 7. WARP cache interrupt This interrupt is generated when there is a cache miss. (One in each warp.) #### 8. Second CRTC Vertical Line Interrupt This interrupt is generated when the value of the **c2vlinecomp** field in the **C2MISC** register equals the current count value. #### **Video Interrupts:** 1. Video In Vertical Sync interrupt This interrupt is generated when a video input vsync is detected. This interrupt is located in the **VSTATUS** register. 2. Codec Command Complete interrupt This interrupt is generated when the codec interface has completed executing the commands in the command buffer. The interrupt is located in the **VSTATUS** register 3. Codec Buffer Level interrupt This interrupt is generated when the Codec interface's hardware pointer (CODECHARDPTR) is equal to the value set in the **CODECHOSTPTR**. This interrupt is located in the **VSTATUS** register. 4. Decompression End of Image interrupt This interrupt is posted when **stopcodec** is a '1'. The Codec Interface is decompressing data, and the FFD9h end of image marker was detected in the data stream. This interrupt is located in the **VSTATUS** register. Table 4-12: Supported Functionality for each Interrupt Source | Туре | Interrupt | STATUS | EVENT | ENABLE | CLEAR | |---------|------------------------|-----------|--------------------|-------------------|-------------------| | | Soft trap | | softrapen | softrapien | softrapicIr | | | Soft trap | | STATUS<0> | IEN<0> | ICLEAR<0> | | | Pick | _ | pickpen | pickien | pickiclr | | | FICK | | STATUS<2> | IEN<2> | ICLEAR<2> | | | Vertical sync | vsyncsts | vsyncpen | vinten | vintclr | | | vertical sync | STATUS<3> | STATUS<4> | <b>CRTC11</b> <5> | <b>CRTC11</b> <4> | | | Vertical line | | vlinepen | vlineien | vlineicIr | | | vertical fille | | STATUS<5> | IEN<5> | ICLEAR<5> | | | External | extpen | | extien | | | Graphic | External | STATUS<6> | | IEN<6> | | | Engine | WARP | _ | wpen | wien | wiclr | | | WARP | _ | STATUS<7> | IEN<7> | ICLEAR<7> | | | WARP cache | _ | wcpen | wcien | wciclr | | | WAINI Cache | | STATUS<8> | IEN<8> | ICLEAR<8> | | | 2nd CRTC vertical line | _ | c2vlinepen | c2vlineien | c2vlineiclr | | | | _ | STATUS<9> | IEN<9> | ICLEAR<9> | | | WARP1 | _ | wpen1 | wien1 | wiclr1 | | | | _ | STATUS<10> | IEN<10> | ICLEAR<10> | | | WARP1 cache | _ | wcpen1 | wcien1 | wciclr1 | | | WARFI Cache | | <b>STATUS</b> <11> | IEN<11> | ICLEAR<11> | | | Video In verme | | vinvsyncpen | vinvsyncien | vinvsynciclr | | | Video In vsync | | VSTATUS<0> | VIEN<0> | VICLEAR<0> | | | Codec command done | _ | cmdcmplpen | cmdcmplien | cmdcmpliclr | | 17.1 | Codec command doffe | _ | VSTATUS<1> | VIEN<1> | VICLEAR<1> | | Video | C 1 1 CC 1 1 | _ | blvlpen | blvlien | blvliclr | | | Codec buffer level | | VSTATUS<2> | VIEN<2> | VICLEAR<2> | | | Codec decompression | _ | dcmpeoipen | dcmpeoiien | dcmpeoiiclr | | | end of image marker | | VSTATUS<3> | VIEN<3> | VICLEAR<3> | STATUS Indicates which bit reports the current state of the interrupt source. EVENT Indicates which bit reports that the interrupt event has occurred. **ICLEAR** A pending bit is kept set until it is cleared by the associated clear bit. **IEN** Each interrupt source may or may not take part in activating the PINTA/ hardware interrupt line. The EVENT and STATUS flags are not affected by interrupt enabling or $\,$ disabling. **VSTATUS** Indicates which bit reports the current state of the video interrupt source. **VICLEAR** A pending bit remains set until it is cleared by the associated clear bit. **VIEN** Each interrupt source may or may not take part in activating the PINTA/hardware interrupt line. The **VSTATUS** flags are only set when the enable bit in **VIEN** for each respective source is on. #### **◆** *Note*: - Clear interrupts before enabling them - vsyncpen is set on the rising edge of vsync - pickpen is set on the first pixel within the clipping box - vlinepen is set at the beginning of the line - vinvsyncpen is set after a vsync is detected and the video in unit has completed writing the data to memory. - c2vlinepen is set at the beginning of the line. # 4.12 Power Saving Features ## 4.12.1 Entering Power Saving Mode The Matrox G400 supports four power conservation features: - DPMS is supported directly, through the following control bits: - Video can be disabled using **scroff** blanking bit (**SEQ1**<5>) - Vertical sync can be forced inactive using vsyncoff (CRTCEXT1) - Horizontal sync can be forced inactive using **hsyncoff** (**CRTCEXT1**) - The video section can be powered down using the following steps: - 1. Set bits scroff, hsyncoff and vsyncoff to '1'. - 2. Disable the cursor (set the **curmode** field to '00'). - 3. Set the **pixclkdis** field of **XPIXCLKCTRL** to '1'. - 4. Power down the DAC. - 5. Power down the LUT. - 6. Power down the Pixel PLL. - Chip power consumption can be further reduced by shutting-down the drawing engine and slowing-down the system clocks. The procedure below *must* be followed: - 1. Power down the video section following the procedure above. - 2. Wait for **dwgengsts** to become '0'. - 3. If the contents of the frame buffer must be preserved, MCLK must be running and the **rfhcnt** field of the **OPTION** register must be re-programmed according to the new MCLK frequency (normally, set rfhcnt to '0001'). - 4. Program the memory clock to the desired value following the procedure in section 4.7.8.5 (see (B) Changing the System PLL Frequency on page 4-93). The recommended PLL oscillation frequency is 6.66MHz (N=107, M=28, P=7, S=0). - 5. Set mclkdiv to '1' (gclkdiv should already be '0' and must be set to '0' if that is not already the case) following the procedure in section 4.7.8.5 (see (C) Changing the System Clock Source, MCLK, or GCLK Division Factor on page 4-93). - The second CRTC is powered down by setting the **c2pixclkdis** field of the **C2CTL** register to '1'. This programming value turns off the second CRTC clock. The second CRTC registers are *not* affected by this setting, therefore, these registers can be programmed while the second CRTC is powered down. - •• *Note:* In Power Saving mode, *do not* use, or initialize, the drawing engine. - Note: Matrox G400 supports PCI Bus Power Management Interface specification 1.0.(See the PM\_CSR register on page 4-26.) # 4.12.2 Coming Out of Power Saving Mode When coming out of Power Saving Mode, do the following: - Step 1. Set mclkdiv to '0' following the procedure in section (See 'Clock Source Selection / PLL Reprogramming' on page 4-93). - Program the System PLL to normal frequency following the procedure in section (See 'Clock Step 2. Source Selection / PLL Reprogramming' on page 4-93). - Program **rfhcnt** to its normal value. Step 3. - Step 4. Power up the **Pixel PLL**. - Power up the **LUT**. Step 5. - Step 6. Power up the **DAC**. - Set the **pixclkdis** field of **XPIXCLKCTRL** to '0', or reprogram the **Pixel PLL** to a new operat-Step 7. ing frequency if desired by following the procedure in section (See 'Clock Source Selection / PLL Reprogramming' on page 4-93). - Reset bits scroff, vsyncoff and hsyncoff to '0'. Step 8. # 4.13 Accessing the Serial EEPROM The page write sizes of serial eeproms may vary between manufactuers. The Matrox G400 is designed to support up to 16 bytes for a small serial eeprom (128 to 512 bytes) and up to 128 bytes for a large serial eeprom (32 or 64 Kbytes). It is possible to access any combination of bytes in a dword of the serial eeprom (reading or writing). There is a read or a write cycle for each non-consecutive byte in a dword, and for every dword, except when a page write is possible (in this case there will be one write cycle for the entire page write). To access the serial eeprom, **biosen** and **romen** must be set to '1', and **rombase** must be mapped. To write the serial eeprom, **eepromwt** must also be set to '1'. The process of writing the serial eeprom is as follows: - **Step 1.** Find the size of the serial eeprom - **Step 2.** Find the size of the page write - **Step 3.** Decide how to reorder the data to be written - **Step 4.** Execute the writes #### Step details: - 1. The size of the serial eeprom is indicated by the reset value of **biosen** (biosboot). - '0': small serial eeprom - '1': big serial eeprom - 2. To determine the size of the page write: If biosboot = '0': - 1. Write a DW at address 0x04 of the serial eeprom. - 2. Write a DW at address 0x08 of the serial eeprom. - 3. Read a DW at address 0x08 of the serial eeprom. - 4. If the data is the one written in 2, then the page write size is 16 bytes. If not, the page write size is 8 bytes. If biosboot = '1': - 1. Write a DW at address 0x3C of the serial eeprom. - 2. Write a DW at address 0x40 of the serial eeprom. - 3. Read a DW at address 0x40 of the serial eeprom. - 4. If the data is the one written in 2, then the page write size is 128 bytes. If not, the page write size is 64 bytes. At present, 8/16 bytes and 64/128 bytes are the only known page write sizes. If there was a smaller page size, the procedure would continue with 5), 6), 7), 8) at half the addresses to determine the proper page size. In the event of a bigger page size, Matrox G400 could not support a page write only version of that serial eeprom. If the page size is 16 bytes (for a small serial eeprom) or 128 bytes (for a big serial eeprom), proceed to step 4. - 3. The size of the page write is smaller than the one hard-coded in the Matrox G400. That means that care must be taken when sending the writes to the Matrox G400's serial eeprom. The Matrox G400 has a 2 dword ROMFIFO serving as a dword accumulator. The Matrox G400 will perform a page write when the ROMFIFO is full, the addresses are consecutive, both dwords are writes, and all the bytes within the dwords are enabled. If the transferred dword is the last before the boundary of the page write size (0x7C for a big serial eeprom), then, after transferring the data, the Matrox G400 will stop the page write. If the real page write size of the serial eeprom is smaller, the second half of the page size will always be written over the first half. - •• *Note:* To avoid this write the serial eeprom starting from the end, by blocks of its page write size. #### Example: 128 byte serial eeprom with an 8 byte page write size. | Access | beN | Address | | | |--------|-----|-------------------------------|--|--| | write | 0x0 | 0X78 one page write (8 bytes) | | | | write | 0x0 | 0x7C one page write (8 bytes) | | | | write | 0x0 | 0x70 | | | | write | 0x0 | 0x74 a second page write | | | | write | 0x0 | 0x68 | | | | write | 0x0 | 0x6C | | | | | ••• | | | | | write | 0x0 | 0x08 | | | | write | 0x0 | 0x0C | | | | write | 0x0 | 0x00 | | | | write | 0x0 | 0x04 | | | Other possible solutions are inserting a delay or reading from the serial eeprom between the write transfers at the end of the page write. The solution displayed above will always prove to be faster since accessing the serial eeprom is a long process (the clock runs at less than 5 MHz per bit). In reality, the blocks could be re-arranged in any way except consecutively. This can be done even when the page write size is the biggest one, as long as the blocks are at least the size of the page write. If the blocks are smaller, there will still be a page write, but not as much data will be transferred, and you will still have to wait for the write cycle time to complete before being able to transfer more data. 4. Transfer the data to the Matrox G400. When a page write occurs, no accesses are transferred to the serial eeprom until the write cycle time is over (up to 10 ms), therefore, the ROMFIFO will remain full for a long time and will force retries on the bus when accessed. There is no way to determine if the ROMFIFO is full. If retries are an issue, insert delays between page write transfers, or program the **noretry** bit to '1' in the **OPTION** register. # 4.13.1 **SEEPROM State Machine Bypass** The SEEPROM state machine can be bypassed by software programming. #### **SEEPROM Bypass Register** The register fields are located in the **CFG\_OR** register In bypass mode, when writing to this register drive the serial data output "q" pin of the e2pq <16> **SEEPROM** #### MGI Confidential | e2pbypcsn<br><17> | In bypass mode, writing to this register drives the chip select "S" pin on the SEEPROM. | |-------------------|------------------------------------------------------------------------------------------------| | e2pbypd<br><18> | In bypass mode, writing to this register drives the serial data of the "D" pin on the SEEPROM. | | e2pbypclk<br><19> | In bypass mode, writing to this register drives the serial clock "C" pin on the SEEPROM. | | e2pbyp<br><20> | <ul><li>0: normal SEEPROM use</li><li>1: SEEPROM state machine bypass mode.</li></ul> | The software *must* comply with the SEEPROM specification when driving the control signals **e2pbypcsn**, **e2pbypclk** and reading the serial output **e2pq**. # 4.14 Second CRTC Programming #### 4.14.1 Characteristics The 2nd CRTC has these following characteristics: - Second desktop outputs onto the VDOUT bus to MGA-TVO. - RGB modes: - They are output directly onto the VDOUT bus on both edges of the clock without LUT and/or H/W cursor. - 32-bit RGB 8:8:8 format: 12 bits of data on both edges of clock (24 bit RGB, the alpha data is dropped). - 16-bit RGB 5:6:5 format: 12 bits of data on both edges of clock (each of 5:6:5 components are expanded to 8 bits by copying MSB to LSB positions). - 15-bit RGB 1:5:5:5 format: 12 bits of data on both edges of clock (each of 5:5:5 components are expanded to 8 bits by copying MSB to LSB positions). - These surfaces are scanned as a non-interlaced raster. - No zoom support. - Panning limited on 8 quadword boundaries. - No backend scaler support. - VDOUT supports resolutions up to 1280 x 1024 at 60 Hz (112 MHz), for panel-like mode. - ITU-R BT656 output modes: - YCbCr 4:2:2 and YCbCr 4:2:0 modes: YCbCr surfaces in the frame buffer are scanned as an interlaced or non-interlaced raster. - The 3-plane and 4-plane YCbCr 4:2:0 data formats are supported. - It outputs onto the VDOUT bus as an 8-bit ITU-R BT656 data stream on each rising edge of the clock. - ARGB 32 bpp mode: A 32 bpp ARGB surface in the frame buffer is scanned as an interlaced raster. A RGB to YCbCr color space converter is in the output path. The upper nibble of the VDOUT bus is used to output the 8-bit alpha as a 4-bit multiplex. - RGB15 & RGB16 are also supported as the above. The alpha-bit in RGB15 is programmable with the 16-bit registers: c2bpp15halpha and c2bpp15lalpha. - The output of the color space converter can be dithered on luminance. It also has a filter for the luminance and the chrominance. Both filters can be enabled independently. The filtering function is 1/4, 1/2, 1/4. - Two frame buffer YCbCr 4:2:2 formats are supported: UYVY and YUY2. - The HD0 1280x720p @ 24 and HDO 704x480p @ 60 Hz are supported. - Second CRTC to VIP port video (reconfigure in output): It uses the same ITU-R BT656 mode described above. The video data is output onto both the VIP bus (bi-directional) and to the VDOUT bus. - DVD support: 4-plane YCbCr 4:2:0 data format is used for DVD playback. - The 4th plane contains the sub-picture (graphics overlay) data. - The overlay is 8 bpp plane: 4 bits for the 24-bit YCbCr LUT index and 4 bits for sub-picture mixing key (giving opacity of the sub-picture). - It outputs onto the VDOUT bus as an 8-bit ITU-R BT656 data stream on each rising edge of the clock. - It can be fed back internally through the VIP bus and grabbed back into off screen memory as a YCbCr 4:2:2 surface. At this point, the data can be used by either the backend scaler or the frontend scaler (texture engine). Then, DVD video can be displayed in a scaled window on the desktop. - It provides full screen DVD playback via VDOUT bus and an external encoder while simultaneously supporting DVD in a window on the desktop. Figure 4-15: Second CRTC Data Path #### Master Mode: - The 2nd CRTC sends the video data via the VDOUT bus to an external panel link device. - The 2nd CRTC drives the VDOCLK in master mode. #### ■ Slave Mode: - The 2nd CRTC sends the video data via the VDOUT bus to an external encoder. - An external encoder controls the 2nd CRTC with the VDOCLK and VIDRST input pins. - YCbCr mode: the VDOCLK pin caries the 27 MHz clock from the external encoder; the VOBLANKN pin gives the gated clock to the external encoder; and the VIDRST pin gives the video reset and the field value from the external encoder. - Swap Mode: Matrox G400 supports a full swap of the primary CRTC and the 2nd CRTC to the outputs. - Usually, the primary CRTC/RAMDAC/backend scaler drives the on chip RGB DAC's and the 2nd CRTC drives the VDOUT bus. - Either the primary CRTC or the 2nd CRTC can drive the VDOUT. - Either the primary CRTC or 2nd CRTC can drive the on chips RGB DAC's. - When the 2nd CRTC drive the DAC, the maximum pixel clock frequency is 135 MHz (1280x1024x75) and interlace modes are not supported. # 4.14.2 Horizontal Timing The horizontal counter programming values must be a multiple of the height (the 3 LSBs set to '000'). The 2nd CRTC horizontal timings are controlled by the following register fields (see Figure 4-5): | c2htotal<br><11:0> | Horizontal Total. This field defines the total horizontal scan period in pixels. | |----------------------|------------------------------------------------------------------------------------------------------------------------------| | • | Horizontal Display enable End. This field determines the number of displayed pixels per line. | | c2hsyncstr<br><11:0> | Start Horizontal Sync pulse. The horizontal sync signal becomes active when the horizontal pixel counter reaches this value. | | c2hsyncend<br><11:0> | End Horizontal Sync pulse. The horizontal sync signal becomes inactive when the horizontal pixel counter reaches this value. | The horizontal counter can be preloaded upon an edge on the **VIDRST** pin. This preloading is used to synchronize the 2nd CRTC with an external video encoder. The following register fields set the horizontal preloading: | <b>c2vidrstmod</b> VIDRST Detection Mode. This bit selects the video reset detection m | | | | |----------------------------------------------------------------------------------------|-----------------------------------------------------------------------|--|--| | <1:0> | the VIDRST pin. | | | | c2hproloadon | Horizontal Counter Preload Enable. This bit enables the capability of | | | | cznpreioauen | preloading the horizontal counter with the <b>VIDRST</b> pin. | | | # 4.14.3 Vertical Timing The 2nd CRTC vertical timings are controlled by the following register fields (see Figure 4-6): | c2vtotal | Vertical Total. Determines the total number of lines per frame in non- | |----------------------|---------------------------------------------------------------------------------------------------------------------------------------------| | <11:0> | interlace mode or per field 0 in interlace mode. | | c2vdispend<br><11:0> | Vertical Display enable End. Determines the total number of displayed lines per frame in non-interlace mode or per field in interlace mode. | | c2vsyncstr<br><11:0> | Start Vertical Sync Pulse. The vertical sync signal becomes active when the vertical line counter reaches this value. | | c2vsyncend<br><11:0> | End Vertical Sync Pulse. The vertical sync signal becomes inactive when the vertical line counter reaches this value. | The vertical counter can be preloaded upon an edge on the VIDRST pin. The preloading is used to synchronize the 2nd CRTC with an external video encoder. The following register fields set the vertical preloading: | c2vdirstmod | VIDRST Detection Mode. This bit selects the video reset detection mode on | |------------------|------------------------------------------------------------------------------------| | <1:0> | the VIDRST pin. | | c2vpreloaden | Vertical Counter Preload Enable. This bit enables the capability of | | 0_1 p. 0.0 d.d.o | preloading the vertical counter with the <b>VIDRST</b> pin. | | c2fieldlength | Field Length Polarity. Selects the polarity of the field signal according to the | | Czneidlength | VIDRST pin after a video reset. | | offioldpol | Field Identification Polarity. Selects the polarity of the field identification | | c2fieldpol | (field value in the video timing codes) signal according to the <b>VIDRST</b> pin. | # 4.14.4 Second CRTC Memory Address Generator All the addresses programmed in the 2nd CRTC address generator *must* be aligned on an 8 quadword boundary (the 6 LSBs set to '000000'). All these address registers are double-buffered. This means that, the addresses written in these registers become effective *after* the beginning of the next vertical blank. At this point, the programming values written during the drawing of a frame will only affect the next frame, therefore, no tearing occurs. In RGB non-interlace mode, the following register fields are used to program the 2nd CRTC memory address counter: | <b>c2startadd0</b> Start Address. This register holds the address of the first pixel after the | | | |------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--| | <b>&lt;24:0&gt;</b> vertical retrace of each screen refresh in non-interlace mode. | | | | | Logical Line Width of the Screen. This field stores the offset between the current line start address and the next line start address. | | In YCbCr interlace mode, the following register fields are used to program the 2nd CRTC memory address counter: | c2startadd0 | Start Address of the Field #0. This register holds the address of the first pixel | | | |----------------|--------------------------------------------------------------------------------------|--|--| | <24:0> | after the vertical retrace of each field #0 screen refresh in interlace mode. | | | | c2startadd1 | Start Address of the Field #1. This register holds the address of the first pixel | | | | <24:0> | after the vertical retrace of each field #1 screen refresh in interlace mode. | | | | c2pl2startadd0 | Plane #2 Start Address of the Field #0. In 3-plane YCbCr420 mode, this | | | | <24:0> | register holds the address of the first Cb data after the vertical retrace of each | | | | <24.02 | field #0 screen refresh. | | | | c2pl2startadd1 | Plane #2 Start Address of the Field #1. In 3-plane YCbCr420 mode, this | | | | <24:0> | register holds the address of the first Cb data after the vertical retrace of each | | | | <b>\Z</b> 4.0> | field #1 screen refresh. | | | | c2pl3startadd0 | Plane #3 Start Address of the Field #0. In 3-plane YCbCr420 mode, this | | | | <24:0> | register holds the address of the first $Cr$ data after the vertical retrace of each | | | | \Z-1.02 | field #0 screen refresh. | | | | c2pl3startadd1 | Plane #3 Start Address of the Field #1. In 3-plane YCbCr420 mode, this | | | | <24:0> | register holds the address of the first Cr data after the vertical retrace of each | | | | \Z-4.0> | field #1 screen refresh. | | | | c2offset | Logical Line Width of the Screen. This field stores the offset between the | | | | <13:0> | current line start address and the next line start address. | | | The following register fields are used to control the 2nd CRTC memory address generator: | c2en | Second CRTC Enable. Stops the address generator. No new requests to read | |------------------|----------------------------------------------------------------------------------------------| | CZGII | from memory are generated. | | c2depth<br><2:0> | Color Depth. | | c2vcbcrsingle | Vertical CbCr Single. Disables the repetition of a <i>CbCr</i> line for 2 luma lines. | | c2interlace | Interlace Mode. Enables all the field #1 registers. | | c2subpicen | Sub-picture Enable. Sub-picture data is applied on the output of the second CRTC. | | c2offsetdiven | Sub-picture Offset Division. Selects the offset of the sub-picture data in the frame buffer. | The following figures illustrate the 4 different groupings of the YCbCr 4:2:0 data in the frame buffer. The address generator registers should be programmed in order to meet one of the groupings. •• *Note:* The small arrows in the illustrations indicate the plane start addresses. For example, an arrow labeled "Cb0" illustrates the plane #2 start address of the field #0. Figure 4-16: 420 YCbCr data groupings 420 YCbCr data interleaved in the memory used with : c2vcbcrsingle = '1' and c2offsetdiven = '0' <sup>\*</sup> The line numbers represent the line number in the resulting frame. ## Resulting frame | | | | | | • | |-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------| | Y(0,0) | Y(0,1) | Y(0,2) | Y(0,3) | Y(0,4) | Y(0,5) | | Cb(0 & 1,0) Cr(0 & 1,0) | Cb(0 & 1,0) Cr(0 & 1,0) | Cb(0 & 1,2) Cr(0 & 1,2) | Cb(0 & 1,2) Cr(0 & 1,2) | Cb(0 & 1,4) Cr(0 & 1,4) | Cb(0 & 1,4) Cr(0 & 1,4) | | Y(1,0) | Y(1,1) | Y(1,2) | Y(1,3) | Y(1,4) | Y(1,5) | | Cb(0 & 1,0) Cr(0 & 1,0) | Cb(0 & 1,0) Cr(0 & 1,0) | Cb(0 & 1,2) Cr(0 & 1,2) | Cb(0 & 1,2) Cr(0 & 1,2) | Cb(0 & 1,4) Cr(0 & 1,4) | Cb(0 & 1,4) Cr(0 & 1,4) | | Y(2,0) | Y(2,1) | Y(2,2) | Y(2,3) | Y(2,4) | Y(2,5) | | Cb(2 & 3,0) Cr(2 & 3,0) | Cb(2 & 3,0) Cr(2 & 3,0) | Cb(2 & 3,2) Cr(2 & 3,2) | Cb(2 & 3,2) Cr(2 & 3,2) | Cb(2 & 3,4) Cr(2 & 3,4) | Cb(2 & 3,4) Cr(2 & 3,4) | | Y(3,0) | Y(3,1) | Y(3,2) | Y(3,3) | Y(3,4) | Y(3,5) | | Cb(2 & 3,0) Cr(2 & 3,0) | Cb(2 & 3,0) Cr(2 & 3,0) | Cb(2 & 3,2) Cr(2 & 3,2) | Cb(2 & 3,2) Cr(2 & 3,2) | Cb(2 & 3,4) Cr(2 & 3,4) | Cb(2 & 3,4) Cr(2 & 3,4) | | Y(4,0) | Y(4,1) | Y(4,2) | Y(4,3) | Y(4,4) | Y(4,5) | | Cb(4 & 5,0) Cr(4 & 5,0) | Cb(4 & 5,0) Cr(4 & 5,0) | Cb(4 & 5,2) Cr(4 & 5,2) | Cb(4 & 5,2) Cr(4 & 5,2) | Cb(4 & 5,4) Cr(4 & 5,4) | Cb(4 & 5,4) Cr(4 & 5,4) | | Y(5,0) | Y(5,1) | Y(5,2) | Y(5,3) | Y(5,4) | Y(5,5) | | Cb(4 & 5,0) Cr(4 & 5,0) | Cb(4 & 5,0) Cr(4 & 5,0) | Cb(4 & 5,2) Cr(4 & 5,2) | Cb(4 & 5,2) Cr(4 & 5,2) | Cb(4 & 5,4) Cr(4 & 5,4) | Cb(4 & 5,4) Cr(4 & 5,4) | | Y(6,0) | Y(6,1) | Y(6,2) | Y(6,3) | Y(6,4) | Y(6,5) | | Cb(6 & 7,0) Cr(6 & 7,0) | Cb(6 & 7,0) Cr(6 & 7,0) | Cb(6 & 7,2) Cr(6 & 7,2) | Cb(6 & 7,2) Cr(6 & 7,2) | Cb(6 & 7,4) Cr(6 & 7,4) | Cb(6 & 7,4) Cr(6 & 7,4) | | Y(7,0) | Y(7,1) | Y(7,2) | Y(7,3) | Y(7,4) | Y(7,5) | | Cb(6 & 7,0) Cr(6 & 7,0) | Cb(6 & 7,0) Cr(6 & 7,0) | Cb(6 & 7,2) Cr(6 & 7,2) | Cb(6 & 7,2) Cr(6 & 7,2) | Cb(6 & 7,4) Cr(6 & 7,4) | Cb(6 & 7,4) Cr(6 & 7,4) | # pixel: field 0 data: Cb(6 & 7,0) Cr(6 & 7,0) field 1 data: V(7.0) line number pixel number Figure 4-17: 420 YCbCr data groupings (cont) # 420 YCbCr data not interleaved in the memory used with: c2vcbcrsingle = '0' and c2offsetdiven = '0' <sup>\*</sup> The line numbers represent the line number in the resulting frame. #### Resulting frame | Y(0,0) | Y(0,1) | Y(0,2) | Y(0,3) | Y(0,4) | Y(0,5) | |-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------| | Cb(0 & 2,0) Cr(0 & 2,0) | Cb(0 & 2,0) Cr(0 & 2,0) | Cb(0 & 2,2) Cr(0 & 2,2) | Cb(0 & 2,2) Cr(0 & 2,2) | Cb(0 & 2,4) Cr(0 & 2,4) | Cb(0 & 2,4) Cr(0 & 2,4) | | Y(1,0) | Y(1,1) | Y(1,2) | Y(1,3) | Y(1,4) | Y(1,5) | | Cb(1 & 3,0) Cr(1 & 3,0) | Cb(1 & 3,0) Cr(1 & 3,0) | Cb(1 & 3,2) Cr(1 & 3,2) | Cb(1 & 3,2) Cr(1 & 3,2) | Cb(1 & 3,4) Cr(1 & 3,4) | Cb(1 & 3,4) Cr(1 & 3,4) | | Y(2,0) | Y(2,1) | Y(2,2) | Y(2,3) | Y(2,4) | Y(2,5) | | Cb(0 & 2,0) Cr(0 & 2,0) | Cb(0 & 2,0) Cr(0 & 2,0) | Cb(0 & 2,2) Cr(0 & 2,2) | Cb(0 & 2,2) Cr(0 & 2,2) | Cb(0 & 2,4) Cr(0 & 2,4) | Cb(0 & 2,4) Cr(0 & 2,4) | | Y(3,0) | Y(3,1) | Y(3,2) | Y(3,3) | Y(3,4) | Y(3,5) | | Cb(1 & 3,0) Cr(1 & 3,0) | Cb(1 & 3,0) Cr(1 & 3,0) | Cb(1 & 3,2) Cr(1 & 3,2) | Cb(1 & 3,2) Cr(1 & 3,2) | Cb(1 & 3,4) Cr(1 & 3,4) | Cb(1 & 3,4) Cr(1 & 3,4) | | Y(4,0) | Y(4,1) | Y(4,2) | Y(4,3) | Y(4,4) | Y(4,5) | | Cb(4 & 6,0) Cr(4 & 6,0) | Cb(4 & 6,0) Cr(4 & 6,0) | Cb(4 & 6,2) Cr(4 & 6,2) | Cb(4 & 6,2) Cr(4 & 6,2) | Cb(4 & 6,4) Cr(4 & 6,4) | Cb(4 & 6,4) Cr(4 & 6,4) | | Y(5,0) | Y(5,1) | Y(5,2) | Y(5,3) | Y(5,4) | Y(5,5) | | Cb(5 & 7,0) Cr(5 & 7,0) | Cb(5 & 7,0) Cr(5 & 7,0) | Cb(5 & 7,2) Cr(5 & 7,2) | Cb(5 & 7,2) Cr(5 & 7,2) | Cb(5 & 7,4) Cr(5 & 7,4) | Cb(5 & 7,4) Cr(5 & 7,4) | | Y(6,0) | Y(6,1) | Y(6,2) | Y(6,3) | Y(6,4) | Y(6,5) | | Cb(4 & 6,0) Cr(4 & 6,0) | Cb(4 & 6,0) Cr(4 & 6,0) | Cb(4 & 6,2) Cr(4 & 6,2) | Cb(4 & 6,2) Cr(4 & 6,2) | Cb(4 & 6,4) Cr(4 & 6,4) | Cb(4 & 6,4) Cr(4 & 6,4) | | Y(7,0) | Y(7,1) | Y(7,2) | Y(7,3) | Y(7,4) | Y(7,5) | | Cb(5 & 7,0) Cr(5 & 7,0) | Cb(5 & 7,0) Cr(5 & 7,0) | Cb(5 & 7,2) Cr(5 & 7,2) | Cb(5 & 7,2) Cr(5 & 7,2) | Cb(5 & 7,4) Cr(5 & 7,4) | Cb(5 & 7,4) Cr(5 & 7,4) | Figure 4-18: 420 YCbCr data groupings (cont) # 420 YCbCr data interleaved in the memory used with : c2vcbcrsingle = '0' and c2offsetdiven = '0' <sup>\*</sup> The line numbers represent the line number in the resulting frame. #### Resulting frame | Y(0,0) | Y(0,1) | Y(0,2) | Y(0,3) | Y(0,4) | Y(0,5) | |-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------| | Cb(0 & 2,0) Cr(0 & 2,0) | Cb(0 & 2,0) Cr(0 & 2,0) | Cb(0 & 2,2) Cr(0 & 2,2) | Cb(0 & 2,2) Cr(0 & 2,2) | Cb(0 & 2,4) Cr(0 & 2,4) | Cb(0 & 2,4) Cr(0 & 2,4) | | Y(1,0) | Y(1,1) | Y(1,2) | Y(1,3) | Y(1,4) | Y(1,5) | | Cb(1 & 3,0) Cr(1 & 3,0) | Cb(1 & 3,0) Cr(1 & 3,0) | Cb(1 & 3,2) Cr(1 & 3,2) | Cb(1 & 3,2) Cr(1 & 3,2) | Cb(1 & 3,4) Cr(1 & 3,4) | Cb(1 & 3,4) Cr(1 & 3,4) | | Y(2,0) | Y(2,1) | Y(2,2) | Y(2,3) | Y(2,4) | Y(2,5) | | Cb(0 & 2,0) Cr(0 & 2,0) | Cb(0 & 2,0) Cr(0 & 2,0) | Cb(0 & 2,2) Cr(0 & 2,2) | Cb(0 & 2,2) Cr(0 & 2,2) | Cb(0 & 2,4) Cr(0 & 2,4) | Cb(0 & 2,4) Cr(0 & 2,4) | | Y(3,0) | Y(3,1) | Y(3,2) | Y(3,3) | Y(3,4) | Y(3,5) | | Cb(1 & 3,0) Cr(1 & 3,0) | Cb(1 & 3,0) Cr(1 & 3,0) | Cb(1 & 3,2) Cr(1 & 3,2) | Cb(1 & 3,2) Cr(1 & 3,2) | Cb(1 & 3,4) Cr(1 & 3,4) | Cb(1 & 3,4) Cr(1 & 3,4) | | Y(4,0) | Y(4,1) | Y(4,2) | Y(4,3) | Y(4,4) | Y(4,5) | | Cb(4 & 6,0) Cr(4 & 6,0) | Cb(4 & 6,0) Cr(4 & 6,0) | Cb(4 & 6,2) Cr(4 & 6,2) | Cb(4 & 6,2) Cr(4 & 6,2) | Cb(4 & 6,4) Cr(4 & 6,4) | Cb(4 & 6,4) Cr(4 & 6,4) | | Y(5,0) | Y(5,1) | Y(5,2) | Y(5,3) | Y(5,4) | Y(5,5) | | Cb(5 & 7,0) Cr(5 & 7,0) | Cb(5 & 7,0) Cr(5 & 7,0) | Cb(5 & 7,2) Cr(5 & 7,2) | Cb(5 & 7,2) Cr(5 & 7,2) | Cb(5 & 7,4) Cr(5 & 7,4) | Cb(5 & 7,4) Cr(5 & 7,4) | | Y(6,0) | Y(6,1) | Y(6,2) | Y(6,3) | Y(6,4) | Y(6,5) | | Cb(4 & 6,0) Cr(4 & 6,0) | Cb(4 & 6,0) Cr(4 & 6,0) | Cb(4 & 6,2) Cr(4 & 6,2) | Cb(4 & 6,2) Cr(4 & 6,2) | Cb(4 & 6,4) Cr(4 & 6,4) | Cb(4 & 6,4) Cr(4 & 6,4) | | Y(7,0) | Y(7,1) | Y(7,2) | Y(7,3) | Y(7,4) | Y(7,5) | | Cb(5 & 7,0) Cr(5 & 7,0) | Cb(5 & 7,0) Cr(5 & 7,0) | Cb(5 & 7,2) Cr(5 & 7,2) | Cb(5 & 7,2) Cr(5 & 7,2) | Cb(5 & 7,4) Cr(5 & 7,4) | Cb(5 & 7,4) Cr(5 & 7,4) | Figure 4-19: 420 YCbCr data groupings (cont) # 420 YCbCr data interleaved in the memory used with : c2vcbcrsingle = '0' and c2offsetdiven = '1' <sup>\*</sup> The line numbers represent the line number in the resulting frame. #### Resulting frame | Y(0,0) | Y(0,1) | Y(0,2) | Y(0,3) | Y(0,4) | Y(0,5) | |-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------| | Cb(0 & 2,0) Cr(0 & 2,0) | Cb(0 & 2,0) Cr(0 & 2,0) | Cb(0 & 2,2) Cr(0 & 2,2) | Cb(0 & 2,2) Cr(0 & 2,2) | Cb(0 & 2,4) Cr(0 & 2,4) | Cb(0 & 2,4) Cr(0 & 2,4) | | Y(1,0) | Y(1,1) | Y(1,2) | Y(1,3) | Y(1,4) | Y(1,5) | | Cb(1 & 3,0) Cr(1 & 3,0) | Cb(1 & 3,0) Cr(1 & 3,0) | Cb(1 & 3,2) Cr(1 & 3,2) | Cb(1 & 3,2) Cr(1 & 3,2) | Cb(1 & 3,4) Cr(1 & 3,4) | Cb(1 & 3,4) Cr(1 & 3,4) | | Y(2,0) | Y(2,1) | Y(2,2) | Y(2,3) | Y(2,4) | Y(2,5) | | Cb(0 & 2,0) Cr(0 & 2,0) | Cb(0 & 2,0) Cr(0 & 2,0) | Cb(0 & 2,2) Cr(0 & 2,2) | Cb(0 & 2,2) Cr(0 & 2,2) | Cb(0 & 2,4) Cr(0 & 2,4) | Cb(0 & 2,4) Cr(0 & 2,4) | | Y(3,0) | Y(3,1) | Y(3,2) | Y(3,3) | Y(3,4) | Y(3,5) | | Cb(1 & 3,0) Cr(1 & 3,0) | Cb(1 & 3,0) Cr(1 & 3,0) | Cb(1 & 3,2) Cr(1 & 3,2) | Cb(1 & 3,2) Cr(1 & 3,2) | Cb(1 & 3,4) Cr(1 & 3,4) | Cb(1 & 3,4) Cr(1 & 3,4) | | Y(4,0) | Y(4,1) | Y(4,2) | Y(4,3) | Y(4,4) | Y(4,5) | | Cb(4 & 6,0) Cr(4 & 6,0) | Cb(4 & 6,0) Cr(4 & 6,0) | Cb(4 & 6,2) Cr(4 & 6,2) | Cb(4 & 6,2) Cr(4 & 6,2) | Cb(4 & 6,4) Cr(4 & 6,4) | Cb(4 & 6,4) Cr(4 & 6,4) | | Y(5,0) | Y(5,1) | Y(5,2) | Y(5,3) | Y(5,4) | Y(5,5) | | Cb(5 & 7,0) Cr(5 & 7,0) | Cb(5 & 7,0) Cr(5 & 7,0) | Cb(5 & 7,2) Cr(5 & 7,2) | Cb(5 & 7,2) Cr(5 & 7,2) | Cb(5 & 7,4) Cr(5 & 7,4) | Cb(5 & 7,4) Cr(5 & 7,4) | | Y(6,0) | Y(6,1) | Y(6,2) | Y(6,3) | Y(6,4) | Y(6,5) | | Cb(4 & 6,0) Cr(4 & 6,0) | Cb(4 & 6,0) Cr(4 & 6,0) | Cb(4 & 6,2) Cr(4 & 6,2) | Cb(4 & 6,2) Cr(4 & 6,2) | Cb(4 & 6,4) Cr(4 & 6,4) | Cb(4 & 6,4) Cr(4 & 6,4) | | Y(7,0) | Y(7,1) | Y(7,2) | Y(7,3) | Y(7,4) | Y(7,5) | | Cb(5 & 7,0) Cr(5 & 7,0) | Cb(5 & 7,0) Cr(5 & 7,0) | Cb(5 & 7,2) Cr(5 & 7,2) | Cb(5 & 7,2) Cr(5 & 7,2) | Cb(5 & 7,4) Cr(5 & 7,4) | Cb(5 & 7,4) Cr(5 & 7,4) | # 4.14.5 Register Programming Methodology The second CRTC field indication signal has two functions: - it provides field information to the video encoder (embedded in the 656 video data stream output) on the MAFC port - it selects which field in the frame has one more lines To activate the second CRTC, and to control the starting value of the field signal, the registers below *must* be programmed in the following order: - 1. **c2en** *must* be programmed to '0', to avoid unnecessary requests to the memory controller - 2. Program **c2pixclkdis** to '1', to disable the CRTC2 pixel clock (to stop the vertical and horizontal timing counters) - 3. Program **c2interlace** to '0', to reset the field signal to '0' - 4. Program the following registers with their proper values: - C2PIXCLKSEL - C2DEPTH - C2FIELDLENGTH - C2FIELDPOL - C2VIDRSTMOD - C2HPLOADEN - C2VPLOADEN - C2HDISPEND - C2HTOTAL - C2VDISPEND - C2VTOTAL - C2FIELDLINE0 - C2FIELDLINE1 - 5. Enable the CRTC2 requester: **c2en** = '1' - 6. Enable the CRTC2 pixel clock: **c2pixclkdis** = '0' - 7. Program the **c2interlace** to the proper value By programming the registers in the displayed order, the field bit starts at '0'. This value is preloaded with the VIDRST pin value when: - c2vploaden is enabled, and - c2interlace is enabled, and - a preload is detected onto the VIDRST pin. - •• CAUTION: The c2interlace field should never be modified when the vertical timing counter value (c2vcount) is located between c2fieldline0 and c2vtotal or between c2fieldline1 and c2vtotal. This also means that the vertical counter preload value (c2vpreload) cannot be located in the above mentioned value ranges. ## 4.14.6 DVD Support Programming The 2nd CRTC playback uses 4-plane YCbCr 4:2:0 data format. The fourth plane contains the sub-picture (graphics overlay) data. Each pixel has its own 8-bit sub-picture data (8bpp). In a pixel, the sub-picture data is mapped as shown in the following illustrations: # mixer key color index | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|---| In a 64-bit slice, the sub-picture data is mapped as shown in the following illustration: | 6 | 3 | 56 | | 48 | | 40 | | 32 | | 24 | | 16 | | 8 | | 0 | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----| | | K7 | 17 | K6 | 16 | K5 | 15 | K4 | 14 | K3 | 13 | K2 | 12 | K1 | I1 | K0 | 10 | The color index uses 4 bits to select one of the 16 locations in the sub-picture color LUT. Each location in the LUT contains a valid 24-bit YCbCr value programmed with the **C2SUBPICLUT** register. The valid values reside within these ranges: Each 4-bit mixer key value corresponds to a different alpha value according to the following rules: | Mixer key | Alpha (CL) | |----------------|---------------| | 0 | 0 | | not equal to 0 | mixer key + 1 | The mixer key values range from 0 to 15 while the alpha values range from 0 to 16. An alpha value of '1' is, therefore, impossible. The alpha controls the opacity of the sub-picture over the main picture according to the following formula: $$mixer\_output = \frac{\alpha}{16} sub\_pic + \frac{(16 - \alpha)}{16} main\_pic$$ The following fields in the C2DATACTL and C2SUBPICLUT registers control the sub-picture data formatting in the 2nd CRTC DVD data path: | c2subpicen | Sub-picture Enable. Sub-picture data is applied on the output of the second CRTC. | |------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | c2statickeyen | Static Sub-picture Mixing Key Enable. Static sub-picture mixing key ( <b>c2statickey</b> ) is applied on the sub-picture blender of the second CRTC. | | c2offsetdiven | Sub-picture Offset Division. Select the offset of the sub-picture data in the frame buffer. | | c2statickeye<br><4:0> | Static Sub-picture Mixing Key. Sub-picture mixing key applied to the second CRTC sub-picture blender when <b>c2statickeyen</b> is enabled. Only binary values between 0 and 16 (between "00000" and "10000") are valid. | | c2subpiclutx<br><3:0> | Sub-picture Color LUT Index Register. A binary value that points to the sub-picture color register where data is to be written when the <b>c2subpicylut</b> , <b>c2subpiccblut</b> or <b>c2subpiccrlut</b> fields are accessed. | | c2subpicylut<br><7:0> | Y Value in the Sub-picture Color LUT. Y value written in the color register pointed by the <b>c2subpiclutx</b> field. | | c2subpiccblut<br><7:0> | Cb Value in the Sub-picture Color LUT. Cb value written in the color register pointed by the <b>c2subpiclutx</b> field. | | c2subpiccrlut<br><7:0> | Cr Value in the Sub-picture Color LUT. Cr value written in the color register pointed by the <b>c2subpiclutx</b> field. | A representation of the 2nd CRTC data path is given by Figure 4-15. The following sub-picture configurations are allowed: | Depth | Mixer Key Source | Color Index Source | Settings | |---------------------------|------------------------------------------------|------------------------------------------|-----------------------------------------| | 4-plane<br>YCbCr 420 | From the 4th plane | From the 4th plane | c2subpicen = '1'<br>c2statickeyen = '0' | | 4-plane<br>YCbCr 420 | From the <b>c2statickey</b> field | From the 4th plane | c2subpicen = '1'<br>c2statickeyen = '1' | | 3 or 4-plane<br>YCbCr 420 | From the <b>c2statickey</b> field | From the first location of the color LUT | c2subpicen = '0'<br>c2statickeyen = '1' | | YCbCr 422 | From the <b>c2statickey</b> field | From the first location of the color LUT | c2subpicen = '0'<br>c2statickeyen = '1' | | RGB 32 bpp | From the 8-bit alpha data | From the 8-bit alpha data | c2subpicen = '1'<br>c2statickeyen = '0' | | RGB 32 bpp | From the <b>c2statickey</b> field | From the 8-bit alpha data | c2subpicen = '1'<br>c2statickeyen = '1' | | RGB 32 bpp | From the 8-bit alpha data | From the first location of the color LUT | c2subpicen = '0'<br>c2statickeyen = '0' | | RGB 32 bpp | From the <b>c2statickey</b> field | From the first location of the color LUT | c2subpicen = '0'<br>c2statickeyen = '1' | | RGB 16 bpp | From the <b>c2statickey</b> field | From the first location of the color LUT | c2subpicen = '0'<br>c2statickeyen = '1' | | RGB 15 bpp | From the c2bpp15halpha and c2bpp15alpha fields | From the c2bpp15halpha and c2bpp15lalpha | c2subpicen = '1'<br>c2statickeyen = '0' | | RGB 15 bpp | From the <b>c2statickey</b> field | From the c2bpp15halpha and c2bpp15lalpha | c2subpicen = '1'<br>c2statickeyen = '1' | | RGB 15 bpp | From the c2bpp15halpha and c2bpp15alpha fields | From the first location of the color LUT | c2subpicen = '0'<br>c2statickeyen = '0' | | RGB 15 bpp | From the <b>c2statickey</b> field | From the first location of the color LUT | c2subpicen = '0'<br>c2statickeyen = '1' | # 4.14.7 Data Control The following fields in the C2DATACTL register control the data aspect. | c2dithen | Dither Enable. Dithering is applied on the luma component to smooth out some non-linearities caused by the RGB to YCbCr color space converter. | |------------------------|------------------------------------------------------------------------------------------------------------------------------------------------| | c2yfilten | Y Filter Enable. Filtering is applied on the luma generated by the color space converter. | | c2cbcrfilten | CbCr Filter Enable. Filtering is applied before sub-sampling on the chroma generated by the color space converter. | | c2bpp15halpha<br><7:0> | 15 bpp High Alpha Value. In 15bpp, the value in this field corresponds to an high alpha bit. | | c2bpp15lalpha<br><7:0> | 15 bpp Low Alpha Value. In 15bpp, the value in this field corresponds to a low alpha bit. | # 4.14.8 NTSC Support The field **c2ntscen** in the **C2DATACTL** register enables the NTSC clock killer circuitry. # 4.14.9 Stop the Second CRTC Memory Requests The **c2en** field of the **CRTC2CTL** register controls the second CRTC address generator. When not used, the address generator should *always* be turned off in order to stop all access to memory and, therefore, maximize bandwidth utilization. # 4.14.10 Turning Off the Second CRTC (Power Saving Mode) The second CRTC is powered down by setting the **c2pixclkdis** field of **C2CTL** register to '1'. This programming value turns off the 2nd CRTC clock. The 2nd CRTC registers are not affected by this setting; these registers can be programmed while the second CRTC is powered down. # 4.15 AGP I/O Buffer Compensation The purpose of the compensation is to evaluate the minimum drive required by the AGP buffer to drive a logic '1' (Cpn) and a logic '0' (Cnn). The drive value is 0...7 The register fields are located in the **CFG\_OR** register: - comp\_or<3> - compfreq<7:4> - comporup<11:8> - comporup<15:12> # 4.15.1 Compensation Override Instead of using internal logic, the compensation value can be forced by the software. #### **Compensation Override Procedure** - Step 1. set comp\_or to 1 - Step 2. properly set compordn and comporup - **Note:** Steps 1 and 2 can be done simultaneously. The host interface will update the compensation values when the bus is idle. # Chapter 5: Hardware Designer's Notes | Introduction | 5-2 | |-------------------------------------|------------------| | Host AGP Interface | 5-2 | | Snooping | 5-2 | | EEPROM Devices | 5-3 | | Memory Interface | 5-4 | | SGRAM Configurations | 5-4 | | Video interface | 5-14 | | Slaving the Matrox G400Genlock Mode | 5-15 | | Crystal Resonator Specification | <del>5-</del> 10 | #### 5.1 Introduction The Matrox G400 chip has been designed to minimize the amount of external logic required to build a board. Included among its features are: - Direct interface to the or AGP bus - All necessary support for external devices such as ROM - Direct connection to the RAM - Direct interface with the video and feature connectors #### 5.2 Host AGP Interface The Matrox G400 interfaces with the AGP bus as shown in Figure 5-1. The Matrox G400 acts as an AGP master and a PCI target. The AGP master uses the AGP sideband signal in 1X, 2X and 4X modes addressing mechanism. The PCI target is a medium speed device (it responds with PDEVSEL/ during the second clock after PFRAME/ is asserted). Figure 5-1: AGP Interface # 5.3 Snooping The Matrox G400 performs snooping when VGA I/O is enabled *and* snooping is turned *on*. In this case, two things may occur when the DAC is written to: - 1. If the Matrox G400 is *unable* to process the access immediately, it takes control of the bus and performs a retry cycle. - 2. If the Matrox G400 is *able* to process the access, the access is snooped, and the Matrox G400 processes it as soon as the transaction is completed on the bus. Under normal conditions, only a subtractive agent will respond to the access. There could also be no agent at all (all devices are set to snoop, so a master-abort occurs). In these cases, the snoop mechanism will function correctly. ## 5.4 EEPROM Devices The Matrox G400 supports a few external devices (the SPI-EEPROM is a standard expansion device that is supported by the Matrox G400). Figure 5-2 shows how to connect the serial eeprom devices to the Matrox G400. #### **BIOS EPROM** The Matrox G400 supports 32K x 8 EEPROMs, 64K x 8 EEPROMS, and 128 byte EEPROMS. The following table lists specific EEPROM devices that have been verified to work with the Matrox G400. A write cycle to the EEPROM has been defined. Another bit which locks write accesses to the EEPROM has also been added in order to prevent unexpected writes. Note, however, that sequencing of operations to write the memory must be performed by software. Additionally, some requirements must be guaranteed by software (refer to the device specification and 'Accessing the Serial EEPROM' on page 4-137). | | Serial EEPROM | | | | | | | | |--------------|---------------|---------|----------|--|--|--|--|--| | Manufacturer | 32K x 8 | 64K x 8 | 128 x 8 | | | | | | | Atmel | AT 25256 | | AT 25010 | | | | | | | SGS -Thomson | M35560 | | ST95010 | | | | | | Figure 5-2: External Device Configuration Note: If a local oscillator is used instead of crystal, it is connected to XTAL0, and XTAL1 is left unconnected. #### **Memory Interface** 5.5 #### 5.5.1 **SGRAM Configurations** The principal characteristics of the Matrox G400's SGRAM interface are provided in table 5-1, which identifies the cycles that are supported by the chip, and lists all of the commands generated by the Matrox G400. Table 5-1: Supported SGRAM/SDRAM Commands | $Command^{(1)}$ | Mnemonic | MCS/ | MRAS/ | MCAS/ | MWE/ | MDSF | МЪОМ | BS | AP | Address | |-----------------------------------------------------------|----------|------|-------|-------|------|------|------|----|----------------------------|-------------------------------| | Mode Register Set | MRS | L | L | L | L | L | X | L | L | opcode1 <sup>(2)</sup> | | Special Mode Register Set | SMRS | L | L | L | L | Н | X | L | L | opcode2 <sup>(3)</sup> | | Auto Refresh | REF | L | L | L | Н | L | X | X | X | X | | Bank Activate / Row Address<br>(Mask Disabled) | ACTV | L | L | Н | Н | L | X | X | Ro | w Address <sup>(4)</sup> | | Bank Activate / Row Address<br>(Mask Enabled) | ACTM | L | L | Н | Н | Н | X | V | Row Address <sup>(4)</sup> | | | Read / Column Address<br>(Auto-Precharge Disabled) | READ | L | Н | L | Н | L | X | V | L | Column Address <sup>(5)</sup> | | Write / Column Address<br>(Auto-Precharge Disabled) | WRITE | L | Н | L | L | L | X | V | L | Column Address <sup>(5)</sup> | | Block Write / Column Address<br>(Auto-Precharge Disabled) | BWRIT | L | Н | L | L | Н | X | V | L | Column Address (5)(6) | | Precharge (Single Bank) | PRE | L | L | Н | L | L | X | V | L | X | | Precharge (Both Banks) | PALL | L | L | Н | L | L | X | X | Н | X | | No Operation | NOP | L | Н | Н | Н | L | X | X | X | X | | Device De-select | DESL | Н | X | X | X | X | X | X | X | X | | Mask Write Data / Disable Read Output | X | X | X | X | X | X | Н | X | X | X <sup>(7)</sup> | | Write Data / Enable Read Output | X | X | X | X | X | X | L | X | X | X <sup>(7)</sup> | <sup>◆</sup> Legend: H = Logical High, L = Logical Low, V = Valid, X = "Don't Care", '/' Indicates an active low signal. MRAS/ = MRAS = MRASN2 < 1:0 > MCAS/ = MCASN = MCAN2 MWE/ = MWEN = MWEN2 MDSF = MDSF2 (this is always '0' for SDRAM with hardpwmsk = '0') <sup>(1)</sup> MCS/ = MCSN < 1:0 > = MCSN < 1:> (2) The Matrox G400 supports CAS latency (CL=2, CL=3, CL=4); burst type = sequential; burst length = 4. opcode1 = mrsopcod[3:0]: CLbits: '0': '010'. (Usually '00000110010') | CLbits | Caslatency | |--------------|------------| | '010' | 2 | | '011' | 3 | | <b>'100'</b> | 4 | | '101' | 5 | The mrsopcod value is a programmable field in the MEMRDBK register. - $^{(3)}$ A5 = 1 for a mask register access, and A6 = 1 for a color register access. Both registers cannot be accessed simultaneously. - opcode2 = '00000100000' <- load mask register - opcode2 = '00001000000' <- load color register - (4) For 2-bank, 16 MBit SGRAM device: Row Address == MA<10,8:0> - For 4-bank, 16 MBit SGRAM device: Row Address == MA<10,7:0> - For 2-bank, 16 MBit SDRAM device: Row Address == MA<10:0> - For 2-bank, 32 MBit SDRAM device: Row Address = = MA<10:0> - For 4-bank, 32 MBit SGRAM device: Row Address = = MA<10,9,7:0> - <sup>(5)</sup> The Matrox G400 does *not* support the auto-precharge function, so AP will always be forced low for READ/WRITE/BWRIT commands. - Column Address = MA < 7:0 > - (6) MA<2:0> are 'don't care' for block write commands. - (7) Not a command "MDQ mask enable" - ◆ *Note:* The Matrox G400 does not drive CKE: it should be driven high externally. - •• *Note:* The number of address bits depends on the memory type (selected by the memconfig field of **OPTION**). The addresses are mapped as follows: Chip Select memconfig Slice Address Decoded <2:0> mcsN[1] | mcsN [0] A24 A23000 0 X 0 100 1 X 0 1 001 X 0 1 0 010 X 0 1 1 X X 0 011 ma12 101 X 11X X Reserved Table 5-2: Slice Address Decoded Table 5-3: 2 bank (memconfig<2:0> = '000'), 16Mb (x16) and 32 (x32) device address mapping | memconfig | | mcsn1 | | MA | | | | | | | | | | | | | |-----------|--------|-------|-------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--|--| | < | <2:0> | | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | (BA0) | (AP) | | | | | | | | | | | | | | 000 | Row | _ | A12 | A23 | A22 | A21 | A20 | A19 | A18 | A17 | A16 | A15 | A14 | A13 | | | | | Column | _ | A12 | "0" | 0 | 0 | A11 | A10 | A9 | A8 | A7 | A6 | A5 | A4 | | | Table 5-4: 2 bank (memconfig<2:0> = '001'), 16Mb (x32) device address mapping | memconfig | | mcsn1 | | MA | | | | | | | | | | | | | |-----------|--------|-------|-------|------|---|-----|-----|-----|-----|-----|-----|-----|-----|-----|--|--| | < | <2:0> | | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | (BA0) | (AP) | | | | | | | | | | | | | | 001 | Row | _ | A12 | A22 | _ | A21 | A20 | A19 | A18 | A17 | A16 | A15 | A14 | A13 | | | | | Column | _ | A12 | "0" | _ | 0 | A11 | A10 | A9 | A8 | A7 | A6 | A5 | A4 | | | Table 5-5: 4 bank (memconfig<2:0> = '010'), 16Mb (x32) device address mapping | memconfig <2:0> | | mcsn1 | | MA | | | | | | | | | | | | | |-----------------|--------|-------|-------|------|---|-------|-----|-----|-----|-----|-----|-----|-----|-----|--|--| | | | | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | (BA0) | (AP) | | (BA1) | | | | | | | | | | | | 010 | Row | | A12 | A21 | _ | A22 | A20 | A19 | A18 | A17 | A16 | A15 | A14 | A13 | | | | | Column | _ | A12 | "0" | | A22 | A11 | A10 | A9 | A8 | A7 | A6 | A5 | A4 | | | Table 5-6: 4 bank (memconfig<2:0> = '011'), 64Mb (x32) device address mapping | memconfig | | | | MA | | | | | | | | | | | | |-----------|--------|-------|-------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--| | < | <2:0> | mcsn1 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | (BA1) | (BA0) | (AP) | | | | | | | | | | | | | 011 | Row | A24 | A12 | A23 | A22 | A21 | A20 | A19 | A18 | A17 | A16 | A15 | A14 | A13 | | | | Column | A24 | A12 | "0" | 0 | 0 | A11 | A10 | A9 | A8 | A7 | A6 | A5 | A4 | | Table 5-7: 4 bank (memconfig<2:0> = '100'), 32Mb (x32) device address mapping | memconfig<br><2:0> | | mcsn1 | | MA | | | | | | | | | | | | | |--------------------|--------|-------|-------|------|-----|-------|-----|-----|-----|-----|-----|-----|-----|-----|--|--| | | | | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | (BA0) | (AP) | | (BA1) | | | | | | | | | | | | 100 | Row | _ | A12 | A22 | A21 | A23 | A20 | A19 | A18 | A17 | A16 | A15 | A14 | A13 | | | | | Column | | A12 | "0" | 0 | A23 | A11 | A10 | A9 | A8 | A7 | A6 | A5 | A4 | | | Table 5-8: 2 bank (memconfig<2:0> = '101'), 64Mb (x32) device address mapping | memconfig<br><2:0> | | mcsn1 | | MA | | | | | | | | | | | | | |--------------------|--------|-------|-------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--|--| | | | | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | (BA0) | (AP) | | | | | | | | | | | | | | 101 | Row | A24 | A12 | A23 | A22 | A21 | A20 | A19 | A18 | A17 | A16 | A15 | A14 | A13 | | | | | Column | 0 | A12 | "0" | 0 | 0 | A11 | A10 | A9 | A8 | A7 | A6 | A5 | A4 | | | •• *Note:* '111' and '110' are Reserved •• *Note:* "0" denotes the AUTOprecharge bit: the auto-precharge function is not used and this bit is forced low during column address generation. "- " denotes that this pin is designated as an NC (No Connect). ma12 is muxed with mcsN[1] functionality for 64Mb SDRAM configurations. ma8 == BA1 in the 16Mb configuration (memconfig = '010') ma12 == BA1 in the 64Mb configuration (memconfig = '011') ma8 == BA1 in the 32Mb configuration (memconfig = '100') ma12 == A12 in the 64Mb configuration (memconfig = '101') MEMCONFIG="000" (a) clk cke MA[11:0]. dqm[1:0] dq[15:0] ba0 a[10:0] ba0 a[10:0] ba0 a[10:0] ba0 a[10:0] dqm[1:0] dqm[1:0] dq[15:0] clk MA2[11:0] 1] ba0 0] a[10:0] ba0 a[10:0] dqm[1:0] clk cke ras/ cas/ we/ ba0 a[10:0] ba0 a[10:0] dqm[1:0] dq[15:0] ras/ cas/ we/ dqm[1:0] dq[15:0] dqm[1:0] dq[15:0] Figure 5-3: Memory Pinout Mapping (memconfig = '000') MCSN[1:0] MCSN[0] MCSN[1] cs/ clk cs/ clk MCLK Vcc cke cke MRASN. ras/ ras/ MCASN cas/ cas/ MWEN. we/ we/ MDSF dsf dsf 2x256Kx32 MA[11] ba0 ba0 MA[11:0]\_ MA[10,8:0] a[9:0] a[9:0] MDQM[3:0] MDQM[7:0]\_ dqm[3:0] dqm[3:0] MDQ[31:0] MDQ[63:0] dq[31:0] dq[31:0] MCSN[0] MCSN[1] CS/ cs/ clk clk cke cke ras/ ras/ cas/ SGRAM cas/ we/ dsf dsf MA[11] ba0 ba0 MA[10,8:0] a[9:0] a[9:0] MDQM[7:4] dqm[3:0] dqm[3:0] MDQ[63:32] dq[31:0] dq[31:0] MCSN2[1:0]\_ MCSN2[0] MCSN2[1] clk clk MCLK2 cke MRASN2 ras/ ras/ MCASN2 cas/ SGRAM cas/ MWEN2 we/ we/ dsf dsf MA2[11] MA2[11:0]\_ ba0 ba0 MA2[10,8:0] a[9:0] a[9:0] MDQM2[3:0] MDQM2[7:0] dqm[3:0] dqm[3:0] MDQ2[31:0] MDQ2[63:0] dq[31:0] dq[31:0] MCSN2[1] MCSN2[0] clk clk cke cke ras/ ras/ cas/ cas/ SGRAM we/ we/ dsf dsf MA2[11] ba0 ba0 MA2[10,8:0] a[9:0] a[9:0] MDQM2[7:4] dqm[3:0] dqm[3:0] MDQ2[63:32] dq[31:0] dq[31:0] 8MB ← Figure 5-4: Memory Pinout Mapping (memconfig = '001') MCSN[1:0] MCSN[0] MCSN[1] cs/ cke cke MRASN. ras/ cas/ cas/ 4x128Kx32 SGRAM MWEN we/ we/ MDSF dsf dsf MA[8] ba1 ba1 MA[11] MA[11:0] ba0 ba0 MA[10,7:0] a[8:0] a[8:0] MDQM[3:0] MDQM[7:0] dqm[3:0] dqm[3:0] MDQ[31:0] MDQ[63:0] dq[31:0] dq[31:0] MCSN[1] MCSN[0] clk clk cs/ cke cke ras/ ras/ cas/ cas/ SGRAM we/ we/ dsf dsf 4x128Kx32 MA[8] ba1 ba1 MA[11] ba0 ba0 MA[10,7:0] a[8:0] a[8:0] dqm[3:0] dqm[3:0] MDQ[63:32] dq[31:0] dq[31:0] MCSN2[1:0] MCSN2[0] MCSN2[1] MCLK2 clk clk cke MRASN2 ras/ ras/ MCASN2 cas/ SGRAM cas/ MWEN2 dsf dsf 4x128Kx32 4x128Kx32 MA2[8] ba1 ba1 MA2[11] MA2[11:0] ba0 ba0 MA2[10,7:0] a[8:0] a[8:0] MDQM2[3:0] MDQM2[7:0] dqm[3:0] dqm[3:0] MDQ2[31:0] MDQ2[63:0] dq[31:0] dq[31:0] MCSN2[0] MCSN2[1] clk clk cke cke ras/ ras/ cas/ cas/ SGRAM we/ we/ dsf dsf 4x128Kx32 MA2[8] ba1 ba1 MA2[11] ba0 ba0 MA2[10,7:0] a[8:0] MDQM2[7:4] dqm[3:0] dqm[3:0] MDQ2[63:32] dq[31:0] dq[31:0] 8MB 16MB < Figure 5-5: Memory Pinout Mapping (memconfig = '010') MCSN[1:0] MCSN[0] MCLK clk Vcc. cke MRASN MCASN\_ 4x512Kx32 SDRAM cas/ MWEN\_ we/ MDSF\_ "NC" MCSN[1] ba1 MA[11] MA[11:0]\_ ba0 MA[10:0] a[10:0] MDQM[3:0] MDQM[7:0]\_ dqm[3:0] MDQ[31:0] dq[31:0] MDQ[63:0] clk cs/ cke ras/ cas/ 4x512Kx32 SDRAM we/ MCSN[1] ba1 MA[11] ba0 MA[10:0] a[10:0] MDQM[7:4] dqm[3:0] MDQ[63:32] dq[31:0] MCSN2[1:0] MCSN2[0] MCLK2 clk cs/ MRASN2 ras/ MCASN2 cas/ 4x512Kx32 SDRAM MWEN2\_ we/ MDSF2\_ "NC" MCSN2[1] MA2[11] MA2[11:0]\_ ba0 MA2[10:0] a[10:0] MDQM2[3:0] MDQM2[7:0] dqm[3:0] MDQ2[31:0] MDQ2[63:0] dq[31:0] MCSN2[0] cs/ clk cke ras/ 4x512Kx32 SDRAM cas/ MCSN2[1] ba1 MA2[11] ba0 MA2[10:0] a[10:0] MDQM2[7:4] dqm[3:0] MDQ2[63:32] dq[31:0] 32MB ← Figure 5-6: Memory Pinout Mapping (memconfig = '011') NOTE: In this configuration MCSN2[1]=MCSN[1] == BA1 MCSN[1:0] MCSN[0] MCSN[1] MCLK clk cs/ cke cke MRASN ras/ ras/ MCASN cas/ SGRAM cas/ MWEN. we/ we/ dsf dsf MDSF 4x256Kx32 MA[8] ba1 ba1 MA[11] MA[11:0] ba0 ba0 MA[9,10,7:0] a[9:0] a[9:0] MDQM[3:0] MDQM[7:0] dqm[3:0] dqm[3:0] MDQ[31:0] dq[31:0] MDQ[63:0] dq[31:0] MCSN[0] MCSN[1] clk cs/ clk cs/ cke ras/ ras/ SGRAM cas/ cas/ we/ dsf dsf 4x256Kx32 MA[8] ba1 ba1 MA[11] ba0 ba0 MA[9,10,7:0] a[9:0] a[9:0] MDQM[7:4] dqm[3:0] MDQ[63:32] dq[31:0] dq[31:0] MCSN2[1:0] MCSN2[1] MCSN2[0] clk MCLK2 clk cs/ Vcc cke cke MRASN2 ras/ ras/ MCASN2 cas/ SGRAM cas/ MWEN2 we/ we/ MDSF2 dsf dsf 4x256Kx32 MA2[8] ba1 ba1 MA2[11] MA2[11:0] ba0 ba0 MA2[9,10,7:0] a[9:0] MDQM2[3:0] MDQM2[7:0] dqm[3:0] dqm[3:0] MDQ2[31:0] MDQ2[63:0] dq[31:0] dq[31:0] MCSN2[0] MCSN2[1] clk cke cke cas/ SGRAM cas/ we/ we/ dsf dsf 4x256Kx32 MA2[8] ba1 ba1 MA2[11] ba0 ba0 MA2[9,10,7:0] a[9:0] a[9:0] MDQM2[7:4] dqm[3:0] dqm[3:0] MDQ2[63:32] dq[31:0] dq[31:0] 16MB ← 32MB **←** Figure 5-7: Memory Pinout Mapping (memconfig = '100') MCSN[1:0]\_ MCSN[0] clk MCLK Vcc cke MRASN\_ ras/ MCASN cas/ SDRAM MWEN we/ MDSF\_ "NC" MCSN[1] a[11] MA[11] MA[11:0] ba0 MA[10:0] MDQM[3:0] MDQM[7:0] dqm[3:0] MDQ[31:0] MDQ[63:0] dq[31:0] MCSN[0] clk cs/ cke ras/ cas/ SDRAM we/ MCSN[1] a[11] MA[11] ba0 MA[10:0] a[10:0] MDQM[7:4] dqm[3:0] MDQ[63:32] dq[31:0] MCSN2[1:0]\_ MCSN2[0] MCLK2 clk cs/ Vcc. cke MRASN2 ras/ MCASN2 cas/ MWEN2 we/ MDSF2\_ "NC" MCSN2[1] a[11] MA2[11] MA2[11:0]\_ ba0 MA2[10:0] a[10:0] MDQM2[3:0] MDQM2[7:0]\_ dqm[3:0] MDQ2[31:0] MDQ2[63:0] dq[31:0] MCSN2[0] clk cke ras/ cas/ 2x1Mx32 MCSN2[1] a[11] MA2[11] ba0 MA2[10:0] a[10:0] MDQM2[7:4] dqm[3:0] MDQ2[63:32] dq[31:0] 32MB ← Figure 5-8: Memory Pinout Mapping (memconfig = '101') NOTE: In this configuration MCSN[1]=MCSN2[1] == MA[12] == a[11] ### 5.6 Video interface ### 5.6.1 Slaving the Matrox G400 This section describes the operations of the VIDRST (video reset input) signal. A VIDRST is detected on the first rising edge of VDOCLK where VIDRST is high. The video reset can affect both the horizontal and/or vertical circuitry. The first time that the Matrox G400's CRTC is synchronized, the data may be corrupted for up to one complete frame. However, when the CRTC is already synchronous and a reset occurs, the CRTC will behave as if there was no VIDRST. ► Note: In order for the Matrox G400 to be synchronous with any other source, the Matrox G400 CRTC *must* be programmed with the same video parameters as that other source. VDOCLK can also be modulated in order to align both CRTCs. ### 5.6.1.1 Slaving the Primary CRTC A VIDRST is detected on the first rising edge of **VDOCLK** where **VIDRST** is high. The **hrsten** field of the **CRTCEXT1** register is used to enable the horizontal reset, which sets the horizontal and character counters to the beginning of the horizontal SYNC. The **vrsten** field of the **CRTCEXT1** register is used to enable the vertical reset, which sets the vertical counter to the beginning of the vertical SYNC in the even field. Horizontal active and horizontal retrace are *not* affected by **VIDRST** when the vertical reset alone is active. Figure 5-9 shows the relationship between **VIDRST**, the internal horizontal retrace, and the internal horizontal and vertical active signals, when both the horizontal and vertical counters are reset. Figure 5-9: VIDRST, Internal Horizontal/Vertical Active, and VOBLANKN ### 5.6.1.2 Slaving the Secondary CRTC The 2nd CRTC is synchronized with an external encoder by preloading the horizontal and vertical counters upon an edge on the VIDRST pin. The following register fields set the preloading: | c2vidrstmod | VIDRST Detection Mode. This bit selects the video reset detection | |--------------|------------------------------------------------------------------------------------------------------------------------------| | <1:0> | mode on the VIDRST pin. | | c2hpreloaden | Horizontal Counter Preload Enable. This bit enables the capability of preloading the horizontal counter with the VIDRST pin. | | c2vnroloadon | Vertical Counter Preload Enable. This bit enables the canability of | #### 5.6.2 **Genlock Mode** The **VIDRST** pin can be used to reset the **CRTC** horizontal and/or vertical counters. The **VIDRST** must be maintained for at least 1 **VDOCLK** cycle for the reset to take effect in the Matrox G400. #### 5.6.2.1 **Genlock the Primary CRTC** When it is **not** used, the **VIDRST** pin **must** be maintained low (there is **no** enable/disable control bit for the VIDRST pin). If the timing on the VIDRST pin is respected, the reset operation on the chip will be completed (the VBLANK/ pin is set to '1'), according to the number of VDOCLK clock cycles shown in the following table: | Pixel Width | Delay to Video Pins (VDOCLKs) | |-------------|-------------------------------| | BPP | 31 | | BPP15 | 21 | | BPP16 | 21 | | BPP24 | 17 | | BPP32 | 16 | <sup>••</sup> *Note:* Genlocking is *not* supported in VGA mode. #### 5.6.2.2 **Genlock the Secondary CRTC** The delay from the active edge of the VIDRST (active edge is selected with **c2vidrstmod**) and the output of the first valid data onto the VDOUT bus depends on the output mode (vdoutsel field of the XMISCCTL register). That delay, expressed in the number of VDOCLK clock cycles, is shown in the following table: | vdoutsel | Delay to Video Pins (VDOCLKs) | |------------------------|------------------------------------------------------| | '100'<br>(RGB modes) | 34 + (c2htotal - c2hpreload + 1) * 8 | | '110'<br>(YCbCr modes) | 52 + ( <b>c2htotal</b> - <b>c2hpreload</b> + 1) * 16 | #### **Crystal Resonator Specification** 5.6.3 Frequency 27 MHZ Equivalent series resistance (Rs) 35 - 200 $\Omega$ Load capacitance (Cl) 18 or 20 pF (series or parallel) Shunt capacitance (Co) 7 pF max. 100 - 1,000 μW Drive level Temperature stability 50 ppm Figure 5-10: Video Interface Figure 5-11: Video Connector # Appendix A: Technical Information | Pin List | A-2 | |-----------------------------------|------| | AGP Pinout Illustration and Table | A-8 | | Electrical Specification | A-10 | | Mechanical Specification | A-41 | | NAND-Tree | A-42 | | Ordering Information | A-54 | ### A.1 Pin List Table A-1: Pin Count Summary Matrox G400 (Rev. 0) | Group | Total | I | 0 | I/O | |---------------------------|--------|------|------|------| | Host AGP | 65 | 7 | 13 | 45 | | Host Local | 2 | 1 | 1 | _ | | Memory | 182 | _ | 53 | 129 | | Video Display | 6 | _ | 2 | 4 | | Video In | 9 | _ | _ | 9 | | MAFC/Video Out | 15 | 1 | 13 | 1 | | CODEC <sup>(1)</sup> | 14[17] | 1[2] | 5[6] | 8[9] | | SEEPROM | 4 | 1 | 3 | _ | | Analog Signals | 13 | 6 | 7 | | | Miscellaneous Functions | 3 | _ | _ | 3 | | Test | 2 | 2 | _ | | | Power and Ground Supplies | 145 | _ | _ | | | Reserved | 24 | _ | _ | _ | | PBGA Total | 484 | | | | <sup>(1)</sup> The numbers within the brackets reflect the fact that one input pin (EP2Q) and one output pin (EP2D) of the SEEPROM interface, as well as one bi-directional miscellaneous control pin (MISC[2]), are shared with the CODEC interface. The total number of pins used for the CODEC interface is, therefore,17. Table A-2: Pin Count Summary Matrox G400 (Rev. 1) | Group | Total | I | 0 | I/O | |---------------------------|--------|------|------|------| | Host AGP | 65 | 7 | 13 | 45 | | Host Local | 2 | 1 | 1 | | | Memory | 182 | _ | 53 | 129 | | Video Display | 6 | _ | 2 | 4 | | Video In | 9 | _ | | 9 | | MAFC/Video Out | 15 | 0 | 13 | 2 | | CODEC <sup>(1)</sup> | 14[17] | 1[2] | 5[6] | 8[9] | | SEEPROM | 4 | 1 | 3 | | | Analog Signals | 15 | 7 | 8 | _ | | Miscellaneous Functions | 3 | _ | | 3 | | Test | 2 | 2 | | | | Power and Ground Supplies | 145 | _ | _ | _ | | Reserved | 22 | | | | | PBGA Total | 484 | | _ | _ | <sup>(1)</sup> The numbers within the brackets reflect the fact that one input pin (EP2Q) and one output pin (EP2D) of the SEEPROM interface, as well as one bi-directional miscellaneous control pin (MISC[2]), are shared with the CODEC interface. The total number of pins used for the CODEC interface is, therefore,17. # A.1.1 Host (AGP) | Name | # Pins | Туре | Description | |-------------|--------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PAD<31:0> | 32 | I/O | PCI address and data bus. During the address phase of a PCI transaction, PAD contains a physical address. During the data phase, it contains the data that is read or written. | | SB_STB | 1 | O | AGP Sideband address strobe. While in AGP 2X mode, the strobe is used | | SB_STB/ | 1 | 0 | to qualify the information on the SBA bus on each of its edges. In AGP 4X mode, the strobes are used as a differential pair. | | PCBE<3:0>/ | 4 | I/O | PCI bus command, and byte enable. During the address phase, PCBE<3:0>/ provides the bus command. During the data phase, PCBE<3:0>/ is used as the byte enable. | | PCLK | 1 | I33 <sup>(1)</sup> | PCI bus clock. All PCI bus activities are referenced to this clock. | | PDEVSEL/ | 1 | I/O | Device select. Is asserted when a transaction is within the MGA address range and space. | | PFRAME/ | 1 | I/O | Cycle frame. Indicates the beginning of an access and its duration. | | AD_STB<1:0> | 2 | I/O | AGP Data Strobe. While in AGP 2X mode, the strobe is used to qualify the | | AD_STB<1:0> | / 2 | I/O | information on the SBA bus on each of its edges. In AGP 4X mode, the strobes are used as a differential pair. | | PGNT/ | 1 | I | Grant. Indicates to the Matrox G400 that access to the PCI bus has been granted. | | PINTA/ | 1 | O33 <sup>(1)</sup> | Interrupt request signal. | | PIRDY/ | 1 | I/O | Initiator ready. Indicates the initiating agent's ability to complete the current data phase of the transaction (used in conjunction with PTRDY/). Wait cycles are inserted until both PIRDY/ and PTRDY/ are asserted together. | | PPAR | 1 | O | PCI even parity bit for the PAD<31:0> and PCBE<3:0>/ lines. Parity is generated during read data phases and during the address phase throughout the PCI mastering cycle. | | PREQ/ | 1 | O | Request. Indicates to the arbiter that the Matrox G400 wishes to use the bus. | | PRST/ | 1 | I33 <sup>(1)</sup> | PCI reset. This signal is used as the chip's hard reset. | | PSTOP/ | 1 | I/O | Stop. Forces the current transaction to terminate. | | PTRDY/ | 1 | I/O | Target ready. When asserted, indicates that the current data phase of the transaction can be completed (used in conjunction with PIRDY/). Wait cycles are inserted until both PIRDY/ and PTRDY/ are asserted together. In target mode, PTRDY/ is used as an input for snooping operations. | | SBA<7:0> | 8 | О | Sideband Address port. Provides an additional bus for the Matrox G400-AGP to pass addresses and commands. | | ST<2:0> | 3 | I | Status. Provides additional information from the arbiter indicating what the Matrox G400-AGP may do when it receives a GNT/. | | TYPEDET/ | 1 | I33 <sup>(1)</sup> | Bus Type Detection. When set to '1', this bit indicates that the AGP interface will use 3.3 volt signaling. When '0', the AGP interface uses 1.5 volt signaling. | <sup>(1)</sup> I33/O33 types mean that the receiver (I33) or driver (O33) is always powered by 3.3V, even when VDDQ is at 1.5V. # A.1.2 Host (Local Mode) | Name | # Pins | Type | Description | |---------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------| | EXTINT/ | 1 | Ι | External interrupt pin. Can be used by a companion chip to generate interrupts on the AGP bus. Interrupt is an active low level interrupt. | | EXTRST/ | 1 | O | External reset signal. Used to reset the RAMDAC and expansion devices. | ## A.1.3 Memory Interface | Name | # Pins | Type | Description | |------------|--------|------|------------------------------------------------------------------------------| | MDQ<63:0> | 64 | I/O | Memory data inputs/outputs for lower 8 bytes of the 128 bit memory interface | | MCSN<1:0> | 2 | O | Memory Chip Select associated with MDQ<63:0> | | MA<11:0> | 12 | 0 | Memory address (row, column, bank: multiplexed) associated with MDQ<63:0> | | MRASN | 1 | O | Memory Row Address Strobe associated with MDQ<63:0> | | MCASN | 1 | O | Memory Column Address Strobe associated with MDQ<63:0> | | MWEN | 1 | O | Memory Write Enable associated with MDQ<63:0> | | MDSF | 1 | O | Memory special function enable associated with MDQ<63:0> | | MDQM<7:0> | 8 | O | Memory Data mask enable associated with MDQ<63:0> | | MCLK | 1 | I/O | Memory Clock associated with MDQ<63:0> | | MDQ2<63:0> | 64 | I/O | Memory data inputs/outputs for upper 8 bytes of the 128 bit memory interface | | MCSN2<1:0> | 2 | O | Memory chip select associated with MDQ2<63:0> | | MA2<11:0> | 12 | О | Memory address (row, column, bank:multiplexed) associated with MDQ2<63:0> | | MRASN2 | 1 | O | Memory Row Address Strobe associated with MDQ2<63:0> | | MCASN2 | 1 | O | Memory Column Address Strobe associated with MDQ2<63:0> | | MWEN2 | 1 | O | Memory Write Enable associated with MDQ2<63:0> | | MDSF2 | 1 | O | Memory special function enable associated with MDQ2<63:0> | | MDQM2<7:0> | 8 | O | Memory Data mask enable associated with MDQ2<63:0> | | MCLK2 | 1 | O | Memory Clock for MDQ2<63:0> | | | | | | # A.1.4 Video Display Interface | Name | # Pins | Type | Description | |----------|--------|------|---------------------------------------------------------| | DDC<3:0> | 4 | I/O | Display Data Channel. Used to communicate with monitor. | | VHSYNC/ | 1 | O | Horizontal Sync. | | VVSYNC/ | 1 | O | Vertical Sync. | ### A.1.5 Video In Interface | Name | # Pins | Type | Description | |---------|--------|------|----------------------------------| | VD<7:0> | 8 | I/O | Video In Data | | VDCLK | 1 | I/O | Video In Clock. Maximum: 60 MHz. | ### A.1.6 Video Out Interface | Name | # Pins | Type | Description | |-------------|--------|------|--------------------------------------------------------------------| | VIDRST | 1 | I/O | Video Reset Input. Used to synchronize the CRTC and CRTC2 on an | | | | | external source. The VIDRST pin must be forced inactive when not | | | | | in use. Also used as output for clock in Panel Link mode (does not | | | | | apply to Matrox G400 rev. 0). | | VDOCLK | 1 | I/O | Video Out Clock. (Input for MAFC, output in Panel Link mode.) | | VDOUT<11:0> | 12 | O | Video Out Data. | | VOBLANK/ | 1 | O | Video Out Blank. Gated clock feedback in MAFC mode. | ### A.1.7 CODEC Interface | Name | # Pins | Type | Description | |-------------|--------|------|-----------------------------------------------| | MISC_WR | 1 | O | Data strobe for external register | | C_ADDR_2 | 1 | O | CODEC address <2> | | C_ADDR_1 | 1 | O | CODEC address <1> | | C_ADDR_0 | 1 | O | CODEC address <0> | | HDATA <7:0> | 8 | I/O | CODEC data port. Also used for chip strapping | | | | | HDATA <0> VGA boot strap | | | | | HDATA <1> BIOS EEPROM installed strap | | C_WR/ | 1 | O | CODEC interface write signal | | C_HRDY | 1 | I | CODEC host ready | ### A.1.8 SEEPROM | Name | # Pins | Type | Description | |--------|--------|------|-------------------------------------------------------------------------------------------------------------------| | E2PCLK | 1 | О | Clock for the Serial EEPROM. | | E2CS/ | 1 | O | Serial EEPROM chip select. | | E2PD | 1 | O | Serial EEPROM write data. Also, the Codec Interface read signal when Codec interface is enabled. | | E2PQ | 1 | I | Serial EEPROM read data. Also, the Codec Interface read/write acknowledge signal when Codec interface is enabled. | ## A.1.9 Analog Signals | Name | # Pins | Type | Description | |------|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADC0 | 1 | N/A | Connected to Vddq through a 78Ω pull-up resistor. (1) | | ADC1 | 1 | N/A | Connected to ground through a $78\Omega$ pull-down resistor for 1.5V AGP bus and through a $165\Omega$ pull-down resistor for 3.3V AGP bus . <sup>(1)</sup> | | COMP | 1 | O | Compensation. COMP provides compensation for the internal reference amplifier. A 0.1 uF ceramic capacitor is required between COMP and analog power. The capacitor must be as close to the device as possible to avoid noise pick-up. | | IOB | 1 | Ο | Analog current Output Blue. This output can drive a $37.5\Omega$ load directly (doubly-terminated $75\Omega$ load). | | IOG | 1 | O | Analog current Output Green. This output can drive a $37.5\Omega$ load directly (doubly-terminated $75\Omega$ load). | | IOR | 1 | О | Analog current Output Red. This output can drive a $37.5\Omega$ load directly (doubly-terminated $75\Omega$ load). | |------------------------|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | REFAGP | 1 | I | Voltage reference for AGP Interface receivers. | | REFD<br>REFP1<br>REFP3 | 3 | I | Voltage reference for the RAMDAC, PLL#1 (pixel clock PLL by default), and PLL#3 (AGP Interface PLL) respectively. An internal voltage reference of nominally 1.235 V may or may not be provided, which would require an external 0.01 uF ceramic capacitor between REF and analog GND. However, the internal reference voltage can be overdriven by an externally supplied reference voltage. | | RSET | 1 | I | Full-scale adjustment pin. A resistor connected between this pin and ground controls the full-scale range of the DACs. | | XTAL1 | 1 | O | Connection for a series of resonant crystals as a reference for the | | XTAL0 | 1 | I | frequency synthesizer PLLs. XTAL0 may be used as a TTL reference clock (local oscillator) input, in which case XTAL1 is left unconnected. | | VSS | 1 | O | Internal ground, used in connection with VDDQ1 to generate a reference voltage for the AGP target receivers . | | VDDQ1 | 1 | O | Internal AGP interface power supply, used in connection with VSS to generate a reference voltage for the AGP target receivers. | <sup>(1)</sup> These are reference resistors for the digitally compensated AGP output buffers. ADC0 and ADC1 are N/C (reserved) balls in Matrox G400 rev. 0 ### A.1.10 Miscellaneous Functions | Name | # Pins | Type | Description | |-----------|--------|------|----------------------------------------------------| | MISC<2:0> | 3 | I/O | Miscellaneous Control. General purpose I/O pins. | | | | | MISC <0> can be used for I2CDAT | | | | | MISC <1> can be used for I2CCLK | | | | | MISC <2> can be used for CODEC Address <3> or EOI/ | ### A.1.11 TEST | Name | # Pins | Type | Description | |----------|--------|------|--------------------------------------------------------------------------| | TST<1:0> | 2 | I | These pins place the chip in test mode. They should be tied to a pull-up | | | | | during normal operation. | ## A.1.12 Power and Ground Supplies | Name | # Pins | Voltage | Description | |--------|--------|---------|--------------------------------------------------------| | AVDDD | 3 | 2.5 V | Analog power for RAMDAC. | | AVDDP1 | 1 | 2.5 V | Analog power for PLL #1 (Pixel Clock PLL by default). | | AGNDP1 | 1 | 0 V | Analog ground for PLL #1. | | DGNDP1 | 1 | 0 V | Digital ground for PLL #1. | | AVDDP2 | 1 | 2.5 V | Analog power for PLL #2 (System Clock PLL by default). | | AGNDP2 | 1 | 0 V | Analog ground for PLL #2. | | AVDDP3 | 1 | 2.5 V | Analog power for PLL #3 (AGP Interface PLL). | | AGNDP3 | 1 | 0 V | Analog ground for PLL # 3. | | DGNDP3 | 1 | 0 V | Digital ground for PLL #3. | | GND | 97 | 0 V | Main Digital Ground supply. | ### MGI Confidential | VDD2.5 | 16 | 2.5 V | Main Digital Power supply. | |--------|----|--------|--------------------------------------| | VDD | 16 | 3.3 V | Power supply for I/Os. | | VDDQ | 5 | 3.3 V/ | Power supply for AGP Interface I/Os. | | | | 1.5 V | | ### A.2 AGP Pinout Illustration and Table The illustration below shows the locations of the Matrox G400-AGP's 320 pins on the chip. The table on the next page lists the signal names with their respective pin numbers, in numeric order. Figure A-1: AGP Pinout Illustration # Matrox G400 Bottom View Table A-3: AGP Pinout Legend (Top View) | 56 | 55 | 24 | 23 | 52 | 72 | 70 | ę. | <u>\$</u> | 1 | 9 | 5 | 4 | 5 | 12 | Ξ | 5 | | | ٨. | 9 | 9 | 4 | e | 7 | | | |--------------|---------|---------|---------|---------|---------|---------|--------|-----------|---------|---------|---------|----------|--------|-------------------|---------|---------|---------|---------|---------|----------|----------|--------|----------|----------|---------|----------| | AF<br>MDQ_53 | MDQ_49 | MDQM_5 | MDQ_45 | MDQ_41 | MDQ_37 | MDQ_33 | MDSF | MWEN | WA_9 | MA_5 | MA_1 | MDQ_29 | MDQ_27 | MDQ_23 | MDQ_19 | MDQM_3 | MDQ_15 | MDQ_11 | MDQ_7 | MDQ_3 | PAD_1 | PAD_3 | PAD_5 | PAD_7 | AGNDP2 | AF | | AE<br>MDQ_57 | MDQ_51 | MDQM_7 | MDQ_47 | MDQ_43 | MDQ_39 | MDQ_35 | MCSN_1 | MRASN | MA_11 | MA_7 | MA_3 | MDQ_31 | MDQ_25 | MDQ_21 | MDQ_17 | MDQM_1 | MDQ_13 | MDQ_9 | MDQ_5 | MDQ_1 | PAD_0 | PAD_2 | PAD_4 | PAD_6 | AD_STB0 | AE | | AD<br>MDQ_61 | MDQ_89 | MDQ_55 | MDQ_46 | MDQ_44 | MDQ_40 | MDQ_36 | MDQ_32 | MCASN | MA_10 | MA_6 | MA_2 | MDQ_30 | MDQ_28 | MDQ_24 | MDQ_20 | MDQ_16 | MDQM_0 | MDQ_12 | MDQ_8 | MDQ_6 | MDQ_2 | PSTOPN | PDEVSEL | AD_STBN0 | N/C | ΑD | | AC<br>MDQ_63 | MDQ_50 | MDQ_48 | MDQM_6 | MDQM_4 | MDQ_42 | MDQ_38 | MDQ_34 | MCSN_0 | MCLK | MA_8 | MA_4 | MA_0 | MDQ_26 | MDQ_22 | MDQ_18 | MDQM_2 | MDQ_14 | MDQ_10 | PPAR | MDQ_4 | MDQ_0 | AVDDP2 | PTRDY | PAD_8 | N/C | AC | | AB<br>MDQ_58 | MDQ_56 | MDQ_54 | MDQ_52 | GND | GND | 2.5 | 3.3 | GND | GND | 3.3 | 3.3 | GND | GND | 2.5 | 3.3 | GND | GND | 3.3 | 2.5 | GND | GND | PIRDYN | PFRAME | PCBEN_0 | PAD_10 | AB | | AA<br>MDQ2_3 | MDQ2_1 | MDQ2_2 | MDQ2_0 | GND | | , | | | | , | | | | - | | | ,, | | , | | VDDQ | PAD_13 | PCBEN_1 | PAD_9 | PAD_12 | ¥ | | Y<br>MD02_7 | MD02_5 | MD02_4 | MDQ_60 | 2.5 | | | | | | | | | | | | | | | | | 2.5 | N/C | PAD_15 | REFAGP | N/C | > | | W<br>MD02_11 | MDQ2_9 | MDQ2_8 | MDQ2_6 | 3.3 | | | | | | | | | | | | | | | | | 3.3 | NIC | NC | PAD_11 | N/C | × | | v<br>MDQ2_15 | MDQ2_13 | MDQ2_10 | MDQ_62 | GND | | | | | | | | | | | | | | | | | GND | NIC | NIC | PAD_14 | PCBEN_2 | > | | U<br>MDGM2_3 | MDQM2_1 | MD02_14 | MDQ2_12 | GND | | | | | GND | | | | GND | N/C | REFP3 | DGNDP3 | PAD_16 | Þ | | T<br>MD02_19 | MD02_17 | MDQM2_2 | MDQM2_0 | 3.3 | | | | | GND | | | | VDDG | VDDQ1 | PAD_17 | ADC0 | AVDDP3 | F | | R<br>MDQ2_23 | MD02_21 | MDQ2_18 | MDQ2_16 | 2.5 | | | | | GND | | | | 2.5 | AGNDP3 | PAD_18 | ADC1 | P.AD_19 | ~ | | P<br>MD02_27 | MDQ2_25 | MDQ2_22 | MDQ2_20 | GND | | | | | GND | | | | GND | NIC | VDD25 | PAD_20 | PAD_21 | • | | N<br>MDQ2_29 | MDQ2_31 | MDQ2_24 | MDQ2_26 | GND | | | | | GND | | | | VDDQ | NIC | PCBEN_3 | PAD_23 | PAD_22 | z | | M<br>MA2_1 | MA2_3 | MDQ2_28 | MDQ2_30 | 2.5 | | | | | GND | | | | 2.5 | VSS | AD_STBN1 | N/C | N/C | × | | L<br>MA2_5 | MA2_7 | MA2_0 | MA2_2 | 3.3 | | | | | GND | | | | VDDQ | NC | AD_STB1 | PAD_24 | PAD_25 | , | | K<br>MA2_9 | MA2_11 | MA2_4 | MA2_6 | GND | | | | | GND | | | | GND | NIC | PAD_29 | PAD_26 | PAD_27 | × | | J<br>WWENZ | MRASN2 | MA2_8 | MA2_10 | GND | | | | | | | | | | | | | - | | | | GND | N/C | PAD_30 | PAD_31 | PAD_28 | 7 | | H<br>MGLK2 | MDSF2 | MCASNZ | MCSN2_1 | 3.3 | | | | | | | | | | | | | | | | | 3.3 | NIC | ST_2 | SBA_7 | SBA_6 | I | | G<br>MCSN2_0 | MDG2_33 | MDO2_32 | MDO2_34 | 2.5 | | | | | | | | | | | | | | | | | 2.5 | NIC | ST_1 | SBA_5 | SBA_4 | 9 | | F<br>MDGZ_35 | MD02_37 | MDQ2_36 | MDQ2_38 | GND | | | | | | | | | | | | | | | | | VDDQ | ST_0 | N/C | SB_STB | N/C | L | | E<br>MDQ2_39 | MDQ2_41 | MDQ2_40 | MDQ2_42 | GND | GND | 2.5 | 3.3 | GND | GND | 3.3 | 3.3 | GND | GND | 2.5 | 3.3 | GND | GND | 3.3 | 2.5 | GND | GND | PREQN | PGNTN | VDD25 | SB_STBN | ш | | D<br>MDQ2_43 | MDQ2_46 | MD02_44 | MDQ2_46 | MDQM2_6 | MISC_2 | MDGZ_60 | MISC_1 | MDQ2_62 | DDC_2 | HDATA_3 | DGNDP1 | C_ADDR_1 | EZPCSN | 9 <sup>-</sup> Q/ | VVSYNCN | VBOUT_0 | NIC | VDOUT_4 | NO. | VDOUT_10 | VDOUT_11 | PCLK | SBA_1 | SBA_3 | SBA_2 | ۵ | | C<br>MD02_47 | MDQM2_5 | MD02_53 | MDQM2_4 | MD02_48 | MD02_54 | TST_0 | DDC_0 | HDATA_7 | HDATA_6 | AGNDP1 | HDATA_2 | C_ADDR_0 | C_WRN | E2PD | VD_3 | 0_dv | VIDRST | vbout_3 | VBOUT_7 | €_TUOdv | VOBLANKN | AVDDD3 | 108 | TYPEDETN | SBA_0 | ပ | | B<br>MDQM2_7 | MDQ2_49 | MDQ2_57 | MDQ2_61 | MDQ2_50 | MDQ2_56 | TST_1 | DDC_1 | EXTRSTN | HDATA_5 | REFP1 | HDATA_1 | MISC_WR | C_HRDY | EZPOLK | VD_4 | VD_1 | VDCLK | VDOUT_2 | VEOUT_6 | VDOUT_8 | XTAL1 | RSET | 90 | AVDDD1 | PRSTN | <b>m</b> | | A<br>MDGZ_51 | MDQ2_55 | MDQ2_59 | MDQ2_63 | MD02_52 | MDQ2_58 | MISC_0 | DDC_3 | EXTINTN | HDATA_4 | AVDDP1 | HDATA_0 | C_ADDR_2 | E2PQ | √Q∧ | VD_5 | VD_2 | VHSYNCN | VBOUT_1 | VDOUT_5 | VDOCLK | ХТАЦО | AVDDD2 | REFD | COMP | PINTAN | ∢ | | 56 | 52 | 24 | 53 | 52 | 2 | 50 | 6 | 8 | 4 | 9 | 5 | 4 | 5 | 12 | Ξ | 5 | 6 | - 60 | - | ø | 100 | 4 | е . | 7 | - | 1 | # A.3 Electrical Specification ### A.3.1 DC Specifications Table A-4: Absolute Maximum Ratings | Symbol | Parameter | Conditions | Min. | Max. | Units | Notes | |-----------|-------------------------|---------------------|------|------|-------|-------| | VDD3V | Power Supply Voltage | | -0.5 | 4.6 | V | | | VDD2.5V | Power Supply Voltage | | -0.5 | - | V | | | $V_{I}$ | Input Voltage | | | | | | | | IO-3, IO-6, IO-9, I-0 | $V_I < VDD3 + 0.5V$ | -0.5 | 4.6 | V | | | $V_{O}$ | Output Voltage | | | | | (1) | | | IO-3, IO-6, IO-9, IO-12 | $V_O < VDD3 + 0.5V$ | -0.5 | 4.6 | V | | | $I_{O}$ | Output Current | | | | | (1) | | | IO-3 | | | 10 | mA | | | | IO-6 | | | 20 | mA | | | | IO-9 | | | 30 | mA | | | $T_A$ | Ambient Temperature | | 0 | 55 | °C | | | $T_{C}$ | Case Temperature | | 0 | TBD | °C | | | $T_{J}$ | Junction Temperature | | 0 | TBD | °C | | | $T_{STG}$ | Storage Temperature | | -65 | 150 | °C | | $<sup>^{(1)}</sup>$ $V_{O}$ : the range of voltage which will not cause damage when applied to the output pin. $I_{O}$ : the maximum current which will not cause damage when flowing to or from the output pin. *Caution:* Exposure to the absolute maximum ratings for extended periods may affect device reliability; exceeding the ratings could cause permanent damage. The device should not be operated outside the recommended operating conditions. Table A-5: Recommended Operating Conditions | Symbol | Parameter | Min. | Max. | Units | | |----------------|--------------------------------------------------|-----------|------------|---------------------------------------------|--------| | VDD2.5 | Core Power Supply | 2.3 | 2.7 | V | | | VDD3 | Non-AGP Interface Supply | 3.0 | 3.6 | V | | | VDDq (3.3) | AGP interface supply | 3.15 | 3.45 | V | (1) | | VDDq (1.5) | AGP interface supply | 1.425 | 1.575 | V | (2) | | REFAGP (3.3) | AGP buffer voltage reference (V <sub>ref</sub> ) | 0.39 VDDq | 0.41 VDDq | V | (1) | | | Vref pin input current (I ref) | | ±10 | μΑ | (1) | | REFAGP (1.5) | AGP buffer voltage reference (V <sub>ref</sub> ) | 0.48 VDDq | 0.52 VDDq | V | (2) | | | Vref pin input current (I ref) | | ±5 | μΑ | (2) | | $V_{IH}$ | High-Level Input Voltage | | | | | | | IO-12, I-0 | 2.0 | VDD3 | V | | | | IO-AGP, I-AGP (3.3) | 0.5 VDDq | VDDq + 0.5 | V | (1)(3) | | | IO-AGP, I-AGP (1.5) | 0.6 VDDq | VDDq + 0.5 | V | (2) | | $V_{IL}$ | Low-Level Input Voltage | | | | | | | IO-12, I-0 | 0 | 0.8 | V | | | | IO-AGP, I-AGP (3.3) | -0.5 | 0.3 VDDq | V | (1)(3) | | | IO-AGP, I-AGP (1.5) | -0.5 | 0.4 VDDq | V<br>V<br>V<br>V<br>μΑ<br>V<br>μΑ<br>V<br>V | (2) | | t <sub>r</sub> | (IO-12, I-O) Input Rise Time | 0 | 200 | ns | | | $t_{\rm f}$ | (IO-12, I-O) Input Fall Time | 0 | 200 | ns | | | tr/tf | (IO-AGP, I-AGP) Input Slew Rate | 1.5 | 4.0 | V/ns | (1) | | tr/tf | (IO-AGP, I-AGP) Input Slew Rate | 0.9 | 2.3 | V/ns | (2) | <sup>(1)</sup> TYPEDETN = 1 = 3.3V AGP bus operation mode <sup>(2)</sup> TYPEDETN = 0 = 1.5V AGP bus operation mode <sup>(3)</sup> PRSTN, PCLK, and PINTA are always powered by a 3.3V supply Table A-6: DC Characteristics $(VDD3 = 3.3 \pm 0.3V, VDD2.5 = 2.5 \pm 0.2V, VDDq = 3.3 \pm 0.15V, TA = 0^{\circ} to 55^{\circ})(AGP 3.3)^{(1)}$ $(VDD3 = 3.3 \pm 0.3V, VDD2.5 = 2.5 \pm 0.2V, VDDq = 1.5 \pm 0.075V, TA = 0^{\circ} to 55^{\circ})(AGP 1.5)^{(2)}$ | Symbol | Parameter | Conditions | Min. | Max. | Units | Notes | |------------------|-----------------------------------------------------------|-------------------------------|------------|----------------------------------------------------------------------------|-------|-------------| | I <sub>OS</sub> | Output Short-Circuit Current | $V_{O} = 0V$ | | -250 | mA | (3) | | $I_i$ | Input Leakage Current | $V_i = VDD3 \text{ or } 0V$ | | ±10 | μΑ | | | $I_{OL}$ | IO-AGP, O-AGP (3.3) | $V_{OL} = 0.18VDDq$ | | | | (1),(4),(5) | | | IO-AGP, O-AGP (1.5) | $V_{OL} = 0.325 VDDq$ | | | | (2),(4) | | | Low-Level Output Current | $V_{OL} = 0.4V$ | | | | | | | O-3 | | 3 | | mA | | | | O-6 | | 6 | | mA | | | | O-9 | | 9 | | mA | | | | O-12, IO-12 | | 12 | | mA | | | I <sub>OH</sub> | IO-AGP, O-AGP (3.3) | $V_{OH} = 0.7 \text{ VDDq}$ | | | | (1),(4),(5) | | | IO-AGP, O-AGP (1.5) | $V_{OH} = 0.675 \text{ VDDq}$ | | | | (2),(4) | | | High-Level Output Current | $V_{OH} = 2.4V$ | | | | | | | O-3 | | -3 | | mA | | | | O-6 | | -6 | | mA | | | | O-12, IO-12 | | -12 | | mA | | | V <sub>OL</sub> | IO-AGP, O-AGP (3.3) | $I_{out}=1500\mu A$ | | 0.1 VDDq | V | (1),(4),(5) | | | IO-AGP, O-AGP (1.5) | I <sub>out</sub> =1000μA | | 0.15 VDDq | V | (2),(4) | | | Low-Level Output Voltage | $I_{OL} = 0 \text{ mA}$ | | 0.1 | V | | | V <sub>OH</sub> | IO-AGP, O-AGP (3.3) | $I_{out} = -500 \mu A$ | 0.9 VDDq | | V | (1),(4),(5) | | | IO-AGP, O-AGP (1.5) | $I_{out}$ = -200 $\mu$ A | 0.85 VDDq | | | (2),(4) | | | High-Level Output Voltage | $I_{OH} = 0 \text{ mA}$ | VDD3 - 0.1 | | V | | | | T 1: 1 | 0 m/s | | TBD | | | | | Junction to ambient thermal resistance, without heat sink | 1 m/s | | TBD | °C/W | | | 0 | resistance, without heat sink | 2 m/s | | TBD | | (6) | | $ heta_{ m JA}$ | | 0 m/s | | TBD | | | | | Junction to ambient thermal resistance, with heat sink | 1 m/s | | TBD | °C/W | | | | resistance, with heat shik | 2 m/s | | DDq V (1) DDq V (1) DDq V (1) TBD V TBD °C/W TBD TBD °C/W TBD TBD °C/W TBD | | | | | T | 0 m/s | | TBD | | | | $\theta_{ m JC}$ | Junction to case thermal resistance | 1 m/s | | TBD | °C/W | | | | resistance | 2 m/s | | TBD | | | | $C_{PIN}$ | Pin Capacitance | F = 1 MHz | | 7 | pF | | | ICC3 | VDD3 Supply Current | | TBD | | mA | | | ICC2.5 | VDD2.5 Supply Current | | TBD | | mA | | | IDDq | VDDq Supply Current (3.3) | | TBD | | mA | (1) | | | VDDq Supply Current (1.5) | | TBD | | mA | (2) | <sup>(1)</sup> TYPEDETN = 1: 3.3V AGP bus operation mode <sup>(2)</sup> TYPEDETN = 0: 1.5V AGP bus operation mode <sup>(3)</sup> The Output Short-Circuit time is less than one second for one pin only. <sup>(4)</sup> AGP buffers are characterized by their V/I curves (see the following figures). <sup>(5)</sup> PRSTN, PCLK, and PINTA are always powered by a 3.3V supply. <sup>(6)</sup> All GND balls connected to the PCB ground plane and all VDD3 balls connected to the PCB VDD plane. Figure A-2: V/I Curves for AGP 2X Buffers (Pull Up) Vddq = 3.3V Figure A-3: V/I Curves for AGP 2X Buffers (Pull Down) Vddq = 3.3V Figure A-4: V/I Curves for AGP 4X Buffers (Pull Up) Vddq = 1.5V Figure A-5: V/I Curves for AGP 4X Buffers (Pull Down) Vddq = 1.5V Table A-7: Buffer Type and Pin Load (Part 1 of 2) | | | Logo | l (pF) | Damping | | |--------------|-------------|------|--------|---------|---------| | Signal Name | Buffer Type | Min. | Max. | (ohms) | Notes | | PAD<31:0> | IO_AGP | 0 | 10 | - | | | PCBE<3:0>/ | IO_AGP | 0 | 10 | - | | | PCLK | I_AGP | - | - | - | (1) | | PDEVSEL/ | IO_AGP | 0 | 10 | - | | | PFRAME/ | IO_AGP | 0 | 10 | - | | | PGNT/ | I_AGP | - | - | - | | | PINTA/ | O_AGP | 0 | 10 | - | (1) | | PIRDY/ | IO_AGP | 0 | 10 | - | | | PPAR | IO_AGP | 0 | 10 | - | (2) | | PREQ/ | IO_AGP | 0 | 10 | - | (2) | | PRST/ | I_AGP | - | - | - | (1) | | PSTOP/ | IO_AGP | 0 | 10 | - | | | PTRDY/ | IO_AGP | 0 | 10 | - | | | SBA<7:0> | IO_AGP | 0 | 10 | - | (2) | | ST<2:0> | I_AGP | - | - | - | | | SB_STB | IO_AGP | 0 | 10 | - | (2) | | AD_STB<1:0> | IO_AGP | 0 | 10 | - | | | SB_STBN | IO_AGP | 0 | 10 | - | (2),(3) | | AD_STBN<1:0> | IO_AGP | 0 | 10 | - | (3) | | EXTINT/ | IO | - | - | - | | | EXTRST/ | IO_6 | 70 | 70 | - | (2) | | E2PCLK | IO_3 | 6 | 12 | - | (2) | | E2PCS/ | IO_3 | 25 | 50 | - | (2) | | MCLK | IO_12 | 23 | 39 | - | (2) | | MCLK2 | IO_12 | 23 | 39 | - | (2) | | MCSN<1:0> | IO_9 | 19 | 39 | - | (2) | | MCSN2<1:0> | IO_9 | 19 | 39 | - | (2) | | MA<11:0> | IO_9 | 23 | 39 | - | (2) | | MA2<11:0> | IO_9 | 23 | 39 | - | (2) | | MRASN | IO_9 | 23 | 39 | - | (2) | | MRASN2 | IO_9 | 23 | 39 | - | (2) | | MCASN | IO_9 | 23 | 39 | - | (2) | | MCASN2 | IO_9 | 23 | 39 | - | (2) | | MWEN | IO_9 | 23 | 39 | - | (2) | | MWEN2 | IO_9 | 23 | 39 | - | (2) | | MDSF | IO_9 | 23 | 39 | - | (2) | | MDSF2 | IO_9 | 23 | 39 | - | (2) | | MDQM<7:0> | IO_6 | 19 | 27 | - | (2) | | MDQM2<7:0> | IO_6 | 19 | 27 | - | (2) | | MDQ<63:0> | IO_6 | 19 | 29 | - | | | MDQ2<63:0> | IO_6 | 19 | 29 | - | | Table A-7: Buffer Type and Pin Load (Part 2 of 2) | C' | D. CC. T. | Load | d (pF) | Damping | Mindon | |-------------|-------------|------|--------|---------|--------| | Signal Name | Buffer Type | Min. | Max. | (ohms) | Notes | | VDOCLK | IO_9 | 10 | 20 | - | (2) | | VDOUT<11:0> | IO_6 | 10 | 20 | - | (2) | | VHSYNC/ | IO_6 | 10 | 20 | 33 | (2) | | VIDRST | IO_9 | 10 | 20 | - | | | VOBLANK/ | IO_9 | 10 | 20 | - | (2) | | VVSYNC/ | IO_6 | 10 | 20 | 33 | (2) | | DDC<3:0> | IO_6 | - | 50 | - | | | TST<1:0> | I_O | - | - | - | | | RBFN_LFT | I_O | - | - | - | | | MISC_WR | O_6 | - | 35 | - | | | C_WRN | O_6 | - | 50 | - | | | C_HRDY | I_O | - | 0 | - | | | C_ADDR<2:0> | O_6 | - | 40 | - | | | MISC(0) | IO_6 | - | 100 | - | | | MISC(1) | IO_6 | - | 100 | - | | | MISC(2) | IO_6 | - | 80 | - | | | HDATA<7:0> | IO_6 | - | 40 | - | | | E2PQ | I_O | - | 0 | - | | | E2PD | O_9 | - | 96 | - | | | VD<7:0> | IO_6 | - | 40 | - | | | VDCLK | IO_9 | - | 40 | - | | <sup>(1)</sup> PRSTN, PCLK, and PINTA are always powered by a 3.3V supply. <sup>(2)</sup> Input mode only when TST<1:0> = '00' (HiZ mode for NAND Tree test). <sup>(3)</sup> Available only when TYPEDETN = 0 (1.5 V AGP bus) and AGP4X mode is selected. ### A.3.2 AC Specifications The following tables indicate the timing parameters a device (SGRAM, BIOS ROM, RAMDAC, or other external device) must meet to work properly with the Matrox G400 chip. #### A.3.2.1 RAMDAC AC Parameters Table A-8: RAMDAC Parameter List | Parameter | Min. | Тур. | Max. | Units | |-----------------------------------------|------|------|------|-------| | Analog output delay (Td) (1) | TBD | TBD | TBD | ns | | Analog output settling time (Ts) (2) | - | 10.0 | - | ns | | Analog output rise/fall time (Tr/f) (3) | - | 2.0 | - | ns | | Glitch impulse | = | 50 | - | pV/s | | RAMDAC to RAMDAC crosstalk | - | - | 5% | - | | Analog output skew | - | - | - | ns | <sup>(1)</sup> Measured from the 90% point of the rising clock edge to 50% of full-scale transition. Table A-9: PLL Parameter List | Parameter | Min. | Тур. | Max. | Units | |---------------------------------------|------|------|------|-------| | P1 PLL frequency | 6.25 | - | 310 | MHz | | PLL duty cycle variation | 45 | - | 55 | % | | P2 PLL frequency | 6.25 | - | 310 | MHz | | Frequency select to PLL output stable | - | 1.00 | - | ms | | PLL phase jitter | - | - | 500 | ps | | PLL duty cycle jitter | - | - | 250 | ps | <sup>(2)</sup> Measured from 50% of full-scale transition to settled output, within +/- 1 LSB. <sup>(3)</sup> Measured between 10% and 90% of full-scale transition. #### **Host Interface Timing** A.3.2.2 Figure A-6: AGP 1X Timing Table A-10: AGP 1X Timing<sup>(1)</sup> | Symbol | Parameter | Min | Max | Unit | Notes | |---------------------|--------------------------------------|------|------|------|-------| | T <sub>pclk</sub> | PCLK cycle time | 15.0 | 30 | ns | | | T <sub>plow</sub> | PCLK low time | 6.0 | _ | ns | | | T <sub>phigh</sub> | PCLK high time | 6.0 | _ | ns | | | T <sub>on</sub> | Float to active delay | 1.0 | 6.0 | ns | _ | | T <sub>val1</sub> | PCLK to signal valid delay (Data) | 1.0 | 6.0 | ns | (2) | | T <sub>val2</sub> | PCLK to signal valid delay (Control) | 1.0 | 5.5 | ns | (3) | | T <sub>off</sub> | Active to float delay | 1.0 | 14.0 | ns | (4) | | T <sub>rstoff</sub> | Reset active to output float delay | | 40.0 | ns | | | T <sub>su1</sub> | Input setup time to PCLK (Data) | 5.5 | _ | ns | (5) | | T <sub>su2</sub> | Input setup time to PCLK (Control) | 6.0 | _ | ns | (6) | | T <sub>h</sub> | Input setup time from PCLK | 0 | _ | ns | _ | - (1) Timings are evaluated with a 10pF lumped load. Vt = 0.4 V $_{DDq}$ 3.3V operation and Vt = 0.5 $_{DDq}$ for 1.5V operation. - (2) Applies only to pframe/, pirdy/, ptrdy/, pstop/, pdevsel/, preq/, and ppar. - (3) Applies only to pad<31:0> and pcbe<3:0>/,SBA<7:0> and ppar. - (4) Hi-Z or off state is achieved when the total current delivered through the component pin is less than or equal to the leakage current specification - (5) Applies only to pad<31:0>, pcbe<3:0> and ppar. - (6) Applies only to pframe/, pirdy/, ptrdy/, pstop/, pdevsel/, pgnt/ and st<2:0>. Figure A-7: AGP 2X Timing Diagram AGP CLK AD Strobe $\mathsf{T}_{\mathsf{ons}}$ $\mathsf{T}_{\mathsf{OFFS}}$ - Figure A-8: AGP 2X Strobe/Data Turnaround Timings Table A-11: AGP 2X Timing<sup>(1)</sup> | Symbol | Parameter | Min | Max | Unit | Notes | | | |-----------------------------|--------------------------------------------|--------|-----|------|-------|--|--| | Transmitter Output Signals: | | | | | | | | | T <sub>TSf</sub> | CLK to transmit strobe falling | 2 | 12 | ns | | | | | T <sub>TSr</sub> | CLK to transmit strobe rising | | 20 | ns | _ | | | | T <sub>Dvb</sub> | Data valid before strobe | 1.7 | _ | ns | | | | | T <sub>Dva</sub> | Data valid after strobe | 1.9 | _ | ns | _ | | | | T <sub>ONd</sub> | Float to Active Delay | -1 | 9 | ns | | | | | T <sub>OFFd</sub> | Active to Float Delay | 1 | 12 | ns | | | | | T <sub>ONS</sub> | Strobe active to strobe falling edge setup | 6 | 10 | ns | _ | | | | T <sub>OFFS</sub> | Strobe rising edge to strobe float delay | 6 | 10 | ns | _ | | | | Receiver Ou | tput Signals: | | | | | | | | T <sub>RSsu</sub> | Receive strobe setup tome to CLK | 6 | _ | ns | _ | | | | T <sub>RSh</sub> | Receive strobe hold time from CLK | 1 | _ | _ | | | | | T <sub>Dsu</sub> | Data strobe setup time | 1 | _ | ns | _ | | | | $T_{Dh}$ | Strobe to data hold time | 1 | _ | ns | _ | | | | Ts <sub>low</sub> | Strobe minimum low and high time | 5.0 ns | | _ | _ | | | | Ts <sub>high</sub> | Strobe minimum low and high time | 5.0 ns | _ | _ | | | | | Tpll <sub>lock</sub> | AGP 2X pll lock time | | 2.5 | ns | | | | (1) Timings are evaluated with a 10pF lumped load. $Vt = 0.4\ V \\ DDq \\ 3.3V \ operation \ and \ Vt = 0.5 \\ DDq \\ for 1.5V \ operation.$ Figure A-9: AGP 4X Timing Diagram Figure A-10: AGP 4X Strobe/Data Turnaround Timings Table A-12: AGP 4X Timing<sup>(1)</sup> | Symbol | Parameter | Min | Max | Unit | Notes | | | |-------------------|-----------------------------------------------|-------|-----|------|-------|--|--| | Transmitter | Transmitter Output Signals: | | | | | | | | T <sub>TSf</sub> | CLK to transmit strobe falling | 1.9 | 8 | ns | | | | | T <sub>TSr</sub> | CLK to 4 <sup>th</sup> transmit strobe rising | | 20 | ns | _ | | | | T <sub>Dvb</sub> | Data valid before strobe | -0.95 | _ | ns | _ | | | | T <sub>Dva</sub> | Data valid after strobe | 1.15 | | ns | | | | | T <sub>ONd</sub> | Float to Active Delay | -1 | 7 | ns | _ | | | | T <sub>OFFd</sub> | Active to Float Delay | 1 | 14 | ns | _ | | | | T <sub>ONS</sub> | Strobe active to strobe falling edge setup | 4 | 9 | ns | _ | | | | T <sub>OFFS</sub> | Strobe rising edge to strobe float delay | 4 | 9 | ns | _ | | | Table A-12: AGP 4X Timing<sup>(1)</sup> | Receiver Output Signals: | | | | | | | |--------------------------|-----------------------------------|-----|---|----|-----|--| | T <sub>RSsu</sub> | Receive strobe setup tome to CLK | 6 | _ | ns | (2) | | | T <sub>RSh</sub> | Receive strobe hold time from CLK | 0.5 | _ | _ | (2) | | | T <sub>Dsu</sub> | Data strobe setup time | 0.4 | _ | ns | | | | T <sub>Dh</sub> | Strobe to data hold time | 0.7 | _ | ns | | | <sup>(1)</sup> Timings are evaluated with a 10pF lumped load. ### A.3.2.3 Serial EEPROM Device Timing Figure A-11: Serial EEPROM Waveform Table A-13: Serial EEPROM Clock Period Cycle | hioshoot | anial common siza | om size Matrox G400 tcp min (ns) | | taga (mg) | tcse | | | |----------|--------------------|----------------------------------|----|-----------|----------|-----------|--| | Diosbooi | serial eeprom size | | | icse (ns) | min (ns) | max (MHz) | | | 0 | 128 bytes | AGP | 15 | tcp * 64 | 960 | 1.04 | | | 1 | 32KB or 64KB | AGP | 15 | tcp * 16 | 240 | 4.17 | | •• Note: tcp is the AGP clock cycle period. •• *Note:* tose is the serial EEPROM clock cycle period. Table A-14: Serial EEPROM Parameter List | Name | Min. (ns) | Max. (ns) | Comment | |------|--------------|-----------|---------------------------------------| | t1 | tcse/2-tcp-3 | | Chip select falling to clock | | t2 | tcse-1 | | Chip select high time | | t3 | tcse/2-9 | | Input data setup time to clock rising | | t4 | tcse/2-2 | | Input data hod time from clock rising | | t5 | tcse/2 | | Clock low time | | t6 | tcse/2-1 | | Clock high time | $Vt = 0.4 \ V \\ DDq \ \ \text{for 3.3V operation and } Vt = 0.5 \\ DDq \ \ \text{for 1.5V operation}.$ <sup>(2)</sup> These specifications refer to the setup and hold times for the strobe set started in the previous cycle. Table A-14: Serial EEPROM Parameter List | Name | Min. (ns) | Max. (ns) | Comment | |------|--------------|-----------|------------------------------------------| | t7 | tcp-3 | | Clock falling time to chip select rising | | t8 | tcse/2+tcp-3 | | Clock rising to chip select rising | | t9 | | tcse-19 | Clock falling to valid output data | | t10 | 3 | | Output data hold from clock falling | #### **MAFC Feature Connector** A.3.2.4 Figure A-12: MAFC Waveform Figure A-13: Panel Link Mode Figure A-14: Bypass Mode & CRTC2 656 mode Table A-15: MAFC Waveform data information | Name | Min.<br>(ns) | Max. (ns) | Comment | | |------|--------------|-----------|--------------------------------------------------------|---------------------------| | T1 | 8.9 | - | VDOCLK Period (max 112 MHz) | (Slave Mode max 100 MHz) | | T2 | 4.0 | - | VDOCLK high | | | Т3 | 4.0 | - | VDOCLK low | | | T5 | 0.2 | 1.5 | Valid data time ( VOBLANK/ $\rightarrow$ VDOUT <11:0>) | MAFC RGB | | T6 | 6.0 | - | Setup time ( VIDRST $\rightarrow$ VDOCLK) | MAFC RGB | | T7 | 0.0 | - | Hold time ( VIDRST $\rightarrow$ VDOCLK) | MAFC RGB | | T9 | 1.1 | 3.5 | $VDOCLK \rightarrow VH(V)SYNC$ | Panel Link <sup>(1)</sup> | | T10 | 1.1 | 3.5 | $VDOCLK \rightarrow VOBLANK/$ | Panel Link <sup>(1)</sup> | | T11 | 1.1 | 3.5 | Valid data time ( VDOCLK $\rightarrow$ VDOUT <11:0>) | Panel Link <sup>(1)</sup> | | T12 | 16.0 | - | VDCLK period | | | T13 | 7.0 | - | VDCLK high | | | T14 | 7.0 | - | VDCLK low | | | T15 | 3.0 | 16.0 | VDCLK → VDOUT<7:0> | Bypass mode | | T16 | 3.0 | 12.0 | VOBLANKN → VDOUT<7:0> | Bypass mode | | T17 | 3.0 | 12.0 | VOBLANKN → VDOUT<7:0> | CRTC2-656 mode | $<sup>(1) \</sup> In \ Panel Link \ mode, the \ clock \ can \ come \ from \ the \ VDOCLK \ pin \ or \ the \ VIDRST \ pin \ (see \ panelsel < 0 >)$ Figure A-15: PanelLink and MAFC RGB Datapath ### Figure A-16: MAFC 656 Datapath P[2] = F xor H P[1] = F xor V P[0] = F xor V xor H ### A.3.2.5 Memory Interface Timing •• *Note:* Figure A-18 through Figure A-31 refer to generic signals which correspond to the memory interface pins as follows: | | Lower 64-bit data bus | Upper 64-bit data bus | | |------------------------|--------------------------|------------------------------|--| | MCLK | MCLK | MCLK2 | | | COMMAND <sup>(1)</sup> | MRASN, MCASN, MWEN, MDSF | MRASN2, MCASN2, MWEN2, MDSF2 | | | BA <sup>(2)</sup> | MA<11> | MA2<11> | | | AP | MA<10> | MA2<10> | | | ADDR <sup>(3)</sup> | MA<9:0> | MA2<9:0> | | | DQMi | MDQM<7:0> | MDQM2<7:0> | | | DQ | MDQ<63:0> | MDQ2<63:0> | | - (1) MDSF and MDSF2 are only valid for frame buffers populated with SGRAm and when the **hardpwmsk** field is programmed to '1'. - (2) BA == BA0 for two bank memory configurations and BA == <BA1, BA0> for four bank memory configurations; where BA1 is available on pin MA<8> and MA2<8> for SGRAM configurations and on pin MCSN<1> and MCSN2<1> for SDRAM configurations. - (3) MCSN<1> and MCSN2<1> are also used as an address signal for the 64Mb SDRAM configuration. Figure A-17: Memory Interface Waveform Table A-16: Memory Interface Parameter List | Timing | Description | Min. (ns) | Max. (ns) | |--------|-----------------------------------------------------------|-----------|-----------| | Tmclk | MCLK period | 6.66 | - | | Tmlow | MCLK low | 2.5 | - | | Tmhigh | MCLK high | 2.5 | - | | Tm2a | MCLK> Command (MRAS/, MCAS/, MWE/, MDSF, MCS/<3:0>) valid | 1.18 | 4.49 | | Tm2b | MCLK> MDQM<7:0> valid | 1.18 | 4.49 | | Tm2c | MCLK> MA<11:0> valid | 1.18 | 4.49 | | Tm2d | MCLK> MDQ<63:0> valid | 1.18 | 4.49 | | Tm3 | MDQ<63:0> setup> MCLK | 0.99 | - | | Tm4 | MDQ<63:0> hold> MCLK | 2.18 | - | | Tm5 | MCLK> MDQ<63:0> low-z | 1.18 | - | | Tm6 | MCLK> MDQ<63:0> high-z | - | 4.49 | Figure A-18: Read Followed by Precharge (Tcl=3) Figure A-19: Read Followed by a Precharge (Tcl = 2) Figure A-20: Write Followed by Precharge Figure A-21: Read Followed by Write (Tcl =3) Figure A-23: Write Followed by Read (same chip select) Figure A-25: Read to Both Banks (same chip select) Figure A-27: Write to Both Banks (same chip select) Figure A-29: Power-On Sequence Figure A-31: Memory Refresh Sequence Table A-17: Matrox G400 Sync. RAM Clock-Based Parameter Table | Symbol | Number of Clocks | Parameter | | |--------|------------------|---------------------------------------------------------|---------| | CL | (2,3,4) | CAS Latency | | | iRRD | (1,2,3) | Active command to active command (other bank) | (3) | | iRCD | (2,3,4) | Active command to column address command (min.) | (3) | | iRAS | (38) | Row Active time (min.) | (3) | | iRP | (25) | Row Precharge time (min.) | (3) | | iRC | iRAS + iRP | Row Cycle time (min.) | (3) | | iWR | (1, 2) | Last data in to precharge command (write recovery time) | (3) | | iEP | (-1, 1 - CL) | Last data out to early precharge command | | | iCCDrd | 1 | Read command to read command. | | | iCCDwr | 1 | Write command to write command | | | iCDL | 1 | Last data in to read command | | | iOWD | 2 | Last data out to write command | | | iMRD | 3 | MRS to row active command | | | iASD | iRCD | Active command to SMRS command | | | iSMD | (1,2) | SMRS to row block write command | | | iBWC | (1,2) | Block write cycle time (min) | | | iBPL | (15) | Block write command to precharge command | (3) (4) | <sup>(1)</sup> tCk operates in the range $\,$ [6,10] ns. or [100, 166] MHz. <sup>(2)</sup> CAS Latency is dependent upon tCK and memory device rating. <sup>(3)</sup> Programmable paramters based on device rating and tCK. For a given A.C. paramter tXXX; iXXX = tXXX/tCK rounded to the next largest integer. For example: tCK = 6.0 ns, tRAS = 58 ns = 3.67 iRAS = 10.67 sample <sup>(4)</sup> Paramters for SGRAM #### A.3.2.6 CODEC Figure A-32: I33 Mode, Writes Figure A-33: I33 Mode, Reads Figure A-34: VMI Mode A Writes Figure A-35: VMI Mode A, Reads Figure A-36: VMI Mode B, Writes Figure A-37: VMI Mode B, Reads Table A-18: Codec Parameters | name | Min (ns) | Max (ns) | Comment | | |------|----------|----------|---------------------------------------------------------|--| | TI1 | 11 | - | Address setup times to falling edge of HRD#/HWR# strobe | | | TI2 | 6 | - | Address hold time from rising edge of HRD#/HWR# strobe | | | TI3 | 7 | - | Data setup time to falling edge of HWR# strobe | | | TI4 | 5 | - | Data hold time form rising edge of HWR# strobe | | | TI5 | 31 | 44 | HRD#/HWR# strobe rising edge from ACK# falling edge | | | TI6 | 14 | - | Required data setup time to rising HRD# strobe | | | TI7 | 0 | - | Required data hold time from rising HRD# strobe | | | TA1 | 10 | - | Address setup time to falling edge of HDS# strobe | | | TA2 | 30 | - | Address hold time from rising edge of HDS# strobe | | | TA3 | 11 | - | Data setup time to falling edge of HDS# strobe | | | TA4 | 6 | - | Data hold time from rising edge of HDS# strobe | | | TA5 | 8 | - | HR/W# setup time to falling edge of HDS# strobe | | | TA6 | 30 | - | HR/W# hold time from falling edge of HDS# strobe | | | TA7 | 31 | 43 | HDS# strobe rising edge from HACK# falling edge | | | TA8 | 15 | - | Required data setup time to rising edge of HDS# strobe | | | TA9 | 0 | - | Required data hold time from rising edge of HDS# strobe | | | TB1 | 11 | - | Address setup time from falling edge of HRD#/HWR# | | | TB2 | 6 | - | Address hold time from rising edge of HRD#/HWR# strobe | | | TB3 | 13 | - | Data setup time to falling edge of HWR# strobe | | | TB4 | 15 | - | Data hold time form rising edge of HWR# strobe | | | TB5 | - | 20 | HACK# falling edge from HWR#/HRD# falling edge | | | TB6 | 0 | - | HACK# rising edge from HACK# falling edge | | | TB7 | 31 | 44 | HRD#/HWR# strobe rising edge from HACK# rising edge | | | TB8 | 14 | - | Required data setup time to rising HRD# strobe | | | TB9 | 0 | - | Required data hold time from rising HRD# strobe | | #### A.3.2.7 Video In Figure A-38: Video In Timings Table A-19: Video In Parameters | Name | min (ns) | Max (ns) | Comment | |--------------------|----------|----------|-------------------------------------------------------| | VIP in IN | PUT MOI | DЕ | | | Tvdclk | 16 | - | VIP input clock 1x mode (27 MHz) and 2x mode (54 MHz) | | Tvds | 4 | - | Required data setup time to rising edge of VDCLK | | Tvdh | 1 | - | Required data hold time to rising edge of VDCLK | | VIP in OUTPUT MODE | | | | | Tvd | 3 | 12 | VDCLK → VD<7:0> c2pixclk output on VDCLK | ### A.4 Mechanical Specification Figure A-39: Matrox G400 Mechanical Drawing #### A.5 NAND-Tree #### A.5.1 Nand-Tree Operation for Matrox G400 Rev. A The Matrox G400 is equipped with a *NAND-tree* to allow the lead connections to be verified by production test equipment. The test procedure is as follows: - 1. Force the TST pins to '00' to enter test mode and maintain that value during the entire test (for normal operations, the TST pins are tied to pull-ups). This will disable all output drivers except the PINTA/ pin. All pins (except PINTA/, the analog pins, and TST<1:0>) are used as input for the NAND-tree operation. In test mode, PINTA/ acts as a normal driver and is used for the NAND-tree output (for normal operations, PINTA/ is an open drain). - 2. Force all signal pins to logical '1'. PINTA/ should read '1'. - 3. Next, apply a '0' to the first pin in the NAND-tree. The PINTA/ output should toggle to '0'. - 4. Maintain the first pin at '0' and toggle the next pin to '0'. The output should toggle again. - 5. Continue the shift-in of '0', following the NAND-tree order and monitoring the toggling of the PINTA/ pin for each new test vector. #### A.5.2 Nand-Tree Operation for Matrox G400 Rev. B and later The Matrox G400 is equipped with two *NAND-trees* to allow the lead connections to be verified by low pin-count production test equipment. The two following tables list the pins that belong to the first (Table A-21) and second (Table A-22) NAND trees respectively. Testing of the lead connections consists of three steps: - 1. Testing the first NAND tree - 2. Testing the second NAND tree - 3. Testing the select logic #### Procedure for testing the pins in the first NAND tree (PCLK = 1) - 1. Apply '00' to the TST pins to enter test mode and maintain that value for the entire test. Forcing the TST pins to '00' will disable all output drivers except the PINTAN pin. All pins listed in Table A-21 are used as input for the NAND tree operation. (The pins in Table A-22 can be left open if the test equipment does not have enough drivers). In test mode, PINTAN acts as a normal driver and is used for the NAND tree output. - 2. Apply '1' to PCLK to select the first NAND tree. - 3. Force all signals in Table A-21 to logical '1'. PINTAN should read '0'. - 4. Apply a '0' to the first pin in Table A-21. PINTAN should toggle to '1'. - 5. Maintain the first pin at '0', and toggle the next pin in N1 to '0'. The output should toggle again. - 6. Continue the shift-in of '0', following the NAND tree order of Table A-21 and monitor the toggling of PINTAN for each new test vector. #### Procedure for testing the pins in the second NAND tree (PCLK = 0) - 1. Apply '00' to the TST pins to enter test mode and maintain that value for the entire test. Forcing the TST pins to '00' will disable all output drivers except the PINTAN pin. All pins listed in Table A-22 are used as input for the NAND tree operation. (The pins in Table A-21 can be left open if the test equipment does not have enough drivers). In test mode, PINTAN acts as a normal driver and is used for the NAND tree output. - 2. Apply '0' to PCLK to select the second NAND tree. - 3. Force all signals in Table A-22 to logical '1'. PINTAN should read '1'. - 4. Apply a '0' to the first pin in Table A-22. PINTAN should toggle to '0'. - 5. Maintain the first pin at '0', and toggle the next pin in Table A-22 to '0'. The output should toggle - 6. Continue the shift-in of '0', following the NAND tree order of Table A-22 and monitor the toggling of PINTAN for each new test vector. #### Procedure for testing the pins in the second NAND tree (PCLK = 0) - 1. Apply '00' to the TST pins to enter test mode and maintain that value for the entire test. Forcing the TST pins to '00' will disable all output drivers except the PINTAN pin. - 2. Apply '0' to the last pin of Table A-21 (**VOBLANKN**). The other pins in Table A-21 can be left - 3. Apply '0' to the first pin of Table A-22 (MDQ\_48) and apply '1' to all the other pins in Table A- - 4. Apply '1' to PCLK. PINTAN should read '1'. - 5. Apply '0' to PCLK, PINTAN should read '0'. Table A-20: Rev. A Nand Tree | Tree Order | Rall No | Nand Tree Pin Name | |------------|----------|--------------------| | 1 | B1 | PRSTN | | 2 | D4 | PCLK | | 3 | E4 | PREQN | | 4 | E3 | PGNTN | | 5 | F4 | ST_0 | | 6 | G3 | ST_1 | | 7 | H3 | ST_2 | | 8 | C1 | SBA_0 | | 9 | D3 | SBA_1 | | 10 | D3 | SBA_1<br>SBA 2 | | 11 | D1<br>D2 | SBA_2<br>SBA_3 | | 12 | F2 | _ | | | | SB_STB | | 13 | E1 | SB_STBN | | 14 | G1 | SBA_4 | | 15 | G2 | SBA_5 | | 16 | H1 | SBA_6 | | 17 | H2 | SBA_7 | | 18 | J2 | PAD_31 | | 19 | J3 | PAD_30 | | 20 | K3 | PAD_29 | | 21 | J1 | PAD_28 | | 22 | K1 | PAD_27 | | 23 | K2 | PAD_26 | | 24 | L1 | PAD_25 | | 25 | L2 | PAD_24 | | 26 | L3 | AD_STB_1 | | 27 | M3 | AD_STBN_1 | | 28 | N3 | PCBEN_3 | | 29 | N2 | PAD_23 | | 30 | N1 | PAD_22 | | 31 | P1 | PAD_21 | | 32 | R3 | PAD_18 | | 33 | R1 | PAD_19 | | 34 | P2 | PAD_20 | | 35 | V1 | PCBEN_2 | | 36 | U1 | PAD_16 | | 37 | T3 | PAD_17 | | 38 | AD3 | PDEVSELN | | 39 | AB3 | PFRAMEN | | 40 | AB4 | PIRDYN | | 41 | AC7 | PPAR | | 42 | AD4 | PSTOPN | | 43 | AC3 | PTRDYN | | Tree Order | Ball No. | Pin Name | |------------|----------|-----------| | 44 | V2 | PAD_14 | | 45 | Y3 | PAD_15 | | 46 | AA3 | PCBEN_1 | | 47 | W2 | PAD_11 | | 48 | AA1 | PAD_12 | | 49 | AA4 | PAD_13 | | 50 | AC2 | PAD_8 | | 51 | AD2 | AD_STBN_0 | | 52 | AE1 | AD_STB_0 | | 53 | AA2 | PAD_9 | | 54 | AB1 | PAD_10 | | 55 | AB2 | PCBEN_0 | | 56 | AF3 | PAD_5 | | 57 | AE2 | PAD_6 | | 58 | AF2 | PAD_7 | | 59 | AE4 | PAD_2 | | 60 | AF4 | PAD_3 | | 61 | AE3 | PAD_4 | | 62 | AE5 | PAD_0 | | 63 | AF5 | PAD_1 | | 64 | AC6 | MDQ_4 | | 65 | AC5 | MDQ_0 | | 66 | AE6 | MDQ_1 | | 67 | AD5 | MDQ_2 | | 68 | AF6 | MDQ_3 | | 69 | AE7 | MDQ_5 | | 70 | AD6 | MDQ_6 | | 71 | AF7 | MDQ_7 | | 72 | AD7 | MDQ_8 | | 73 | AE8 | MDQ_9 | | 74 | AC8 | MDQ_10 | | 75 | AF8 | MDQ_11 | | 76 | AD8 | MDQ_12 | | 77 | AE9 | MDQ_13 | | 78 | AC9 | MDQ_14 | | 79 | AF9 | MDQ_15 | | 80 | AC10 | MDQM_2 | | 81 | AD9 | MDQM_0 | | 82 | AE10 | MDQM_1 | | 83 | AF10 | MDQM_3 | | 84 | AD10 | MDQ_16 | | 85 | AE11 | MDQ_17 | | 86 | AC11 | MDQ_18 | | 87<br>88<br>89 | AF11 | MDQ_19 | |----------------|------|-----------| | | | 1,110(-1) | | 80 | AD11 | MDQ_20 | | 09 | AE12 | MDQ_21 | | 90 | AC12 | MDQ_22 | | 91 | AF12 | MDQ_23 | | 92 | AD12 | MDQ_24 | | 93 | AE13 | MDQ_25 | | 94 | AC13 | MDQ_26 | | 95 | AF13 | MDQ_27 | | 96 | AD13 | MDQ_28 | | 97 | AF14 | MDQ_29 | | 98 | AD14 | MDQ_30 | | 99 | AE14 | MDQ_31 | | 100 | AF15 | MA_1 | | 101 | AC14 | MA_0 | | 102 | AC15 | MA_4 | | 103 | AE15 | MA_3 | | 104 | AD15 | MA_2 | | 105 | AF16 | MA_5 | | 106 | AF17 | MA_9 | | 107 | AC16 | MA_8 | | 108 | AE16 | MA_7 | | 109 | AD16 | MA_6 | | 110 | AE17 | MA_11 | | 111 | AD17 | MA_10 | | 112 | AC18 | MCSN_0 | | 113 | AE19 | MCSN_1 | | 114 | AF18 | MWEN | | 115 | AE18 | MRASN | | 116 | AD18 | MCASN | | 117 | AC17 | MCLK | | 118 | AF19 | MDSF | | 119 | AF20 | MDQ_33 | | 120 | AD19 | MDQ_32 | | 121 | AF21 | MDQ_37 | | 122 | AD20 | MDQ_36 | | 123 | AC19 | MDQ_34 | | 124 | AE20 | MDQ_35 | | 125 | AF22 | MDQ_41 | | 126 | AD21 | MDQ_40 | | 127 | AE21 | MDQ_39 | | 128 | AC20 | MDQ_38 | | 129 | AF23 | MDQ_45 | | Tree Order | Ball No. | Pin Name | |------------|----------|----------| | 130 | AD22 | MDQ_44 | | 131 | AE22 | MDQ_43 | | 132 | AC21 | MDQ_42 | | 133 | AC22 | MDQM_4 | | 134 | AF24 | MDQM_5 | | 135 | AE24 | MDQM_7 | | 136 | AC23 | MDQM_6 | | 137 | AE23 | MDQ_47 | | 138 | AD23 | MDQ_46 | | 139 | AF25 | MDQ_49 | | 140 | AC24 | MDQ_48 | | 141 | AF26 | MDQ_53 | | 142 | AB23 | MDQ_52 | | 143 | AE25 | MDQ_51 | | 144 | AC25 | MDQ_50 | | 145 | AB25 | MDQ_56 | | 146 | AD24 | MDQ_55 | | 147 | AB24 | MDQ_54 | | 148 | AB26 | MDQ_58 | | 149 | AE26 | MDQ_57 | | 150 | AD25 | MDQ_59 | | 151 | Y23 | MDQ_60 | | 152 | AD26 | MDQ_61 | | 153 | V23 | MDQ_62 | | 154 | AC26 | MDQ_63 | | 155 | AA23 | MDQ2_0 | | 156 | AA25 | MDQ2_1 | | 157 | AA24 | MDQ2_2 | | 158 | AA26 | MDQ2_3 | | 159 | Y24 | MDQ2_4 | | 160 | Y25 | MDQ2_5 | | 161 | W23 | MDQ2_6 | | 162 | Y26 | MDQ2_7 | | 163 | W24 | MDQ2_8 | | 164 | W25 | MDQ2_9 | | 165 | V24 | MDQ2_10 | | 166 | W26 | MDQ2_11 | | 167 | U23 | MDQ2_12 | | 168 | V25 | MDQ2_13 | | 169 | U24 | MDQ2_14 | | 170 | V26 | MDQ2_15 | | 171 | U26 | MDQM2_3 | | 172 | T23 | MDQM2_0 | | Tree Order | Ball No. | Pin Name | |------------|----------|-----------| | 173 | U25 | MDQM2_1 | | 174 | T24 | MDQM2_2 | | 175 | R23 | MDQ2_16 | | 176 | T25 | MDQ2_17 | | 177 | R24 | MDQ2_18 | | 178 | T26 | MDQ2_19 | | 179 | P23 | MDQ2_20 | | 180 | R25 | MDQ2_21 | | 181 | P24 | MDQ2_22 | | 182 | R26 | MDQ2_23 | | 183 | P26 | MDQ2_27 | | 184 | N24 | MDQ2_24 | | 185 | P25 | MDQ2_25 | | 186 | N23 | MDQ2_26 | | 187 | M24 | MDQ2_28 | | 188 | N26 | MDQ2_29 | | 189 | N25 | MDQ2_31 | | 190 | M23 | MDQ2_30 | | 191 | G26 | MCSN2_0 | | 192 | H23 | MCSN2_1 | | 193 | L23 | MA2_2 | | 194 | M26 | MA2_1 | | 195 | L24 | MA2_0 | | 196 | L26 | MA2_5 | | 197 | K24 | MA2_4 | | 198 | M25 | MA2_3 | | 199 | K23 | MA2_6 | | 200 | J23 | MA2_10 | | 201 | K26 | MA2_9 | | 202 | J24 | MA2_8 | | 203 | L25 | MA2_7 | | 204 | K25 | MA2_11 | | 205 | H24 | MCASN2 | | 206 | H26 | MCLK2 | | 207 | J26 | MWEN2 | | 208 | H25 | MDSF2 | | 209 | J25 | MRASN2 | | 210 | G23 | MDQ2_34 | | 211 | G25 | MDQ2_33 | | 212 | G24 | MDQ2_32 | | 213 | F23 | MDQ2_38 | | 214 | F25 | MDQ2_37 | | 215 | F24 | MDQ2_36 | | 413 | 1.74 | 1410(2_30 | | Tree Order | Ball No. | Pin Name | |------------|----------|----------| | 216 | F26 | MDQ2_35 | | 217 | E23 | MDQ2_42 | | 218 | E25 | MDQ2_41 | | 219 | E24 | MDQ2_40 | | 220 | E26 | MDQ2_39 | | 221 | D23 | MDQ2_46 | | 222 | D25 | MDQ2_45 | | 223 | D24 | MDQ2_44 | | 224 | D26 | MDQ2_43 | | 225 | B26 | MDQM2_7 | | 226 | D22 | MDQM2_6 | | 227 | C25 | MDQM2_5 | | 228 | C23 | MDQM2_4 | | 229 | B25 | MDQ2_49 | | 230 | C22 | MDQ2_48 | | 231 | C26 | MDQ2_47 | | 232 | A26 | MDQ2_51 | | 233 | B22 | MDQ2_50 | | 234 | A22 | MDQ2_52 | | 235 | B24 | MDQ2_57 | | 236 | C24 | MDQ2_53 | | 237 | C21 | MDQ2_54 | | 238 | A25 | MDQ2_55 | | 239 | B21 | MDQ2_56 | | 240 | A21 | MDQ2_58 | | 241 | A24 | MDQ2_59 | | 242 | D20 | MDQ2_60 | | 243 | B23 | MDQ2_61 | | 244 | D18 | MDQ2_62 | | 245 | A23 | MDQ2_63 | | 246 | D21 | MISC_2 | | 247 | D19 | MISC_1 | | 248 | A20 | MISC_0 | | 249 | A19 | DDC_3 | | 250 | D17 | DDC_2 | | 251 | B19 | DDC_1 | | 252 | C19 | DDC_0 | | 253 | A18 | EXTINTN | | 254 | B18 | EXTRSTN | | 255 | C18 | HDATA_7 | | 256 | C17 | HDATA_6 | | 257 | C15 | HDATA_2 | | 258 | B17 | HDATA_5 | | Tree Order | Ball No. | Pin Name | |------------|----------|----------| | 259 | A17 | HDATA_4 | | 260 | D16 | HDATA_3 | | 261 | B15 | HDATA_1 | | 262 | A15 | HDATA_0 | | 263 | D14 | C_ADDR_1 | | 264 | A14 | C_ADDR_2 | | 265 | B14 | MISC_WR | | 266 | C14 | C_ADDR_0 | | 267 | C13 | C_WRN | | 268 | B13 | C_HRDY | | 269 | A13 | E2PQ | | 270 | D13 | E2PCSN | | 271 | C12 | E2PD | | 272 | B12 | E2PCLK | | 273 | B11 | VD_4 | | 274 | A11 | VD_5 | | 275 | D12 | VD_6 | | 276 | A12 | VD_7 | | 277 | B10 | VD_1 | | 278 | A10 | VD_2 | | 279 | C11 | VD_3 | | 280 | C10 | VD_0 | | 281 | C9 | VIDRST | | 282 | B9 | VDCLK | | 283 | A9 | VHSYNCN | | 284 | D11 | VVSYNCN | | 285 | B6 | VDOUT_8 | | 286 | C6 | VDOUT_9 | | 287 | D6 | VDOUT_10 | | 288 | D5 | VDOUT_11 | | 289 | D8 | VDOUT_4 | | 290 | A7 | VDOUT_5 | | 291 | В7 | VDOUT_6 | | 292 | C7 | VDOUT_7 | | 293 | D10 | VDOUT_0 | | 294 | A8 | VDOUT_1 | | 295 | B8 | VDOUT_2 | | 296 | A6 | VDOCLK | | 297 | C8 | VDOUT_3 | | 298 | C5 | VOBLANKN | Table A-21: Rev. B and later Nand Tree - 1 | Tree Order | Ball No. | Pin Name | |------------|----------|----------| | 1 | AB26 | MDQ_58 | | 2 | AB25 | MDQ_56 | | 3 | AB24 | MDQ_54 | | 4 | V23 | MDQ_62 | | 5 | AB23 | MDQ_52 | | 6 | AA26 | MDQ2_3 | | 7 | AA25 | MDQ2_1 | | 8 | AA24 | MDQ2_2 | | 9 | AA23 | MDQ2_0 | | 10 | W23 | MDQ2_6 | | 11 | Y26 | MDQ2_7 | | 12 | U23 | MDQ2_12 | | 13 | Y25 | MDQ2_5 | | 14 | Y24 | MDQ2_4 | | 15 | W26 | MDQ2_11 | | 16 | T23 | MDQM2_0 | | 17 | W25 | MDQ2_9 | | 18 | W24 | MDQ2_8 | | 19 | V26 | MDQ2_15 | | 20 | V25 | MDQ2_13 | | 21 | V24 | MDQ2_10 | | 22 | U26 | MDQM2_3 | | 23 | U25 | MDQM2_1 | | 24 | U24 | MDQ2_14 | | 25 | R23 | MDQ2_16 | | 26 | T26 | MDQ2_19 | | 27 | T25 | MDQ2_17 | | 28 | T24 | MDQM2_2 | | 29 | R26 | MDQ2_23 | | 30 | R25 | MDQ2_21 | | 31 | P23 | MDQ2_20 | | 32 | R24 | MDQ2_18 | | 33 | P26 | MDQ2_27 | | 34 | P25 | MDQ2_25 | | 35 | P24 | MDQ2_22 | | 36 | N24 | MDQ2_24 | | 37 | N25 | MDQ2_31 | | 38 | N26 | MDQ2_29 | | 39 | N23 | MDQ2_26 | | 40 | M24 | MDQ2_28 | | 41 | M25 | MA2_3 | | Tree Order | Ball No. | Pin Name | |------------|----------|----------| | 42 | M26 | MA2_1 | | 43 | L24 | MA2_0 | | 44 | L25 | MA2_7 | | 45 | L26 | MA2_5 | | 46 | K24 | MA2_4 | | 47 | M23 | MDQ2_30 | | 48 | K25 | MA2_11 | | 49 | K26 | MA2_9 | | 50 | L23 | MA2_2 | | 51 | J24 | MA2_8 | | 52 | J25 | MRASN2 | | 53 | J26 | MWEN2 | | 54 | H24 | MCASN2 | | 55 | H25 | MDSF2 | | 56 | K23 | MA2_6 | | 57 | H26 | MCLK2 | | 58 | G24 | MDQ2_32 | | 59 | G25 | MDQ2_33 | | 60 | G26 | MCSN2_0 | | 61 | H23 | MCSN2_1 | | 62 | F23 | MDQ2_38 | | 63 | F24 | MDQ2_36 | | 64 | J23 | MA2_10 | | 65 | F25 | MDQ2_37 | | 66 | F26 | MDQ2_35 | | 67 | E24 | MDQ2_40 | | 68 | E23 | MDQ2_42 | | 69 | E25 | MDQ2_41 | | 70 | E26 | MDQ2_39 | | 71 | G23 | MDQ2_34 | | 72 | D25 | MDQ2_45 | | 73 | D24 | MDQ2_44 | | 74 | D26 | MDQ2_43 | | 75 | C25 | MDQM2_5 | | 76 | B26 | MDQM2_7 | | 77 | C26 | MDQ2_47 | | 78 | C24 | MDQ2_53 | | 79 | B25 | MDQ2_49 | | 80 | D23 | MDQ2_46 | | 81 | A26 | MDQ2_51 | | 82 | A24 | MDQ2_59 | | 83 | A25 | MDQ2_55 | | Tree Order | Ball No. | Pin Name | |------------|----------|----------| | 84 | B24 | MDQ2_57 | | 85 | B23 | MDQ2_61 | | 86 | A23 | MDQ2_63 | | 87 | D20 | MDQ2_60 | | 88 | C23 | MDQM2_4 | | 89 | A22 | MDQ2_52 | | 90 | B22 | MDQ2_50 | | 91 | D22 | MDQM2_6 | | 92 | C22 | MDQ2_48 | | 93 | A21 | MDQ2_58 | | 94 | B21 | MDQ2_56 | | 95 | D18 | MDQ2_62 | | 96 | C21 | MDQ2_54 | | 97 | D21 | MISC_2 | | 98 | D19 | MISC_1 | | 99 | A20 | MISC_0 | | 100 | A19 | DDC_3 | | 101 | D17 | DDC_2 | | 102 | B19 | DDC_1 | | 103 | C19 | DDC_0 | | 104 | A18 | EXTINTN | | 105 | B18 | EXTRSTN | | 106 | C18 | HDATA_7 | | 107 | D16 | HDATA_3 | | 108 | A17 | HDATA_4 | | 109 | B17 | HDATA_5 | | 110 | C17 | HDATA_6 | | 111 | A15 | HDATA_0 | | 112 | B15 | HDATA_1 | | 113 | C15 | HDATA_2 | | 114 | D14 | C_ADDR_1 | | 115 | A14 | C_ADDR_2 | | 116 | B14 | MISC_WR | | 117 | C14 | C_ADDR_0 | | 118 | C13 | C_WRN | | 119 | B13 | C_HRDY | | 120 | A13 | E2PQ | | 121 | D13 | E2PCSN | | 122 | C12 | E2PD | | 123 | B12 | E2PCLK | | 124 | A12 | VD_7 | | 125 | C11 | VD_3 | | L | l . | <u>l</u> | | Tree Order | Ball No. | Pin Name | |------------|----------|----------| | 126 | B11 | VD_4 | | 127 | A11 | VD_5 | | 128 | C10 | VD_0 | | 129 | D12 | VD_6 | | 130 | B10 | VD_1 | | 131 | A10 | VD_2 | | 132 | C9 | VIDRST | | 133 | B9 | VDCLK | | 134 | A9 | VHSYNCN | | 135 | D11 | VVSYNCN | | 136 | C8 | VDOUT_3 | | 137 | B8 | VDOUT_2 | | 138 | A8 | VDOUT_1 | | 139 | C7 | VDOUT_7 | | 140 | D10 | VDOUT_0 | | 141 | B7 | VDOUT_6 | | 142 | A7 | VDOUT_5 | | 143 | D6 | VDOUT_10 | | 144 | C6 | VDOUT_9 | | 145 | D8 | VDOUT_4 | | 146 | B6 | VDOUT_8 | | 147 | A6 | VDOCLK | | 148 | D5 | VDOUT_11 | | 149 | C5 | VOBLANKN | Table A-22: Rev. B and later Nand Tree - 2 | Tree Order | Ball No. | Pin Name | |------------|----------|----------| | 1 | AC24 | MDQ_48 | | 2 | Y23 | MDQ_60 | | 3 | AC25 | MDQ_50 | | 4 | AD25 | MDQ_59 | | 5 | AC26 | MDQ_63 | | 6 | AD26 | MDQ_61 | | 7 | AE26 | MDQ_57 | | 8 | AC23 | MDQM_6 | | 9 | AF26 | MDQ_53 | | 10 | AE25 | MDQ_51 | | 11 | AD24 | MDQ_55 | | 12 | AF24 | MDQM_5 | | 13 | AF25 | MDQ_49 | | 14 | AE24 | MDQM_7 | | 15 | AF23 | MDQ_45 | | 16 | AD23 | MDQ_46 | | 17 | AE23 | MDQ_47 | | 18 | AF22 | MDQ_41 | | 19 | AC20 | MDQ_38 | | 20 | AE22 | MDQ_43 | | 21 | AD22 | MDQ_44 | | 22 | AF21 | MDQ_37 | | 23 | AC22 | MDQM_4 | | 24 | AE21 | MDQ_39 | | 25 | AD21 | MDQ_40 | | 26 | AC18 | MCSN_0 | | 27 | AC21 | MDQ_42 | | 28 | AF20 | MDQ_33 | | 29 | AE20 | MDQ_35 | | 30 | AC19 | MDQ_34 | | 31 | AD20 | MDQ_36 | | 32 | AF19 | MDSF | | 33 | AC17 | MCLK | | 34 | AE19 | MCSN_1 | | 35 | AD19 | MDQ_32 | | 36 | AF18 | MWEN | | 37 | AE18 | MRASN | | 38 | AD18 | MCASN | | 39 | AF17 | MA_9 | | 40 | AC16 | MA_8 | | 41 | AE17 | MA_11 | | Tree Order | Ball No. | Pin Name | |------------|----------|------------| | 42 | AD17 | MA_10 | | 43 | AF16 | MA_5 | | 44 | AC15 | MA_4 | | 45 | AE16 | MA_7 | | 46 | AD16 | MA_6 | | 47 | AF15 | MA_1 | | 48 | AE15 | MA_3 | | 49 | AD15 | MA_2 | | 50 | AF14 | MDQ_29 | | 51 | AE14 | MDQ_31 | | 52 | AC14 | MA_0 | | 53 | AD14 | MDQ_30 | | 54 | AD13 | MDQ_28 | | 55 | AE13 | MDQ_25 | | 56 | AF13 | MDQ_27 | | 57 | AD12 | MDQ_24 | | 58 | AE12 | MDQ_21 | | 59 | AF12 | MDQ_23 | | 60 | AC13 | MDQ_26 | | 61 | AD11 | MDQ_20 | | 62 | AE11 | MDQ_17 | | 63 | AF11 | MDQ_19 | | 64 | AD10 | MDQ_16 | | 65 | AC12 | MDQ_22 | | 66 | AE10 | MDQM_1 | | 67 | AF10 | MDQM_3 | | 68 | AD9 | MDQM_0 | | 69 | AE9 | MDQ_13 | | 70 | AF9 | MDQ_15 | | 71 | AE8 | MDQ_9 | | 72 | AD8 | MDQ_12 | | 73 | AF8 | MDQ_11 | | 74 | AD7 | MDQ_8 | | 75 | AC11 | MDQ_18 | | 76 | AE7 | MDQ_5 | | 77 | AF7 | MDQ_7 | | 78 | AC6 | MDQ_4 | | 79 | AC10 | MDQM_2 | | 80 | AE6 | MDQ_1 | | 81 | AD6 | MDQ_6 | | 82 | AC8 | MDQ_10 | | 83 | AF6 | MDQ_3 | | | AF6 | <b>\</b> = | | Tree Order | Ball No. | Pin Name | |------------|----------|-----------| | 84 | AD5 | MDQ_2 | | 85 | AC5 | MDQ_0 | | 86 | AC9 | MDQ_14 | | 87 | AE5 | PAD_0 | | 88 | AF5 | PAD_1 | | 89 | AD4 | PSTOPN | | 90 | AC7 | PPAR | | 91 | AE4 | PAD_2 | | 92 | AF4 | PAD_3 | | 93 | AE3 | PAD_4 | | 94 | AF3 | PAD_5 | | 95 | AF2 | PAD_7 | | 96 | AD3 | PDEVSELN | | 97 | AE2 | PAD_6 | | 98 | AE1 | AD_STB_0 | | 99 | AD2 | AD_STBN_0 | | 100 | AC2 | PAD_8 | | 101 | AC3 | PTRDYN | | 102 | AB1 | PAD_10 | | 103 | AB2 | PCBEN_0 | | 104 | AB3 | PFRAMEN | | 105 | AB4 | PIRDYN | | 106 | AA1 | PAD_12 | | 107 | AA2 | PAD_9 | | 108 | AA3 | PCBEN_1 | | 109 | AA4 | PAD_13 | | 110 | Y3 | PAD_15 | | 111 | W2 | PAD_11 | | 112 | V1 | PCBEN_2 | | 113 | V2 | PAD_14 | | 114 | U1 | PAD_16 | | 115 | T3 | PAD_17 | | 116 | R1 | PAD_19 | | 117 | R3 | PAD_18 | | 118 | P1 | PAD_21 | | 119 | P2 | PAD_20 | | 120 | N3 | PCBEN_3 | | 121 | N2 | PAD_23 | | 122 | N1 | PAD_22 | | 123 | M3 | AD_STBN_1 | | 124 | L3 | AD_STB_1 | | 125 | L2 | PAD_24 | | Tree Order | Ball No. | Pin Name | |------------|----------|----------| | 126 | L1 | PAD_25 | | 127 | K3 | PAD_29 | | 128 | K2 | PAD_26 | | 129 | K1 | PAD_27 | | 130 | J3 | PAD_30 | | 131 | J2 | PAD_31 | | 132 | J1 | PAD_28 | | 133 | Н3 | ST_2 | | 134 | H2 | SBA_7 | | 135 | H1 | SBA_6 | | 136 | G3 | ST_1 | | 137 | G2 | SBA_5 | | 138 | G1 | SBA_4 | | 139 | F4 | ST_0 | | 140 | F2 | SB_STB | | 141 | E4 | PREQN | | 142 | E3 | PGNTN | | 143 | E1 | SB_STBN | | 144 | D3 | SBA_1 | | 145 | D1 | SBA_2 | | 146 | D2 | SBA_3 | | 147 | C1 | SBA_0 | | 148 | B1 | PRSTN | ### A.6 Ordering Information ■ To receive a particular chip revision, order the matrox part number indicated in the table of section B.1.1.1 Revision Changes. # Appendix B: Changes | Changes in the DocumentSince Revision 0300 | B-2 | |--------------------------------------------|-----| | Changes in the Document | B-2 | ### **B.1 Changes in the Document Since Revision 0100** This appendix contains the revision history of the Matrox G400 Specification. The first spec. release was made specifically for OEM needs (10617-MS-0100, dated March 1, 1999) and contains information that has since been updated. This section is meant for customers who need to identify the functional changes that took place between various versions of the chip. These changes may or may not be reflected elsewhere in this manual. #### **B.1.1** Chip Revision Notes and Changes #### **B.1.1.1** Revision Changes The revision changes of the chip are reflected in the revision field of the **CLASS** register: | Chip Revision | Matrox Part No. | Rev. ID in CLASS Register | Internal Chip Ref. | |---------------|-----------------|---------------------------|--------------------| | rev. A | MGA-G400A-A | 00h | Rev. 0 | | rev. B | MGA-G400A-B | 01h | Rev. 1 | | rev. C | MGA-G400A-C | 02h | Rev. 1B | | rev. D | MGA-G400A-D | 03h | Rev. 2 | | rev. E | MGA-G400A-E | 04h | Rev. 2B | #### **B.1.1.2** Ordering Information To recieve a particular chip revision, order the Matrox part number indicated in the in the table in section B.1.1.1. Note that revisions **A** and **B** (part numbers MGA-G400A-A and MGA G400A-B) correspond to prototype chips that cannot be ordered. Revision C (part number MGA-G400A-C) was intended for limited production and may no longer be ordered. #### **B.1.1.3** Functional Changes (Latest Revision to Earliest) Matrox G400 rev. D Not applicable Matrox G400 rev. C Not Applicable Matrox G400 rev. B For the **bumpmapping** field (in the **TEXCTL2** register), reset the bump bit to '0' once the bump mapping primitive ceases. Matrox G400 rev. A When the **bumpmapping** field (in the **TEXCTL2** register) is set to '1' to activate bump mapping, it must be reset to '0' to perform any other operation (other texturing modes and any 2D or 3D operations). The correct programming technique is to program **bumpmapping** to '1' when entering a function performing bump mapping, then reset to '0' before exiting the function. | Power Graphic Mode Register | astipple <11> | 34 | |--------------------------------|----------------------------|----| | Fields (includes configuration | aten <12> | | | • | atmode <15:13> | 34 | | space and memory space | atref <23:16> | 34 | | register fields) | atype <6:4> 3-13 | 33 | | | avgstride <19> 3-21 | 18 | | aclkdivrst <10> | azeroextend <23> 3-21 | 12 | | addr4g_cap <5> | backcol <31:0> | 16 | | agp_cap_id <7:0> | bempty <9> 3-14 | 11 | | agp_enable <8> | bes1wghts <16> | 73 | | agp_next_ptr <15:8> | bes2wghts <16> | 74 | | agp_rev <23:16> | bes3plane <5> 3-6 | 51 | | alpha0add <27> 3-198 | bes420pl <17> | 59 | | alpha0add2x <29> 3-198 | besa1c3org <24:0> | 17 | | alpha0add bias <28> | besa1corg <24:0> | 18 | | alpha0arg1 inv <23> 3-197 | besa1org <24:0> | | | alpha0arg1 inv <23> 3-202 | besa2c3org <24:0> 3-5 | | | alpha0arg2 inv <26> | besa2corg <24:0> | | | alpha0arg2 sel <25:24> 3-197 | besa2org <24:0> | | | alpha0mod bright <29:28> 3-198 | besb1c3org <24:0> 3-5 | | | alpha0sel <31:30> 3-198 | besb1corg <24:0> | | | alpha1add <27> 3-203 | besb1org <24:0> | | | alpha1add2x <29> 3-203 | besb2c3org <24:0> 3-5 | | | alpha1add bias <28> | besb2corg <24:0> 3-5 | | | alpha1arg2 inv <26> | besb2org <24:0> | | | alpha1arg2 sel <25:24> 3-202 | besblank <21> 3-6 | | | alpha1mod bright <29:28> 3-203 | besbot <10:0> | 75 | | alpha1sel <31:30> 3-203 | bes brightness <23:16> 3-6 | 58 | | alphamode <9:8> | besbwen <20> | | | alphasel <25:24> | bescontrast <7:0> | 58 | | alphastart <23:0> | bescorder <3> | 51 | | alphaxinc <23:0> | bescups <16> | 59 | | alphayinc <23:0> | besdith <18> | 50 | | apllbyp <9> 3-205 | besen <0> | 59 | | apllmode1 <14> | besfsel <26:25> | 50 | | aplls0 <13> | besfselm <24> | 50 | | aplls1 <12> | beshfen <10> | 59 | | aplltst <11> | beshfixc <12> | 59 | | ar0 <21:0> | beshiscal <20:2> | 54 | | ar1 <23:0> | beshmir <19> | | | ar2 <21:0> | beshsrcend <25:2> 3-6 | | | ar3 <23:0> | beshsrclst <25:16> 3-6 | | | ar4 <21:0> | beshsrcst <25:2> | | | ar5 <21:0> | beshzoom <0> | | | ar6 <21:0> | beshzoomf <1> | | | arzero <12> 3-134 | besleft <26:16> | | | Power Graphic (cont) | bypass332 <28> 3-153 | |---------------------------------|-----------------------------| | | c2bpp15h alpha <15:8> 3-81 | | bespitch <11:0> | c2bpp15l alpha <23:16> 3-81 | | besprocamp <7> | c2cbcrfilten <2> | | besreghup <4> | c2depth <23:21> | | besrgbmode <9:8> 3-61 | c2dithen <0> | | besright <10:0> | c2en <0> | | besstat <1:0> | c2field <24> | | bestop <26:16> | c2fieldlength <26> 3-78 | | besuyvyfmt <6> | c2fieldline0 <2:0> | | besv1 srclast <9:0> 3-71 | c2fieldline1 <6:4> 3-84 | | besv1srcstp <6> 3-59 | c2fieldpol <27> | | besv1wght <15:2> 3-73 | c2hdispend <27:16> 3-82 | | besv2srclst <9:0> | c2hiprilvl <6:4> 3-77 | | besv2srcstp <7> | c2hploaden <30> 3-79 | | besv2wght <15:2> 3-74 | c2hpreload <11:0> 3-90 | | bes vcbcrsingle <10> 3-62 | c2hsyncend <27:16> | | besvcnt <27:16> | c2hsyncpol <8> | | besvfen <11> | c2hsyncstr <11:0> | | besviscal <20:2> 3-76 | c2htotal <11:0> | | bfull <8> | c2interlace <25> | | biosen <30> | c2maxhipri <10:8> 3-77 | | bl <11> | c2ntscen <4> | | bltckey <31:0> | c2offset <14:0> | | bltcmsk <31:0> | c2offsetdiven <6> | | bltmod <28:25> 3-137 | c2pixclkdis <3> | | blvliclr <2> | c2pixclksel <2:1> | | blylian <2> | c2pl2start add0 <24:0> | | blvlpen <2> | c2pl2start add1 <24:0> | | bop <19:16> | c2pl3start add0 <24:0> | | bpldelay <31:29> | c2spicstart add0 <24:0> | | brkleft <8> | c2spicstart add0 <24:0> | | brklefttop <9> | c2startadd0 <24:0> | | brkrighttop <17> | c2startadd1 <24:0> | | bumploffset <16:8> | c2statickey <28:24> | | bumplscale <7:0> | c2static keyen <5> | | bumplsfmt <18:17> | c2subpic cblut <23:16> 3-95 | | bump mapping <9> 3-216 | c2subpic crlut <31:24> | | bumpmat00 <7:0> 3-194 | c2subpicen <3> | | bumpmat01 <15:8> | c2subpiclutx <3:0> | | bumpmat10 <23:16> 3-194 | c2subpicylut <15:8> | | bumpmat11 <31:24> 3-194 | c2uyvyfmt <7> | | bumpmatfmt <20:19> 3-195 | c2vcbcr single <24> 3-78 | | busmaster $R/W < 2 > \dots 3-8$ | c2vcount <11:0> | | bwcdelay <27:26> 3-156 | c2vdispend <27:16> 3-97 | | | | | Power Graphic (cont) | color0alpha1 inv <9> | 3-196 | |-----------------------------|--------------------------|-------| | (00, | color0alpha2 inv <10> | | | c2vidrstmod <29:28> 3-79 | color0 alphasel <4:2> | | | c2vlinecomp <27:16> 3-84 | color0arg1 add <13> | | | c2vlineiclr <9> | color0arg1 alpha <5> | | | c2vlineien <9> | color0arg1 inv <6> | | | c2vlinepen RO <9> 3-188 | color0arg1 mul <11> | | | c2vploaden <31> | color0arg2 add <14> | | | c2vpreload <27:16> 3-90 | color0arg2 alpha <7> | | | c2vsyncend <27:16> | color0arg2 inv <8> | | | c2vsyncpol <9> | color0arg2 mul <12> | | | c2vsyncstr <11:0> | color0arg2 sel <1:0> | | | c2vtotal <11:0> | color0blend <20> | | | c2yfilten <1> | color0mod bright <16:15> | | | cacheline <6:0> | color0sel <22:21> | | | cap_ptr RO<7:0> | color1add <17> | | | cap66mhz RO <21> | color1add2x <18> | | | caplist RO <20> | color1add bias <19> | | | casltncy <2:0> | color1alpha1 inv <9> | | | centersnap <15> | color1alpha2 inv <10> | | | ckstransdis <4> | color1 alphasel <4:2> | | | clampu <28> | color1 adphaser < 4.2> | | | clampy <27> | color1arg1 alpha <5> | | | class <31:8> | color1arg1 inv <6> | | | clipdis <31> | color1arg1 mul <11> | | | cmdcmpliclr <1> | color1arg2 add <14> | | | cmdcmplien <1> | color1arg2 alpha <7> | | | cmdcmplpen <1> | color1arg2 inv <8> | | | cmdexectrig <2> | color1arg2 mul <12> | | | codec _stalled <12> 3-258 | color1arg2 sel <1:0> | | | codecbufsize <0> | color1blend <20> | | | codecdatain <3> | color1mod bright <16:15> | | | codecen <0> | color1sel <22:21> | | | codecfifo addr <11:8> 3-103 | comp_or <3> | | | codechardptr <15:0> | compfreq <7:4> | | | codechostptr <15:0> 3-105 | compordn <15:12> | | | codeclcode <15:0> 3-106 | comporup <11:8> | | | codecmode <1> | crtcdacsel <20> | | | codecrwidth <13:12> 3-103 | cxleft <11:0> | | | codecstart <24:2> 3-101 | cxleft <11:0> | | | codec transen <6> 3-102 | cxright <11:0> | | | codprediv <26> | cxright <27:16> | | | codpstdiv <27> | cybot <23:0> | | | color0add <17> | cytop <23:0> | | | color0add2x <18> | d2_sup <26> | | | color0add bias <19> 3-197 | data_rate <2:0> | | | Power Graphic (cont) extien <6> 3-150 extpen RO <6> 3-188 dcmpeoiiclr <3> 3-243 fastbackcap RO <23> 3-9 dcmpeoipen <3> 3-244 fastcrop <10> 3-173 dcmpeoipen <3> 3-257 fifocount <4:0> 3-141 decalblend <0> 3-215 fifocount <4:0> 3-141 decalckey <24> 3-212 fogcol <23:0> 3-142 decaldis <2> 3-215 fogen <26> 3-152 detparerr RO <31> 3-9 fogstart <23:0> 3-143 device <31:16> 3-10 fogxinc <23:0> 3-144 devseltim RO <26:25> 3-9 fogyinc <23:0> 3-145 dftmode <27> 3-208 forcol <31:0> 3-145 dftmode <27> 3-208 forcol <31:0> 3-145 dift555 <31> 3-159 funcnt <6:0> 3-175 dmadatasiz <9:8> 3-159 funcnt <6:0> 3-175 dmamod <3:2> 3-146 fxleft <15:0> 3-146 dr0 <31:0> | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | dcmpeoiiclr <3> 3-243 fastbackcap RO <23> 3-9 dcmpeoiien <3> 3-244 fastcrop <10> 3-173 dcmpeoipen <3> 3-257 fifocount <4:0> 3-141 decalblend <0> 3-215 filteralpha <20> 3-218 decalckey <24> 3-212 fogcol <23:0> 3-142 decaldis <2> 3-215 fogen <26> 3-152 detparerr RO <31> 3-9 fogstart <23:0> 3-143 device <31:16> 3-10 fogxinc <23:0> 3-144 devseltim RO <26:25> 3-9 fogyinc <23:0> 3-145 dftmode <27> 3-208 forcol <31:0> 3-145 dirtodatasiz <17:16> 3-159 fthres <28:21> 3-218 diit555 <31> 3-159 funcnt <6:0> 3-175 dmadatasiz <9:8> 3-159 fw_cap <4> 3-5 dmapad <31:0> 3-114 fxleft <15:0> 3-146 dr0 <31:0> 3-118 fxleft <15:0> 3-147 dr0 <23:0> 3-125 fxright <31:16> 3-146 | | dcmpeoiien <3> 3-244 fastcrop <10> 3-173 dcmpeoipen <3> 3-257 fifocount <4:0> 3-141 decalblend <0> 3-215 filteralpha <20> 3-218 decalckey <24> 3-212 fogcol <23:0> 3-142 decaldis <2> 3-215 fogen <26> 3-152 detparerr RO <31> 3-9 fogstart <23:0> 3-143 device <31:16> 3-10 fogxinc <23:0> 3-144 devseltim RO <26:25> 3-9 fogyinc <23:0> 3-145 dftmode <27> 3-208 forcol <31:0> 3-140 dirdatasiz <17:16> 3-159 fthres <28:21> 3-218 dit555 <31> 3-153 funcnt <6:0> 3-175 dmadatasiz <9:8> 3-159 funoff <21:16> 3-175 dmamod <3:2> 3-149 fxleft <15:0> 3-146 dr0 <31:0> 3-114 fxleft <15:0> 3-146 dr0 <23:0> 3-125 fxright <15:0> 3-148 dr10 <23:0> 3-125 fxright <31:16> 3-146 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 | | dcmpeoipen <3> 3-257 fifocount <4:0> 3-141 decalblend <0> 3-215 filteralpha <20> 3-218 decalckey <24> 3-212 fogcol <23:0> 3-142 decaldis <2> 3-215 fogen <26> 3-152 detparerr RO <31> 3-9 fogstart <23:0> 3-143 device <31:16> 3-10 fogxinc <23:0> 3-144 devseltim RO <26:25> 3-9 fogyinc <23:0> 3-145 dftmode <27> 3-208 forcol <31:0> 3-140 dirdatasiz <17:16> 3-159 fthres <28:21> 3-218 dit555 <31> 3-153 funcnt <6:0> 3-175 dmadatasiz <9:8> 3-159 fw_cap <4> 3-5 dmapad <31:0> 3-114 fxleft <15:0> 3-146 dr0 <31:0> 3-118 fxleft <15:0> 3-147 dr0_z32 <47:0> 3-115 fxright <15:0> 3-148 dr10 <23:0> 3-125 fxright <31:16> 3-146 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-128 gclkdiv <5:3> 3-23 | | decalblend <0> 3-215 filteralpha <20> 3-218 decalckey <24> 3-212 fogcol <23:0> 3-142 decaldis <2> 3-215 fogen <26> 3-152 detparerr RO <31> 3-9 fogstart <23:0> 3-143 device <31:16> 3-10 fogxinc <23:0> 3-144 devseltim RO <26:25> 3-9 fogyinc <23:0> 3-145 dftmode <27> 3-208 forcol <31:0> 3-140 dirdatasiz <17:16> 3-159 fthres <28:21> 3-218 dit555 <31> 3-153 funcnt <6:0> 3-175 dmadatasiz <9:8> 3-159 funoff <21:16> 3-175 dmanod <3:2> 3-159 fw_cap <4> 3-5 dmapad <31:0> 3-114 fxleft <15:0> 3-146 dr0 <31:0> 3-118 fxleft <15:0> 3-147 dr10 <23:0> 3-125 fxright <31:16> 3-148 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-128 gclkdiv <5:3> 3-23 | | decalckey <24> 3-212 fogcol <23:0> 3-142 decaldis <2> 3-215 fogen <26> 3-152 detparerr RO <31> 3-9 fogstart <23:0> 3-143 device <31:16> 3-10 fogxinc <23:0> 3-144 devseltim RO <26:25> 3-9 fogyinc <23:0> 3-145 dftmode <27> 3-208 forcol <31:0> 3-140 dirdatasiz <17:16> 3-159 fthres <28:21> 3-218 dit555 <31> 3-153 funcnt <6:0> 3-175 dmadatasiz <9:8> 3-159 funoff <21:16> 3-175 dmapad <31:0> 3-114 fxleft <15:0> 3-146 dr0 <31:0> 3-118 fxleft <15:0> 3-147 dr0_z32 <47:0> 3-115 fxright <15:0> 3-148 dr10 <23:0> 3-125 fxright <31:16> 3-146 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-128 gclkdiv <5:3> 3-23 gclkdiv <5:3> 3-23 dr14 <23:0> 3-128 gclkdiv <5:3> 3-23 | | decaldis <2> 3-215 fogen <26> 3-152 detparerr RO <31> 3-9 fogstart <23:0> 3-143 device <31:16> 3-10 fogxinc <23:0> 3-144 devseltim RO <26:25> 3-9 fogyinc <23:0> 3-145 dftmode <27> 3-208 forcol <31:0> 3-140 dirdatasiz <17:16> 3-159 fthres <28:21> 3-218 dit555 <31> 3-153 funcnt <6:0> 3-175 dmadatasiz <9:8> 3-159 funoff <21:16> 3-175 dmamod <3:2> 3-159 fw_cap <4> 3-5 dmapad <31:0> 3-114 fxleft <15:0> 3-146 dr0 <31:0> 3-118 fxleft <15:0> 3-147 dr0_z32 <47:0> 3-115 fxright <15:0> 3-148 dr10 <23:0> 3-125 fxright <31:16> 3-146 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-127 gclkdiv <5:3> 3-23 dr14 <23:0> 3-128 gclksel <1:0> 3-23 | | detparerr RO <31> 3-9 fogstart <23:0> 3-143 device <31:16> 3-10 fogxinc <23:0> 3-144 devseltim RO <26:25> 3-9 fogyinc <23:0> 3-145 dftmode <27> 3-208 forcol <31:0> 3-140 dirdatasiz <17:16> 3-159 fthres <28:21> 3-218 dit555 <31> 3-153 funcnt <6:0> 3-175 dmadatasiz <9:8> 3-159 funoff <21:16> 3-175 dmamod <3:2> 3-159 fw_cap <4> 3-5 dmapad <31:0> 3-114 fxleft <15:0> 3-146 dr0 <31:0> 3-118 fxleft <15:0> 3-147 dr0_z32 <47:0> 3-115 fxright <31:16> 3-148 dr10 <23:0> 3-125 fxright <31:16> 3-146 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-127 gclkdiv <5:3> 3-23 dr14 <23:0> 3-128 gclksel <1:0> 3-23 | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | | dirdatasiz <17:16> 3-159 fthres <28:21> 3-218 dit555 <31> 3-153 funcnt <6:0> 3-175 dmadatasiz <9:8> 3-159 funoff <21:16> 3-175 dmamod <3:2> 3-159 fw_cap <4> 3-5 dmapad <31:0> 3-114 fxleft <15:0> 3-146 dr0 <31:0> 3-118 fxleft <15:0> 3-147 dr0_z32 <47:0> 3-115 fxright <15:0> 3-148 dr10 <23:0> 3-125 fxright <31:16> 3-146 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-127 gclkdiv <5:3> 3-23 dr14 <23:0> 3-128 gclksel <1:0> 3-23 | | dit555 <31> 3-153 funcnt <6:0> 3-175 dmadatasiz <9:8> 3-159 funoff <21:16> 3-175 dmamod <3:2> 3-159 fw_cap <4> 3-5 dmapad <31:0> 3-114 fxleft <15:0> 3-146 dr0 <31:0> 3-118 fxleft <15:0> 3-147 dr0_z32 <47:0> 3-115 fxright <15:0> 3-148 dr10 <23:0> 3-125 fxright <31:16> 3-146 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-127 gclkdiv <5:3> 3-23 dr14 <23:0> 3-128 gclksel <1:0> 3-23 | | dmadatasiz <9:8> 3-159 funoff <21:16> 3-175 dmamod <3:2> 3-159 fw_cap <4> 3-5 dmapad <31:0> 3-114 fxleft <15:0> 3-146 dr0 <31:0> 3-118 fxleft <15:0> 3-147 dr0_z32 <47:0> 3-115 fxright <15:0> 3-148 dr10 <23:0> 3-125 fxright <31:16> 3-146 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-127 gclkdiv <5:3> 3-23 dr14 <23:0> 3-128 gclksel <1:0> 3-23 | | dmamod <3:2> 3-159 fw_cap <4> 3-5 dmapad <31:0> 3-114 fxleft <15:0> 3-146 dr0 <31:0> 3-118 fxleft <15:0> 3-147 dr0_z32 <47:0> 3-115 fxright <15:0> 3-148 dr10 <23:0> 3-125 fxright <31:16> 3-146 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-127 gclkdiv <5:3> 3-23 dr14 <23:0> 3-128 gclksel <1:0> 3-23 | | dmapad <31:0> 3-114 fxleft <15:0> 3-146 dr0 <31:0> 3-118 fxleft <15:0> 3-147 dr0_z32 <47:0> 3-115 fxright <15:0> 3-148 dr10 <23:0> 3-125 fxright <31:16> 3-146 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-127 gclkdiv <5:3> 3-23 dr14 <23:0> 3-128 gclksel <1:0> 3-23 | | dr0 <31:0> 3-118 fxleft <15:0> 3-147 dr0_z32 <47:0> 3-115 fxright <15:0> 3-148 dr10 <23:0> 3-125 fxright <31:16> 3-146 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-127 gclkdiv <5:3> 3-23 dr14 <23:0> 3-128 gclksel <1:0> 3-23 | | dr0_z32 <47:0> 3-115 fxright <15:0> 3-148 dr10 <23:0> 3-125 fxright <31:16> 3-146 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-127 gclkdiv <5:3> 3-23 dr14 <23:0> 3-128 gclksel <1:0> 3-23 | | dr10 <23:0> 3-125 fxright <31:16> 3-146 dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-127 gclkdiv <5:3> 3-23 dr14 <23:0> 3-128 gclksel <1:0> 3-23 | | dr11 <23:0> 3-126 gclkdcyc <9:6> 3-23 dr12 <23:0> 3-127 gclkdiv <5:3> 3-23 dr14 <23:0> 3-128 gclksel <1:0> 3-23 | | dr12 <23:0> 3-127 gclkdiv <5:3> 3-23 dr14 <23:0> 3-128 gclksel <1:0> 3-23 | | dr14 <23:0> | | | | Gitte (25.0) | | dr2 <31:0> | | $dr2_z32 < 47:0>$ | | dr3 <31:0> | | dr3_z32 <47:0> | | dr4 <23:0> | | dr6 <23:0> | | dr7 <23:0> | | dr8 <23:0> | | dstblendf <7:4> | | dstmap <0> | | dualtex <7> | | dwgengsts RO <16> | | dwgsyncaddr <31:2> | | e2pbypclk WO<19> | | e2pbypcsn WO <17> | | e2pbypd WO<18> | | e2pbyp WO <20> | | e2pq RO <16> | | eepromwt <8> | | endprdmasts RO <17> | | enhmemacc <22> | | errorinit <31> | | Power Graphic (cont) | plnwrmsk <31:0> | 3-163 | |--------------------------|------------------------|-------| | , , | pm_cap_id <7:0> | | | maxlat RO <31:24> | pm_next_ptr <15:8> | | | mcldiv <15:13> | pm_version <18:16> | | | mclkbrd0 <3:0> | powerpc <31> | 3-20 | | mclkbrd1 <8:5> 3-157 | powerstate <1:0> | 3-26 | | mclkdcyc <19:16> 3-24 | prefetchable RO <3> | | | mclksel <11:10> | prefetchable RO <3> | 3-16 | | memconfig <12:10> 3-18 | prefetchable RO <3> | 3-17 | | memreset <15> | prefetchen <7> | 3-103 | | memspace R/W <1> 3-8 | primaddress <31:2> | 3-164 | | memspace ind RO <0> 3-15 | primend <31:2> | 3-165 | | memspace ind RO <0> | primod <1:0> | | | memspace ind RO <0> 3-17 | primptr <31:4> | 3-166 | | memwrien RO <4> | primptren1 <1> | 3-166 | | mga_data <31:0> | primsz <13:8> | 3-278 | | mga_index <13:2> | pwidth <1:0> | 3-152 | | mgabase1 <31:14> | ramtstdone RO <2> | 3-207 | | mgabase2 <31:25> | ramtsten <1> | 3-207 | | mgabase3 <31:23> | ramtstpass <20:3> | 3-207 | | minfilter <3:0> | rasmin <12:10> | 3-155 | | mingnt RO <23:16> | rate_cap <2:0> | 3-5 | | miscctl <31:24> | rate_cap_or WO <23:21> | 3-100 | | misr_en <28> | rawvbicapd <10> | 3-258 | | misr_rstn <30> | rcddelay <8:7> | 3-154 | | misr_shift <29> | rddelay <21> | 3-155 | | mod2clkp <18:16> 3-21 | recmastab R/W <29> | 3-9 | | modclkp <21:19> | rectargab R/W <28> | 3-9 | | mrsopcod <29:25> 3-158 | resparerr RO <6> | 3-8 | | nodither <30> | revision <7:0> | 3-7 | | nohireq <28> | rfh <14:9> | 3-219 | | noretry <29> | rfhcnt <20:15> | 3-19 | | offsetsel0 <2> | rfw <14:9> | | | offsetsel1 <2> | ringent RO <29:18> | 3-206 | | offsetsel2 <2> | ringenten <17> | 3-206 | | offsetsel3 <2> | ringoscbyp <16> | 3-206 | | opcod <3:0> | ringoscen <15> | 3-206 | | owalpha <22> 3-212 | rombase <31:16> | | | pagpxfer <1> | romen <0> | | | palsel <7:4> | rpdelay <15:14> | 3-155 | | patreg <63:0> | rpvaliden <24> | | | pattern <29> | rq <31:24> | | | pickiclr <2> 3-149 | rq_depth <28:24> | | | pickien <2> | rq_or WO <28:24> | | | pickpen RO <2> 3-188 | rrddelay <5:4> | | | pllsel <6> 3-18 | sba_cap <9> | 3-5 | | | | | | Power Graphic (cont) | specgxinc <23:0> 3-181 | |----------------------------|---------------------------| | . , , | specgyinc <23:0> 3-182 | | sba_enable <9> | specialcycle RO <3> 3-8 | | sbe <12> 3-173 | specrstart <23:0> 3-183 | | scanleft <0> | specrxinc <23:0> | | $sdxl < 1 > \dots 3-172$ | specryinc <23:0> 3-185 | | sdxr <5> | srcblendf <3:0> | | sdy <2> 3-172 | srcmap <0> | | sdydxl <0> | srcreg <127:0> 3-186 | | secaddress <31:2> | sref <7:0> | | secend <31:2> | sse <13> | | secmod <1:0> | stopcodec <5> | | sellin <31:29> | strans <30> | | seqdst0 <5:0> | strmfctl <23:22> 3-158 | | seqdst1 <11:6> | stylelen <22:16> | | seqdst2 <17:12> 3-260 | subpixen <16> | | seqdst3 <23:18> | subsysid <31:16> 3-30 | | seglen <25:24> | subsysvid <15:0> 3-30 | | seqoff <28> 3-261 | swflag R/W <31:28> | | serrenable RO <8> | swtmsk <23:16> 3-191 | | setup address <31:2> 3-170 | sysclkdis <2> | | setupagpxfer <1> 3-171 | syspllpdN <5> 3-18 | | setupend <31:2> | szfailop <8:6> | | setupmod <1:0> 3-170 | szpassop <11:9> 3-193 | | sfailop <5:3> | tablefog <8> 3-215 | | sgnzero <13> 3-134 | takey <25> 3-212 | | shftzero <14> | tamask <26> 3-212 | | sigsyserr RO <30> | tckey <15:0> | | sigtargab R/W <27> 3-9 | tckeyh <15:0> 3-227 | | slcvbicapd <11> 3-258 | tclkdiv <7:5> | | smode <2:0> | tclkdivrstn <8> | | smrdelay <24:23> 3-156 | tclksel <4:2> | | smsk <15:8> | texbordercol <31:0> 3-209 | | softextrst <1> | texorg <31:5> | | softrapen RO <0> 3-188 | texorg1 <31:5> | | softraphand <31:2> 3-176 | texorg2 <31:5> | | softrapiclr <0> | texorg3 <31:5> | | softrapien <0> 3-150 | texorg4 <31:5> | | softreset <0> | texorgacc <1> | | solid <11> | texorgmap <0> 3-221 | | spage <26:24> | tformat <3:0> | | specbstart <23:0> 3-177 | th <5:0> | | specbxinc <23:0> 3-178 | thmask <28:18> 3-219 | | specbyinc <23:0> 3-179 | tkmask <31:16> | | specen <6> | tkmaskh <31:16> | | specgstart <23:0> 3-180 | tlutload <29> | | Power Graphic (cont) | vincap0 <0> | |------------------------|---------------------------| | . , | vincap1 <0> | | tmodulate <29> | vincap2 <0> | | tmr0 <31:0> | vincap3 <0> | | tmr1 <31:0> | vincapd <9> | | tmr2 <31:0> | vinen <0> | | tmr3 <31:0> | vinfielddetd <8> | | tmr4 <31:0> | vinfimfixen <8> | | tmr5 <31:0> | vingenfbinv <9> | | tmr6 <31:0> | vingrabptr <15:14> 3-258 | | tmr7 <31:0> | vinhdsen <7> | | tmr8 <31:0> | vinheight <9:0> | | toggle <31> | vinintenf0 <5> 3-249 | | tpitch <18:16> | vinintenf1 <4> | | tpitchext <19:9> 3-211 | vinintenta <21> 3-250 | | tpitchlin <8> | vinintentb <22> | | trans <23:20> | vininttsel <23> | | transc <30> | vinpitch0 <11:3> | | tstmbist <0> | vinpitch1 <11:3> | | tstobs <0> | vinpitch2 <11:3> | | tw <5:0> | vinpitch3 <11:3> | | twmask <28:18> | vintaskdetd <13> | | type RO <2:1> | vinuyvyfmt <3> 3-249 | | type RO <2:1> 3-17 | vinvbcnt0 <5:0> | | type RO <2:1> | vinvbcnt1 <21:16> | | udfsup RO <22> | vinvdclkoe <19> | | us <14> | vinvdoe <18> | | uvoffseten <17> | vinvsynciclr <0> | | vbiaddr0 <24:0> 3-239 | vinvsyncien <0> | | vbiaddr1 <24:0> 3-240 | vinvsyncpen <0> | | vbicap0 <2:1> | vlineiclr <5> | | vbicap1 <2:1> | vlineien <5> | | vbicnt0 <13:8> | vlinepen RO <5> 3-188 | | vbicnt1 <29:24> 3-241 | vmimode <4> | | vbitasken <16> | vsyncpen RO <4> | | vcount <11:0> | vsyncsts RO <3> 3-188 | | vendor <15:0> | wagp <2> | | vgaioen <8> 3-18 | wagp <2> | | vgasnoop R/W <5> 3-8 | waitcycle RO <7> 3-8 | | vin2xen <17> | walucfgflag <15:8> | | vinaddr0 <24:0> 3-245 | walucfgflag1 <15:8> 3-264 | | vinaddr1 <24:0> | walustsflag <7:0> | | vinaddr2 <24:0> | walustsflag1 <7:0> | | vinaddr3 <24:0> | warpbfpath RO <20> 3-189 | | vinautoen <6> | wbrklefttop <16> 3-267 | | vinc2graben <20> 3-250 | wbrkrighttop <19> 3-267 | ### Power Graphic (cont) | ruhusul DO (10) | 2 100 | |--------------------|-------| | wbusy1 RO <19> | 3-189 | | wbusy RO <18> | 3-189 | | wcentersnap <18> | 3-267 | | weiclr <8> | 3-149 | | weiclr1 <11> | 3-149 | | wcien <8> | 3-150 | | wcien1 <11> | 3-150 | | wclkdcyc <29:26> | | | wclkdiv <25:23> | | | wclksel <21:20> | | | wcodeaddr <31:8> | 3-262 | | wcpen1 <11> | 3-189 | | wcpen RO <8> | 3-188 | | wfastcrop <17> | 3-267 | | wfipath RO <21> | 3-189 | | wfirsttag <26> | 3-261 | | wfopath RO <22> | 3-189 | | wGetMSB max <12:8> | 3-267 | | wGetMSBmin <4:0> | 3-267 | | wiaddr <31:3> | 3-268 | | wiaddr <31:3> | 3-269 | | wiclr <7> | 3-149 | | wiclr1 <10> | 3-149 | | wien <7> | 3-150 | | wien1 <10> | 3-150 | | wimemaddr < 7:0> | 3-273 | | wimemdata <31:0> | 3-274 | | wimemdata1 <31:0> | 3-275 | | wmaster <1> | 3-276 | | wmode <1:0> | 3-268 | | wmode <1:0> | 3-269 | | wpen1 <10> | 3-188 | | wpen RO <7> | 3-188 | | wprgflag <31:16> | 3-263 | | wprgflag1 <31:16> | 3-264 | | wrdelay <19:18> | 3-155 | | wsametag <27> | 3-261 | | wucode cache <0> | 3-276 | | wvrtxsz <5:0> | 3-278 | | x_end <15:0> | 3-280 | | x_off <3:0> | 3-175 | | x_start <15:0> | 3-281 | | | 3-279 | | y_end <31:16> | | | y_cnu \31.10/ | J-20U | | y_off <6:4> | 3-175 | |-----------------|-------| | y_start <31:16> | 3-281 | | ydst <22:0> | 3-283 | | ylin <15> | 3-162 | | yval <31:16> | 3-284 | | zmode <10:8> | 3-133 | | zorg <31:2> | 3-286 | | zorgacc <1> | 3-286 | | zorgmap <0> | 3-286 | | zwidth <4:3> | 3-152 | | VGA Mode Register Fields | field1 <7:6> 3-288 | 8 | |-------------------------------------------------------|------------------------|---| | <b>G</b> | field2 <5:4> | 8 | | addwrap <5> | field3 <3:2> | 8 | | asyncrst <0> | funsel <4:3> | 9 | | atcgrmode <0> 3-292 | gcgrmode <0> | 3 | | attradsel <7> | gcoddevmd <4> 3-351 | | | attrd <15:8> | gctld <15:8> | | | attrx <4:0> | gctlx <3:0> | | | attrx <4:0> | hblkend <4:0> 3-304 | | | blinken <3> | hblkend <6> 3-334 | | | bytepan <6:5> | hblkend <7> | | | cacheflush <7:0> | hblkstr <1> | | | chain4 <3> | hblkstr <7:0> | | | chainodd even <1> | hdispend <7:0> | | | clksel <3:2> | hdispskew <6:5> 3-304 | | | cms <0> | hiprilvl <2:0> | | | colcompen <3:0> | hpelcnt <3:0> | | | colplen <3:0> | hpgoddev <5> | | | colsel54 <1:0> | hretrace <0> | | | colsel76 <3:2> | hrsten <3> | | | conv2t4 <7> | hsyncdel <6:5> | | | count2 <3> | hsyncend <4:0> | | | count4 <5> | hsyncoff <4> | | | cpudata <7:0> | hsyncpol <6> | | | crtcd <15:8> | hsyncsel <2> | | | crtcextd <15:8> | hsyncstr <2> | | | crtcextx <2:0> | hsyncstr <7:0> | | | crtcintcrt <7> | htotal <0> | | | crtcprotect <7> | htotal <7:0> | | | crtcrstN <7> | hvidmid <7:0> | | | crtcx <5:0> | interlace <7> | | | csyncen <6> | ioaddsel <0> | | | curloc <7:0> | lgren <2> | | | curloc <7:0> | linecomp <4> | | | curoff <5> | linecomp <6> | | | currowend <4:0> | linecomp <7:0> | | | currowstr <4:0> | linecomp <7> | | | curskew <6:5> | mapasel <5, 3:2> 3-364 | | | diag <5:4> | mapbsel <4, 1:0> | | | dotclkrt <3> | maxhipri <6:4> | | | dotmode <0> | maxscan <4:0> | | | dsts <1:0> | memmapsl <3:2> | | | dword <6> | memsz256 <1> | | | featcb0 <0> | mgamode <7> | | | featcb1 <1> | mode256 <6> | | | featin10 <6:5> | mono <1> | | | 10000110 (0.07 1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1. | 1110110 (17 3 2)1 | _ | | VGA (cont) | | |----------------|-------| | offset <5:4> | 3-333 | | offset <7:0> | 3-320 | | ovscol <7:0> | 3-294 | | p5p4 <7> | 3-293 | | page <7:0> | 3-338 | | page8 <4> | 3-342 | | palet0-F <5:0> | 3-291 | | pancomp <5> | 3-293 | | pas <5> | 3-290 | | pas <5> | 3-331 | | pelwidth <6> | 3-293 | | plwren <3:0> | 3-363 | | prowscan <4:0> | 3-309 | | rammapen <1> | 3-358 | | rdmapsl <1:0> | 3-350 | | rdmode <3> | 3-351 | | refcol <3:0> | 3-348 | | rot <2:0> | 3-349 | | scale <2:0> | 3-336 | | scroff <5> | 3-362 | | sel5rfs <6> | 3-318 | | selrowscan <1> | 3-327 | | seqd <15:8> | 3-360 | | seqoddevmd <2> | 3-365 | | setrst <3:0> | 3-346 | | setrsten <3:0> | 3-347 | | shftldrt <2> | 3-362 | | shiftfour <4> | 3-362 | | slow256 <5> | 3-336 | | srintmd <5> | 3-351 | | startadd <0> | 3-342 | | startadd <3:0> | 3-333 | | startadd <7:0> | 3-313 | | startadd <7:0> | 3-314 | | switchsns <4> | 3-356 | | syncrst <1> | 3-361 | | undrow <4:0> | 3-321 | | vblkend <7:0> | 3-323 | | vblkstr <3> | 3-308 | | vblkstr <4:3> | 3-335 | | vblkstr <5> | 3-310 | | vblkstr <7:0> | 3-322 | | vdispend <1> | 3-308 | | vdispend <2> | 3-335 | | vdispend <6> | 3-308 | |----------------|-------| | vdispend <7:0> | 3-319 | | videodis <4> | 3-358 | | vidstmx <5:4> | 3-295 | | vintclr <4> | 3-318 | | vinten <5> | 3-318 | | vretrace <3> | 3-357 | | vrsten <7> | 3-334 | | vsyncend <3:0> | 3-318 | | vsyncoff <5> | 3-334 | | vsyncpol <7> | 3-359 | | vsyncstr <2> | 3-308 | | vsyncstr <6:5> | 3-335 | | vsyncstr <7:0> | 3-317 | | vsyncstr <7> | 3-308 | | vtotal <0> | 3-308 | | vtotal <1:0> | 3-335 | | vtotal <5> | 3-308 | | vtotal <7:0> | 3-307 | | wbmode <6> | 3-327 | | winfreq <5:7> | 3-341 | | winsize <1:3> | 3-341 | | wrmask <7:0> | | | wrmode <1:0> | | | | | ### **DAC Register Fields** | 1.1 4. | 2 200 | |-------------------------------------------------|-------| | alphaen <1> | 3-388 | | bcomp RO<0> | | | colkey <7:0> | | | colkey0 <7:0> | | | colkeyen0 <0> | 3-391 | | colmsk <7:0> | 3-378 | | colmsk0 <7:0> | 3-379 | | crcdata <7:0> | 3-381 | | crcdata <7:0> | 3-382 | | crcsel <4:0> | 3-380 | | curadrh <5:0> | 3-383 | | curadrl <7:0> | 3-384 | | curcol <7:0> | 3-385 | | curmode <2:0> | 3-386 | | curposx <11:0> | 3-368 | | curposy <27:16> | 3-368 | | dacbgen <5> | 3-407 | | dacbgpdN <4> | 3-407 | | dacpdN <0> | 3-393 | | ddcdata <3:0> | 3-390 | | ddcoe <3:0> | 3-389 | | depth <2:0> | 3-395 | | gcomp RO<1> | 3-402 | | hzoom <1:0> | 3-408 | | indd <7:0> | 3-373 | | iogsyncdis <5> | 3-388 | | mafcclkdel <3:0> | 3-392 | | mfcsel <2:1> | | | miscdata <6:4> | | | miscoe <6:4> | | | paldata <7:0> | | | palrdadd <7:0> | | | palwtadd <7:0> | | | panelctl <3:1> | | | panelsel <0> | 3-396 | | panhsoff <4> | 3-396 | | panhspol <6> | 3-396 | | panvsoff <5> | 3-396 | | panvspol <7> | 3-396 | | pedon <4> | 3-388 | | pixclkdis <2> | 3-397 | | <del>-</del> | 3-397 | | pixlock <6> | | | pixpllm <4:0> | | | L. L. M. C. | 2 270 | | pixplln <6:0> | 3-399 | |----------------|-------| | pixpllp <2:0> | 3-400 | | pixpllpdN<3> | 3-397 | | pixplls <4:3> | 3-400 | | pixrdmsk <7:0> | 3-372 | | ramcs <4> | 3-393 | | rcomp RO<2> | 3-402 | | sensepdN <7> | 3-402 | | syslock <6> | 3-406 | | syspllm <4:0> | 3-403 | | sysplln <6:0> | 3-404 | | syspllp <2:0> | 3-405 | | sysplls <4:3> | 3-405 | | vdoutsel <7:5> | 3-393 | | vga8dac <3> | 3-393 | ### **Notes** ### **Notes**