



# RAGE™ XL

## Register Reference Guide (OEM)

### Technical Reference Manual

P/N: RRG-C04300OEM Rev 0.08

© 1999 ATI Technologies Inc.

#### **CONFIDENTIAL MATERIAL**

All information contained in this manual is confidential material of ATI Technologies Inc. Unauthorized use or disclosure of the information contained herein is prohibited.

You may be held responsible for any loss or damage suffered by ATI for your unauthorized disclosure hereof, in whole or in part. Please exercise the following precautions:

- Store all hard copies in a secure place when not in use.
- Save all electronic copies on password protected systems.
- Do not reproduce or distribute any portions of this manual in paper or electronic form (except as permitted by ATI).
- Do not post this manual on any LAN or WAN (except as permitted by ATI).

Your protection of the information contained herein may be subject to periodic audit by ATI. This manual is subject to possible recall by ATI.

The information contained in this manual has been carefully checked and is believed to be entirely reliable. No responsibility is assumed for inaccuracies. ATI reserves the right to make changes at any time to improve design and supply the best product possible.

ATI, ***mach64***, **3D RAGE**, **RAGE THEATER**, and **RAGE 128** are trademarks of ATI Technologies Inc. All other trademarks and product names are properties of their respective owners.

## Record of Revisions

| Release | Date     | Description of Changes           |
|---------|----------|----------------------------------|
| 0.01    | Nov 1998 | Preliminary                      |
| 0.02    | Jan 1999 | Second revision                  |
| 0.03    | Feb 1999 | Customized version of rev 0.02   |
| 0.04    | Jun 99   | See Appendix A: Revision History |
| 0.05    | Aug 99   | See Appendix A: Revision History |
| 0.06    | Aug 99   | See Appendix A: Revision History |
| 0.07    | Aug 99   | See Appendix A: Revision History |
| 0.08    | Dec 99   | See Appendix A: Revision History |

## Related Manuals

### **RAGE XL series**

- RAGE™ XL Register Reference Guide  
(RRG-G04300)
- RAGE™ XL Graphics Controller  
Specifications (GCS-C04300)
- RAGE™ XL Design Guide  
(DRS-D04300)

**Preliminary**

# *Table of Contents*

---

## ***Chapter 1: Introduction***

|                                        |     |
|----------------------------------------|-----|
| 1.1 Scope .....                        | 1-1 |
| 1.2 Summary of the Contents .....      | 1-1 |
| 1.3 Notations and Conventions .....    | 1-2 |
| 1.3.1 Mnemonics.....                   | 1-2 |
| 1.3.2 Numeric Representations.....     | 1-2 |
| 1.3.3 Register Description Format..... | 1-3 |
| 1.3.4 Acronyms.....                    | 1-3 |

## ***Chapter 2: Overview and Memory Mapping***

|                                                |      |
|------------------------------------------------|------|
| 2.1 Register Classification.....               | 2-1  |
| 2.1.1 Setup and Control Registers.....         | 2-2  |
| 2.1.2 Accelerator CRTC and DAC Registers ..... | 2-2  |
| 2.1.3 Draw Engine Trajectory Registers .....   | 2-3  |
| 2.1.4 Draw Engine Control Registers.....       | 2-3  |
| 2.1.5 Bus Mastering Registers .....            | 2-4  |
| 2.1.6 AGP Registers.....                       | 2-4  |
| 2.1.7 LCD Panel Registers .....                | 2-4  |
| 2.1.8 PCI Configuration Space Registers .....  | 2-4  |
| 2.1.9 VGA Registers .....                      | 2-4  |
| 2.2 Memory Mapping .....                       | 2-5  |
| 2.2.1 Mapping Model.....                       | 2-6  |
| 2.2.2 Accessing Bytes, Words, and Dwords.....  | 2-7  |
| 2.2.3 Non-Intel Based Memory Mapping.....      | 2-8  |
| 2.3 Mapping Modes .....                        | 2-8  |
| 2.3.1 Linear Aperture Mapping .....            | 2-8  |
| 2.3.2 VGA Aperture Mapping .....               | 2-11 |
| 2.4 Determining Mapped Addresses .....         | 2-12 |
| 2.4.1 Memory Address .....                     | 2-12 |
| 2.4.2 I/O Base Address.....                    | 2-14 |
| 2.4.3 Absolute I/O Address .....               | 2-14 |

## **Chapter 3: Cross-Reference Tables**

|                                                        |      |
|--------------------------------------------------------|------|
| 3.1 Using the Tables .....                             | 3-1  |
| 3.1.1 Table Notations:.....                            | 3-1  |
| 3.2 Listings of Main Registers.....                    | 3-2  |
| 3.2.1 Registers listed by Offset Address .....         | 3-2  |
| 3.2.2 Registers listed by Mnemonic .....               | 3-9  |
| 3.3 Listings of Indexed Registers .....                | 3-15 |
| 3.3.1 PLL Registers Sorted by Address .....            | 3-15 |
| 3.3.2 PLL Registers Sorted by Mnemonic .....           | 3-16 |
| 3.3.3 LCD Panel Registers Sorted by Index Number ..... | 3-18 |
| 3.3.4 LCD Panel Registers Sorted by Mnemonic .....     | 3-20 |

## **Chapter 4: Display and Configuration**

|                                                                |      |
|----------------------------------------------------------------|------|
| 4.1 Setup and Control Registers .....                          | 4-1  |
| 4.1.1 General I/O Control Registers .....                      | 4-1  |
| 4.1.2 Scratch Pad Registers .....                              | 4-3  |
| 4.1.3 Bus Control Registers .....                              | 4-5  |
| 4.1.4 Memory Buffer Control Registers .....                    | 4-9  |
| 4.1.5 Power Management Mode Registers (for RAGE XL only) ..... | 4-12 |
| 4.1.6 Memory Control Registers .....                           | 4-17 |
| 4.1.7 Test and Debug .....                                     | 4-24 |
| 4.1.8 Configuration Registers.....                             | 4-32 |
| 4.1.9 Custom Macro Registers .....                             | 4-37 |
| 4.2 Accelerator CRTC and DAC Registers.....                    | 4-38 |
| 4.2.1 Accelerator CRTC Registers .....                         | 4-38 |
| 4.2.2 Shadowed and Second CRTC Registers .....                 | 4-38 |
| 4.2.3 Overscan Registers.....                                  | 4-58 |
| 4.2.4 Hardware Cursor Registers.....                           | 4-61 |
| 4.2.5 GenLocking (CRT-Sync to Video) Registers .....           | 4-64 |
| 4.2.6 Clock Control Registers .....                            | 4-67 |
| 4.2.7 PLL Control Registers.....                               | 4-68 |
| 4.2.8 DAC Control Registers .....                              | 4-94 |

## **Chapter 5: GUI Draw Engine**

|                                              |      |
|----------------------------------------------|------|
| 5.1 Draw Engine Trajectory Registers.....    | 5-1  |
| 5.1.1 Destination Trajectory Registers ..... | 5-1  |
| 5.1.2 Source Trajectory Registers.....       | 5-21 |
| 5.2 Draw Engine Control Registers .....      | 5-32 |

---

|       |                                               |      |
|-------|-----------------------------------------------|------|
| 5.2.1 | Host Data Registers .....                     | 5-32 |
| 5.2.2 | Pattern Registers .....                       | 5-34 |
| 5.2.3 | Scissors .....                                | 5-38 |
| 5.2.4 | Data Path Registers .....                     | 5-42 |
| 5.2.5 | Color Compare Registers .....                 | 5-60 |
| 5.2.6 | Command FIFO Registers .....                  | 5-62 |
| 5.2.7 | Draw Engine Composite Control Registers ..... | 5-65 |
| 5.2.8 | Draw Engine Status Registers .....            | 5-68 |

***Chapter 6: Host Interface***

|       |                                           |      |
|-------|-------------------------------------------|------|
| 6.1   | PCI Configuration Space Registers .....   | 6-1  |
| 6.2   | Bus Mastering Registers .....             | 6-11 |
| 6.2.1 | System Bus Mastering Registers .....      | 6-11 |
| 6.2.2 | Draw Engine Bus Mastering Registers ..... | 6-12 |
| 6.3   | AGP Registers .....                       | 6-15 |

***Chapter 7: VGA-Compatible Registers***

|     |                                                      |      |
|-----|------------------------------------------------------|------|
| 7.1 | VGA Compatible Registers Summary – By I/O Port ..... | 7-1  |
| 7.2 | VGA CRT Controller Registers .....                   | 7-5  |
| 7.3 | VGA Attribute Controller Registers .....             | 7-17 |
| 7.4 | General VGA Status and Configuration Registers ..... | 7-22 |
| 7.5 | VGA Sequencer Registers .....                        | 7-25 |
| 7.6 | VGA DAC Registers .....                              | 7-29 |
| 7.7 | VGA Graphics Controller Registers .....              | 7-30 |

***Chapter 8: LCD Panel***

|     |                                                    |      |
|-----|----------------------------------------------------|------|
| 8.1 | Index and Data Registers .....                     | 8-1  |
| 8.2 | Configuration and Timing Registers .....           | 8-3  |
| 8.3 | LCD General Control Registers .....                | 8-6  |
| 8.4 | Dual Scan Panel Control Registers .....            | 8-8  |
| 8.5 | Half Frame Buffer Registers .....                  | 8-10 |
| 8.6 | Horizontal and Vertical Stretching Registers ..... | 8-11 |
| 8.7 | LT_GPIO and ZVGPIO Registers .....                 | 8-14 |

## *Table of Contents*

---

|                                                        |      |
|--------------------------------------------------------|------|
| 8.8 Power Management Registers .....                   | 8-17 |
| 8.9 Hardware Icon Registers .....                      | 8-22 |
| 8.10 TMDS Registers .....                              | 8-26 |
| 8.10.1 TMDS Encoder Registers.....                     | 8-26 |
| 8.10.2 TMDS Testblock Registers .....                  | 8-28 |
| 8.10.3 TMDS Transmitter Macro Registers.....           | 8-31 |
| 8.11 APC Registers.....                                | 8-33 |
| 8.12 Video and Graphics Alpha Blending Registers ..... | 8-42 |

## ***Appendix A: Revision History***

|                                    |     |
|------------------------------------|-----|
| A.1 Revision 0.04 (Jun 1999).....  | A-1 |
| A.2 Revision 0.05 (Aug 1999) ..... | A-1 |
| A.3 Revision 0.06 (Aug 1999) ..... | A-1 |
| A.4 Revision 0.07 (Aug 1999) ..... | A-1 |
| A.5 Revision 0.08 (Dec 1999).....  | A-1 |

# *Chapter 1*

## *Introduction*

---

### **1.1 Scope**

This document is a reference guide for the registers used in the RAGE XL product.

### **1.2 Summary of the Contents**

The following table summarizes the chapters used in this document.

**Table 1-1 A Summary of the Chapters**

| <b>Chapter</b>   | <b>Description or Contents</b>                                                                                                                                                                                                                                             |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>Chapter 1</i> | An outline of the manual. Explains notations and conventions.                                                                                                                                                                                                              |
| <i>Chapter 2</i> | An overview of the registers. Describes the memory and I/O mapping.                                                                                                                                                                                                        |
| <i>Chapter 3</i> | A cross-reference summary of the registers. Two tables list the registers by register name (mnemonic) and by register address. To help quickly locate a specific register, both tables use a page number column. This column is hypertext linked for the on-line document. |
| <i>Chapter 4</i> | 2D accelerator registers<br>Setup and control registers<br>Accelerator CRTC and DAC registers                                                                                                                                                                              |
| <i>Chapter 5</i> | GUI engine registers                                                                                                                                                                                                                                                       |
| <i>Chapter 6</i> | Host interface registers<br>PCI configuration space registers<br>System bus mastering registers<br>Draw engine bus mastering registers<br>AGP registers                                                                                                                    |
| <i>Chapter 7</i> | VGA-compatible registers                                                                                                                                                                                                                                                   |
| <i>Chapter 8</i> | LCD panel registers                                                                                                                                                                                                                                                        |

## 1.3 Notations and Conventions

### 1.3.1 Mnemonics

Mnemonics are expressed in upper-case and are used throughout this document in place of hardware register names and field names. The naming conventions for registers and bit fields are as indicated below:

**Table 1-2 Explanation of the Mnemonic Nomenclature**

| Mnemonic Nomenclature        | Example and Explanation                                                                                                                                                                                             |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| REGISTER_MNEMONIC            | <b>CONFIG_CHIP_ID</b><br>The register mnemonic for the Configuration Chip ID register.                                                                                                                              |
| REGISTER_MNEMONIC[bit#:bit#] | <b>CONFIG_CHIP_ID[15:0]</b><br>[15:0] is the bit field that occupies bit positions 0 through 15 within the CONFIG_CHIP_ID register.                                                                                 |
| FIELD_NAME@REGISTER_MNEMONIC | <b>CFG_CHIP_TYPE@CONFIG_CHIP_ID</b><br>An alternative to the above mnemonic (CONFIG_CHIP_ID[15:0]).<br>Instead of providing the bit positions, this example gives the field name CFG_CHIP_TYPE (Product Type Code). |

### 1.3.2 Numeric Representations

- Hexadecimal numbers are appended with “h” whenever there is a risk of ambiguity. Other numbers are assumed to be in decimal.
- Several signals of identical function are sometimes described by a single expression in which the part of the signal name that differs is shown in parentheses [ ]. For example, the four Select signals—SEL0#, SEL1#, SEL2#, and SEL3#—are represented by the single expression SEL[0-3]#.

### 1.3.3 Register Description Format

All registers in this document are described in the same or similar format as shown by the self-explained sample below.



### 1.3.4 Acronyms

Standard acronyms or abbreviations used in the literature are presumed known and therefore freely used without any explanation. When in doubt, refer to the following table below. Less frequently used or ATI-specific acronyms will be accompanied by the full expression when it appears for the first time in the document.

Table 1-3

| Acronym | Full Expression             |
|---------|-----------------------------|
| AGP     | Accelerated Graphics Port   |
| AMC     | ATI Multimedia Channel      |
| BIOS    | basic input/output system   |
| bpp     | bits per pixel              |
| DAC     | digital-to-analog converter |
| EDO RAM | Extended Data Output RAM    |
| FIFO    | first in first out          |
| GUI     | graphical user interface    |

**Table 1-3 Cont'd**

| <b>Acronym</b>   | <b>Full Expression</b>                                                  |
|------------------|-------------------------------------------------------------------------|
| I <sup>2</sup> C | inter IC communication                                                  |
| I/O              | input/output                                                            |
| MPEG             | Motion Picture Experts Group                                            |
| MPP              | Multimedia Peripheral Port                                              |
| PCI              | Peripheral Component Interconnect                                       |
| PLL              | phase-locked loop                                                       |
| POST             | power-on self-test                                                      |
| RAMDAC           | RAM digital-to-analog converter                                         |
| RGB              | red-green-blue (may refer to a color encoding scheme or a video signal) |
| R/W              | read/write                                                              |
| SDRAM            | Synchronous DRAM                                                        |
| SGRAM            | Synchronous Graphics RAM                                                |
| VGA              | Video Graphics Array                                                    |
| YUV              | A color encoding scheme, no direct correspondence to the letters        |

# *Chapter 2*

## *Overview and Memory Mapping*

---

### **2.1 Register Classification**

For ease of discussion and reference, the registers are grouped into the following main classes according to their functionality:

- Setup and Control registers
- Accelerator CRTC and DAC registers
- GUI registers
- Bus Mastering registers
- AGP registers
- LCD Panel registers
- PCI Configuration Space registers
- VGA registers

These are general register classes only. There may be instances when specific bit fields of the same register may belong to a different class register. When this happens, it is noted in the register description.

Only registers in the first nine classes are tabulated in Chapter 3. To view the contents of the PCI and VGA registers, refer to Chapters 6 and 7 respectively.

The following is an overview of all the registers. Some classes are further divided into sub-groups.

## 2.1.1 Setup and Control Registers

These registers are memory mapped and aliased at an I/O address. Most of these registers are initialized only once at boot time. They are divided into the following sub-groups:

**Table 2-1 Sub-groups for the Setup and Control Register**

| Sub-group           | Purpose                                                                                                                                                                                |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| General I/O Control | Configuring the General Purpose I/O pins on the accelerator chip.                                                                                                                      |
| Scratch Pad         | General-purpose storage for the adapter ROM and for communicating the adapter ROM segment location to host applications. In test modes, these registers are used for chip diagnostics. |
| Bus Control         | Configuring the on-chip bus interface unit.                                                                                                                                            |
| Memory              | Configuring the memory interfaces.                                                                                                                                                     |
| Test and Debug      | Chip diagnostics and hardware debugging.                                                                                                                                               |
| Configuration       | Configuring the aperture and to read the current board configuration.                                                                                                                  |
| Custom Macros       | Setting up custom macros.                                                                                                                                                              |

## 2.1.2 Accelerator CRTC and DAC Registers

These registers are memory mapped and aliased at an I/O address. The accelerator CRTC registers are not the same as the VGA CRTC registers. They are divided into the following sub-groups:

**Table 2-2 Sub-groups for the Accelerator CRTC and DAC Registers**

| Sub-group             | Purpose                                      |
|-----------------------|----------------------------------------------|
| Overscan              | Configuring the overscan borders.            |
| Hardware Cursor       | Defining and moving the hardware cursor.     |
| Genlocking            | Synchronizing the CRT with the video source. |
| Clock Control and PLL | Configuring the pixel clock.                 |
| DAC Control           | Configuring the DAC.                         |

### 2.1.3 Draw Engine Trajectory Registers

These registers are memory mapped. They set up the source and destination trajectories and initiate draw operations. They are divided into the following sub-groups:

**Table 2-3 Sub-groups for the Draw Engine Trajectory Registers**

| Sub-group              | Purpose                                                                                                                                                 |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Destination Trajectory | Defining the region in which pixels are drawn. The region may be a line, a rectangular, or a trapezoidal area.                                          |
| Source Trajectory      | Defining a rectangular region from which pixel data is taken. The pixel data may be used as a monochrome or color pixel source, or a polygon fill mask. |

### 2.1.4 Draw Engine Control Registers

These registers are memory mapped. They set up the source pixel data, the draw engine data path, and the destination mixing logic. They are divided into the following sub-groups:

**Table 2-4 Sub-groups for the Draw Engine Control Registers**

| Sub-group                     | Purpose                                                        |
|-------------------------------|----------------------------------------------------------------|
| Host Data                     | Transferring data from the host to the draw engine.            |
| Pattern                       | Enabling and defining fixed patterns.                          |
| Scissor                       | Defining a draw region.                                        |
| Data Path                     | Configuring the data path and ALU.                             |
| Color Compare                 | Configuring the source or destination color compare.           |
| Command FIFO Status           | Reporting the status of the command FIFO.                      |
| Draw Engine Composite Control | Abbreviated composites of other draw engine control registers. |
| Draw Engine Status            | Reporting the current state of the draw engine.                |

## 2.1.5 Bus Mastering Registers

The *RAGE XL* provides full support for bus mastering to and from system memory. In other words, it is capable of reading system memory and transferring data to the frame buffer as well as writing frame buffer memory out to system memory. Bus mastering operations are invoked either through the bus master system table or via the GUI Draw Engine.

**Table 2-5 Sub-groups for the Bus Mastering Registers**

| Sub-group                 | Purpose                                                                                        |
|---------------------------|------------------------------------------------------------------------------------------------|
| Draw Engine Bus Mastering | Specifying register address/data for bus mastering operations invoked through the Draw Engine. |
| System Bus Mastering      | Controlling and determining the status of all the bus mastering operations.                    |

## 2.1.6 AGP Registers

These registers configure the Accelerated Graphic Port.

## 2.1.7 LCD Panel Registers

These registers configure the LCD panel.

## 2.1.8 PCI Configuration Space Registers

The PCI Configuration Space registers determine the host bus configuration during system reset. For the *RAGE XL*, the internal Host Bus interface has been optimized to support the PCI Version 2.1 bus configuration, providing full 32-bit memory and I/O operations.

## 2.1.9 VGA Registers

The VGA registers provide register-level compatibility with the IBM VGA display adapter. They and the accelerator registers are completely segregated from each other, and their functions are mutually exclusive.

Note that the ATI VGA extended registers, available with the *mach64 GX* family (through 1CEh to 1CFh), are no longer included in the *RAGE XL*.

## 2.2 Memory Mapping

The RAGE XL uses a fully memory mapped programming model. All registers (except DAC\_REGS, which is made up of a group of four 8-bit registers) are 32-bit wide and numbered from 0h to FFh. They are memory mapped into two 1K-blocks — block ‘0’ and block ‘1’, as shown in the figure below.



Aperture Base address can be located anywhere in the shaded region and is aligned to a multiple of 16MB.

**Figure 2-1 Typical Organization of Aperture Within Host Address Space (PC-compatible)**

## 2.2.1 Mapping Model

In terms of memory mapping locations, the registers can be grouped into six major categories. The table below summarizes the mapping of the register groups to memory and to the I/O space.

**Table 2-6 Register Groups by Memory Mapping**

| Register Group            | I/O Mapping        | Memory Mapping | Comments                                                                       |
|---------------------------|--------------------|----------------|--------------------------------------------------------------------------------|
| PCI configuration         | No                 | No             | Accessed with configuration cycles                                             |
| VGA                       | Yes                | No             | VGA standard addresses                                                         |
| Display and Configuration | 00h to 3Fh         | 0_00h to 0_3Fh | Same offset for I/O and memory                                                 |
| GUI                       | No                 | 0_40h to 0_FFh | Memory mapped only                                                             |
| Multimedia registers      | Some in 00h to 3Fh | 1_00h to 1_FFh | Some selected registers in I/O space, but different offsets for I/O and memory |
| PLL                       | 24h                | 0_24h          | Accessed indirectly through CLOCK_CNTL register                                |

- The PCI POS registers exist only in the PCI configuration space.
- VGA registers are mapped to the standard VGA addresses in the I/O space.
- The Accelerator registers (non-VGA) use apertures in both I/O and memory space. All accelerator registers are visible in the memory space, but only a subset is mapped to the I/O space.
- All 2D and 3D draw engine registers are memory mapped to Block ‘0’, with Dword offsets between 40h and FFh inclusive. These registers are written through a command FIFO and are read directly.
- The multimedia registers are memory mapped to Block ‘1’, with Dword offsets between 00h and FFh inclusive. Some selected multimedia registers also appear in the I/O space, but with different offsets for I/O and memory.
- The PLL registers are accessed indirectly through the CLOCK\_CNTL register.

Registers not associated with the 2D and 3D draw engines and multimedia are generally used for display and configuration purposes. These registers, numbered from 00h to 3Fh, can be directly readable and writable. In addition to being memory mapped, they are also mapped into a single continuous I/O block (referred to as “block” or “re-locatable” I/O) which starts at the I/O base address specified in the PCI Configuration registers. This allows the registers to be accessed at I/O addresses aliased to offsets from the base I/O

address. For block I/O, the I/O base address can be located anywhere within the 64K I/O space.

Note that Sparse I/O decoding is **not** supported by the RAGE XL.

## 2.2.2 Accessing Bytes, Words, and Dwords

The table below indicates which register groups may be accessed as bytes, words, or Dwords.

**Table 2-7 Register Accessing Sizes**

| Register Group          | Byte Addressing | Word Addressing | Dword Addressing |
|-------------------------|-----------------|-----------------|------------------|
| PCI POS registers       | Yes             | Yes             | Yes              |
| VGA registers           | Yes             | Note 1          | Note 1           |
| Display & Configuration | Yes             | Yes, note 2     | Yes, note 2      |
| GUI registers           | No              | No              | Yes              |
| Multimedia registers    | No, note 3      | No, note 3      | Yes              |
| PLL registers           | Yes             | No              | No               |

**Notes:**

1. If two or four VGA registers are continuous in the I/O space, 16 or 32 cycles may be used. The cycle will be broken up internally into 2 or 4 sequential cycles starting with the lowest address first.
2. The DAC\_REGS register is actually four 8-bit registers. Word or Dword cycles will be broken up internally into 2 or 4 sequential cycles starting with the lowest address first.
3. The multimedia registers that appear in I/O space are Dword-only registers. This means 32 bit IN or OUT operations must be used.
4. When trying to access only a byte or word of a 32 bit register, simply add 1, 2 or 3 to the absolute address calculated as shown earlier.
5. It is not recommended to perform word or Dword cycles that span a Dword boundary. This will not work correctly in all cases.

### 2.2.3 Non-Intel Based Memory Mapping

When incorporating the RAGE XL into a non-Intel platform (such as the Apple Power Macintosh), make sure the platform conforms to the PCI specification. For information on how to configure the RAGE XL in non-Intel environments, refer to Chapter 2 of the *mach64 Programmer's Guide*.

## 2.3 Mapping Modes

Depending on the system configuration, the RAGE XL operates in either of two selectable register mapping modes – Linear Aperture mode or VGA Aperture mode. The Linear Aperture mode is optimized for PCI configurations, while the VGA Aperture mode is used for backward compatibility to ISA-based systems. The Linear Aperture mode requires that the Linear Aperture be enabled, while the VGA aperture mode requires that the VGA portion of the chip be enabled. All registers are mapped relative to the top of the defined memory aperture.

### 2.3.1 Linear Aperture Mapping

In Linear Aperture mode, a large linear (primary) memory aperture and a small auxiliary register aperture are set up. The primary aperture size is fixed at 2x8 MB, and that of the auxiliary register aperture is 4 KB. The latter is used exclusively for register access (no mapping to the frame buffer) and is always enabled.

#### Primary Aperture

This aperture maps the entire frame buffer into the system memory address space. The memory mapped registers are optionally visible at the top of the first 8 MB of the primary linear aperture.

The aperture position is set by the system BIOS at configuration time through the Base Address registers in the PCI configuration space (see [Chapter 6](#)). The aperture size and position can also be read from the read-only [\*\*CONFIG\\_CNTL\*\*](#) register.

For the primary aperture, register Block '0' (CT-compatible block) is located in the top 1K of the first 8 MB, and register Block '1' (multimedia extensions) is 1K below Block '0'. The figure below shows the positions of register Block '0' and register Block '1' in a typical primary aperture configuration.



**Figure 2-2 Primary Linear Aperture Register Map**

The table below defines the register block offset within the linear aperture. “N/A” indicates that the registers are not visible with those settings. Reads or writes to those addresses will go to the frame buffer memory.

**Table 2-8 Register Block Offsets**

| BUS_APER_REG_DIS<br>@BUS_CNTL | BUS_EXT_REG_EN<br>@BUS_CNTL | Register Block 0<br>Offset | Register Block 1<br>Offset |
|-------------------------------|-----------------------------|----------------------------|----------------------------|
| 1                             | X                           | N/A                        | N/A                        |
| 0                             | 0                           | 7FFC00                     | N/A                        |
| 0                             | 1                           | 7FFC00                     | 7FF800                     |

## Auxiliary Aperture

The auxiliary register aperture is permanently enabled and available. All the registers in this aperture are mapped to the same offset as the primary linear register aperture (at the top of the first 8MB of the linear aperture). This aperture can be used in place of the primary aperture. The purpose of this auxiliary register aperture is to allow the primary aperture to be disabled to enable access to the frame buffer memory mapped behind the memory-mapped registers. In this way, the auxiliary and the primary apertures are independent of each other.

The memory map of the auxiliary aperture is shown in the figure below:



**Figure 2-3 Auxiliary Register Aperture Memory Map**

Note: In the auxiliary register aperture, the base of Block '1' is always at offset 0 and the base of Block '0' is always at offset 400h. The upper 2K of the aperture is reserved. This allows the register aperture to be 4K-aligned.

### 2.3.2 VGA Aperture Mapping

The VGA registers are completely segregated from the Accelerator registers. They provide compatibility with the IBM VGA Display Adapter. VGA apertures are 64K or 128K for standard VGA modes. VGA registers are I/O mapped only (with absolute addresses given in the descriptions in Chapter 9). They cannot be moved or configured.

The VGA aperture is fixed between A0000h and BFFFFh, and the VGA I/O space is fixed at these locations — 102h, 46E8h (and some aliases), 3C0h through 3CFh (except 3CBh and 3CDh), 3B4h and 3B5h for monochrome display or 3D4h and 3D5h for color display.

In VGA aperture mode, the upper 1KB (or 2KB) of the 128KB aperture is reserved for the controller register space. The Graphics Miscellaneous Register (a VGA register) has two bits (GRPH\_ADRSEL) that control which part of the VGA aperture is enabled. The register mapping can only occur when the entire 128KB aperture is enabled, or just the top 32KB is enabled. The other two cases do not include the area from BF800h to BFFFFh, and therefore can not map the registers.



**Figure 2-4 VGA Aperture Memory Map**

The following table indicates the various bits that must be set to enable register mapping

into the VGA aperture.

**Table 2-9 Mapping into the VGA Aperture**

| CFG_MEM_VGA_AP_EN<br>@CONFIG_CNTL | BUS_EXT_REG_EN<br>@BUS_CNTL | GRPH_ADRSEL<br>@GRA06 | Register Block<br>0 Base | Register<br>Block 1 Base |
|-----------------------------------|-----------------------------|-----------------------|--------------------------|--------------------------|
| 0                                 | X                           | XX                    | N/A                      | N/A                      |
| X                                 | X                           | 01 or 10              | N/A                      | N/A                      |
| 1                                 | 0                           | 00 or 11              | BFC00                    | N/A                      |
| 1                                 | 1                           | 00 or 11              | BFC00                    | BF800                    |

## 2.4 Determining Mapped Addresses

### 2.4.1 Memory Address

The notation for the block/Dword offset (see cross-reference tables in Chapter 3) is

**MM: block#\_offset**, where:

**MM** denotes memory mapped

**block#** identifies the block that the register belongs to (0 or 1)

**offset** identifies the register Dword offset *within* the associated block, in hexadecimal

For example, the OVERLAY\_SCALE\_CNTL register address, given by **MM: 1\_09**, indicates that this register is located in register Block ‘1’ (2K below the top of the graphics aperture) at Dword offset 9h. The Dword offset is converted to a byte offset by multiplying it by 4 (i.e., Dword offset 9h is byte offset 24h).

Note: For non-VGA registers, which are visible in both I/O and memory space, **MM** is replaced by **I/O**.

### Absolute Register Address

The memory mapped registers are visible at the top of the first 8MB of the linear aperture. With the base of the aperture located at 8 MB in memory, the absolute primary aperture register address is calculated using the formula:

$$\text{Absolute register address} = (\text{aperture\_base\_address}) + (\text{reg\_block\_offset}) + (\text{reg\_byte\_offset})$$

## Relative Register Address

The relative register address (to the base of the primary linear aperture) is calculated using the formula:

$$\text{Relative register address} = \text{register block offset} + \text{register byte offset}$$

For example, for register (OVERLAY\_SCALE\_CNTL):

```

aperture base address = 800000h
register block 1 offset = 7FF800h
register byte offset = 24h (4*Dword offset)
Absolute register address = FFF824h
Relative register address = 7FF824h

```

## Auxiliary Aperture Register Address

An auxiliary aperture register address is calculated by:

$$\text{auxiliary register address} = (\text{aperture\_base\_address}) + (\text{reg\_block\_offset}) + (\text{reg\_byte\_offset})$$

For example:

```

aperture base address = C00000h
register Block 1 offset = 0h
register byte offset = 24h (4*Dword offset)
Absolute register address = C00024h

```

## VGA Aperture Register Address

A VGA aperture register address is calculated by:

$$\text{Aperture register address} = (\text{register\_block\_base}) + (\text{reg\_byte\_offset})$$

For example:

register Block 1 base = BF800h  
register byte offset = 24h (4\*Dword offset)  
Absolute register address = BF824h

Note: All register offsets that are **not** preceded by a block number are assumed to be in Block ‘0’.

## 2.4.2 I/O Base Address

As mentioned earlier, all display and configuration registers not associated with the 2D/3D draw engines or multimedia are I/O mapped and have memory mapped register aliases.

To support block I/O register mapping, the RAGE XL requests a 256 byte I/O aperture, thus allowing 64 I/O mapped registers. The registers are mapped into this continuous block, starting at the I/O base address specified in the PCI configuration registers (summarized in [Chapter 6](#)).

Since the I/O base address may be different depending on the card configuration, it cannot be assumed to be of a specific value. The easiest way to obtain the I/O base address is to call the *mach64* BIOS function 12h (*see Appendix A - BIOS Services*, of the *mach64 Programmer’s Guide* for more information).

For block I/O, the I/O base address can be of any value within a 64KB I/O space. The value is decided by the system to insure that no conflicts exist and is in accord with the Plug and Play (PnP) specification. Refer to Chapter 2 of the *mach64 Programmer’s Guide* for more information on how to use this function call.

## 2.4.3 Absolute I/O Address

For display and configuration registers not associated with the 2D/3D draw engines or multimedia, the block I/O offset is given as the Dword offset (**Offset**) from the memory mapped register base address and the block I/O base address.

For block I/O, the equation for determining the Absolute I/O address is:

$$\text{Absolute I/O address} = (\text{Dword Offset} * 4) + \text{I/O base address}$$

Using SCRATCH\_REG1 as an example, the Dword offset is given by **Offset: 0\_21**. This indicates that the register is located in register Block ‘0’ at Dword offset 21h. The Dword offset is converted to a byte offset by multiplying by 4 (therefore, Dword offset 21h is byte offset 84h). If the I/O base address = E000h and the Dword offset = 21h, the physical I/O address will be E084h.

For some I/O registers, it is necessary to access individual bytes within the 32-bit register (for example, DAC\_REGS, which is actually four 8-bit registers). In those cases, the Dword offset should be converted to a byte offset before adding the individual byte offset (0, 1, 2, or 3).

As an example, the procedure to access the DAC\_MASK byte of DAC\_REGS is shown below.

```
byte offset = Dword Offset * 4 = 30h * 4 = C0h (DAC_REGS)
individual byte offset = 2 (DAC_MASK byte)
I/O base address = E000h
Absolute I/O address = byte offset + individual byte offset + I/O base address
                      = C0h + 2 + E000h = E0C2h
```

This page intentionally left blank.

# *Chapter 3*

## *Cross-Reference Tables*

---

### **3.1 Using the Tables**

This chapter comprises two main register summary tables, followed by six sub-tables. The two main tables list all but the PCI POS and the VGA Controller registers, which are covered in Chapters 6 and 7 respectively. The first table lists the registers by address while the second by mnemonic. The six sub-tables list the indexed PLL and LCD, with each group also sorted in two ways.

The tables in this chapter offer a convenient way to locate the full description of any of the registers contained in Chapters 4, 5 and 8, and some (excluding the PCI registers) contained in Chapter 6. If you are using the online version of this document, the page numbers are hypertext linked to the register descriptions.

#### **3.1.1 Table Notations:**

- A tick (✓) in the column under the heading *Block I/O* indicates that the register is aliased at an I/O address.
- The (h) in the *DWORD Offset* column heading indicates that numerals are in hex.
- *R/W* means read and write, *R* means read only, and *W* means write only.

## 3.2 Listings of Main Registers

### 3.2.1 Registers listed by Offset Address

Table 3-1 Registers Listed by Offset Address

| Registers by Address         |                        |            |           |                  |                      |
|------------------------------|------------------------|------------|-----------|------------------|----------------------|
| Register Class               | Mnemonic               | Read/Write | Block I/O | DWORD Offset (h) | Page                 |
| <b>Accelerator CRTC</b>      | CRTC2_H_TOTAL_DISP     | R/W        | ✓         | 0_00             | <a href="#">4-44</a> |
|                              | CRTC_H_TOTAL_DISP      | R/W        | ✓         | 0_00             | <a href="#">4-43</a> |
|                              | CRTC2_H_SYNC_STRT_WID  | R/W        | ✓         | 0_01             | <a href="#">4-45</a> |
|                              | CRTC_H_SYNC_STRT_WID   | R/W        | ✓         | 0_01             | <a href="#">4-44</a> |
|                              | CRTC2_V_TOTAL_DISP     | R/W        | ✓         | 0_02             | <a href="#">4-46</a> |
|                              | CRTC_V_TOTAL_DISP      | R/W        | ✓         | 0_02             | <a href="#">4-46</a> |
|                              | CRTC2_V_SYNC_STRT_WID  | R/W        | ✓         | 0_03             | <a href="#">4-47</a> |
|                              | CRTC_V_SYNC_STRT_WID   | R/W        | ✓         | 0_03             | <a href="#">4-47</a> |
|                              | CRTC2_VLINE_CRNT_VLINE | R/W        | ✓         | 0_04             | <a href="#">4-48</a> |
|                              | CRTC_VLINE_CRNT_VLINE  | R/W        | ✓         | 0_04             | <a href="#">4-48</a> |
|                              | CRTC_OFF_PITCH         | R/W        | ✓         | 0_05             | <a href="#">4-49</a> |
|                              | CRTC_INT_CNTL          | R/W        | ✓         | 0_06             | <a href="#">4-50</a> |
|                              | CRTC_GEN_CNTL          | R/W        | ✓         | 0_07             | <a href="#">4-54</a> |
| <b>Memory Buffer Control</b> | DSP_CONFIG             | R/W        | ✓         | 0_08             | <a href="#">4-9</a>  |
|                              | PM_DSP_CONFIG          | R/W        | ✓         | 0_08             | <a href="#">4-12</a> |
|                              | DSP_ON_OFF             | R/W        | ✓         | 0_09             | <a href="#">4-9</a>  |
|                              | PM_DSP_ON_OFF          | R/W        | ✓         | 0_09             | <a href="#">4-12</a> |
|                              | TIMER_CONFIG           | R/W        | ✓         | 0_0A             | <a href="#">4-10</a> |
|                              | MEM_BUF_CNTL           | R/W        | ✓         | 0_0B             | <a href="#">4-13</a> |
|                              | MEM_ADDR_CONFIG        | R/W        | ✓         | 0_0D             | <a href="#">4-15</a> |
| <b>Accelerator CRTC</b>      | CRT_TRAP               | R/W        | ✓         | 0_0E             | <a href="#">4-57</a> |
| <b>Overscan</b>              | OVR2_CLR               | R/W        | ✓         | 0_10             | <a href="#">4-59</a> |
|                              | OVR_CLR                | R/W        | ✓         | 0_10             | <a href="#">4-58</a> |
|                              | OVR2_WID_LEFT_RIGHT    | R/W        | ✓         | 0_11             | <a href="#">4-60</a> |
|                              | OVR_WID_LEFT_RIGHT     | R/W        | ✓         | 0_11             | <a href="#">4-59</a> |
|                              | OVR2_WID_TOP_BOTTOM    | R/W        | ✓         | 0_12             | <a href="#">4-60</a> |
|                              | OVR_WID_TOP_BOTTOM     | R/W        | ✓         | 0_12             | <a href="#">4-59</a> |

Table 3-1 Registers Listed by Offset Address

Cont'd

| Registers by Address                       |                     |            |           |                  |                      |
|--------------------------------------------|---------------------|------------|-----------|------------------|----------------------|
| Register Class                             | Mnemonic            | Read/Write | Block I/O | DWORD Offset (h) | Page                 |
| <i>Memory Buffer Control</i>               | PM_VGA_DSP_CONFIG \ | R/W        | ✓         | 0_13             | <a href="#">4-13</a> |
|                                            | PM_VGA_DSP_ON_OFF   | R/W        | ✓         | 0_14             | <a href="#">4-13</a> |
|                                            | DSP2_CONFIG         | R/W        | ✓         | 0_15             | <a href="#">4-9</a>  |
|                                            | DSP2_ON_OFF         | R/W        | ✓         | 0_16             | <a href="#">4-10</a> |
| <i>Accelerator CRTC</i>                    | CRTC2_OFF_PITCH     | R/W        | ✓         | 0_17             | <a href="#">4-50</a> |
| <i>Hardware Cursor</i>                     | CUR2_CLR0           | R/W        | ✓         | 0_18             | <a href="#">4-62</a> |
|                                            | CUR_CLR0            | R/W        | ✓         | 0_18             | <a href="#">4-61</a> |
|                                            | CUR2_CLR1           | R/W        | ✓         | 0_19             | <a href="#">4-63</a> |
|                                            | CUR_CLR1            | R/W        | ✓         | 0_19             | <a href="#">4-62</a> |
|                                            | CUR2_OFFSET         | R/W        | ✓         | 0_1A             | <a href="#">4-63</a> |
|                                            | CUR_OFFSET          | R/W        | ✓         | 0_1A             | <a href="#">4-61</a> |
|                                            | CUR2_HORZ_VERT_POSN | R/W        | ✓         | 0_1B             | <a href="#">4-63</a> |
|                                            | CUR_HORZ_VERT_POSN  | R/W        | ✓         | 0_1B             | <a href="#">4-61</a> |
|                                            | CUR2_HORZ_VERT_OFF  | R/W        | ✓         | 0_1C             | <a href="#">4-63</a> |
|                                            | CUR_HORZ_VERT_OFF   | R/W        | ✓         | 0_1C             | <a href="#">4-61</a> |
| <i>General I/O Control</i>                 | GP_IO               | R/W        | ✓         | 0_1E             | <a href="#">4-1</a>  |
| <i>Test and Debug</i>                      | HW_DEBUG            | R/W        | ✓         | 0_1F             | <a href="#">4-29</a> |
| <i>Scratch Pad and Test</i>                | SCRATCH_REG0        | R/W        | ✓         | 0_20             | <a href="#">4-3</a>  |
|                                            | SCRATCH_REG1        | R/W        | ✓         | 0_21             | <a href="#">4-4</a>  |
|                                            | SCRATCH_REG2        | R/W        | ✓         | 0_22             | <a href="#">4-4</a>  |
|                                            | SCRATCH_REG3        | R/W        | ✓         | 0_23             | <a href="#">4-5</a>  |
| <i>Clock Control</i>                       | CLOCK_CNTL          | R/W        | ✓         | 0_24             | <a href="#">4-67</a> |
| <i>Configuration</i>                       | CONFIG_STAT1        | R          | ✓         | 0_25             | <a href="#">4-35</a> |
|                                            | CONFIG_STAT2        | R          | ✓         | 0_26             | <a href="#">4-36</a> |
| <i>Bus Control</i>                         | BUS_CNTL            | R/W        | ✓         | 0_28             | <a href="#">4-5</a>  |
| <i>For related registers see Table 3-3</i> | LCD_INDEX           | R/W        | ✓         | 0_29             | <a href="#">8-1</a>  |
|                                            | LCD_DATA            | R/W        | ✓         | 0_2A             | <a href="#">8-2</a>  |
| <i>Memory Control</i>                      | EXT_MEM_CNTL        | R/W        | ✓         | 0_2B             | <a href="#">4-20</a> |
|                                            | MEM_CNTL            | R/W        | ✓         | 0_2C             | <a href="#">4-17</a> |
|                                            | MEM_VGA_WP_SEL      | R/W        | ✓         | 0_2D             | <a href="#">4-23</a> |
|                                            | MEM_VGA_RP_SEL      | R/W        | ✓         | 0_2E             | <a href="#">4-24</a> |

Table 3-1 Registers Listed by Offset Address

Cont'd

| Registers by Address  |                   |                |              |                     |                      |
|-----------------------|-------------------|----------------|--------------|---------------------|----------------------|
| Register Class        | Mnemonic          | Read/<br>Write | Block<br>I/O | DWORD<br>Offset (h) | Page                 |
| <i>DAC Control</i>    | DAC_REGS          | R/W            | ✓            | 0_30                | <a href="#">4-94</a> |
|                       | DAC_CNTL          | R/W            | ✓            | 0_31                | <a href="#">4-95</a> |
| <i>Test and Debug</i> | GEN_TEST_CNTL     | R/W            | ✓            | 0_34                | <a href="#">4-24</a> |
| <i>Custom Macros</i>  | CUSTOM_MACRO_CNTL | R/W            | ✓            | 0_35                | <a href="#">4-37</a> |
| <i>Configuration</i>  | CONFIG_CNTL       | R/W            | ✓            | 0_37                | <a href="#">4-32</a> |
|                       | CONFIG_CHIP_ID    | R              | ✓            | 0_38                | <a href="#">4-33</a> |
|                       | CONFIG_STAT0      | R/W            | ✓            | 0_39                | <a href="#">4-34</a> |
| <i>Test and Debug</i> | CRC_SIG           | R              | ✓            | 0_3A                | <a href="#">4-28</a> |
|                       | CRC2_SIG          | R              | ✓            | 0_3A                | <a href="#">4-28</a> |

Table 3-1 Registers Listed by Offset Address

Cont'd

| Registers by Address                          |                                                             |            |           |                  |                      |
|-----------------------------------------------|-------------------------------------------------------------|------------|-----------|------------------|----------------------|
| Register Class                                | Mnemonic                                                    | Read/Write | Block I/O | DWORD Offset (h) | Page                 |
| <i>Draw Engine<br/>Destination Trajectory</i> | DST_OFF_PITCH                                               | R/W        | -         | 0_40             | <a href="#">5-9</a>  |
|                                               | DST_X                                                       | R/W        | -         | 0_41             | <a href="#">5-11</a> |
|                                               | DST_Y                                                       | R/W        | -         | 0_42             | <a href="#">5-13</a> |
|                                               | DST_Y_X (aliased at 0_4Dh, 3D)                              | W          | -         | 0_43             | <a href="#">5-14</a> |
|                                               | DST_WIDTH                                                   | R/W        | -         | 0_44             | <a href="#">5-10</a> |
|                                               | DST_HEIGHT                                                  | R/W        | -         | 0_45             | <a href="#">5-8</a>  |
|                                               | DST_HEIGHT_WIDTH                                            | W          | -         | 0_46             | <a href="#">5-8</a>  |
|                                               | DST_X_WIDTH                                                 | W          | -         | 0_47             | <a href="#">5-12</a> |
|                                               | DST_BRES_LNTH<br>(LEAD_BRES_LNTH) (aliased at<br>0_51h, 3D) | R/W        | -         | 0_48             | <a href="#">5-3</a>  |
|                                               | DST_BRES_ERR                                                | R/W        | -         | 0_49             | <a href="#">5-2</a>  |
|                                               | DST_BRES_INC (LEAD_BRES_INC,<br>3D)                         | R/W        | -         | 0_4A             | <a href="#">5-3</a>  |
|                                               | DST_BRES_DEC (LEAD_BRES_DEC,<br>3D)                         | R/W        | -         | 0_4B             | <a href="#">5-1</a>  |
|                                               | DST_CNTL                                                    | R/W        | -         | 0_4C             | <a href="#">5-5</a>  |
|                                               | DST_Y_X (aliased at 0_43h, 3D)                              | W          | -         | 0_4D             | <a href="#">5-14</a> |
|                                               | TRAIL_BRES_ERR                                              | R/W        | -         | 0_4E             | <a href="#">5-15</a> |
|                                               | TRAIL_BRES_INC                                              | R/W        | -         | 0_4F             | <a href="#">5-15</a> |
|                                               | TRAIL_BRES_DEC                                              | R/W        | -         | 0_50             | <a href="#">5-15</a> |
|                                               | LEAD_BRES_LNTH (aliased at 0_48h,<br>3D)                    | R/W        | -         | 0_51             | <a href="#">5-3</a>  |
|                                               | Z_OFF_PITCH                                                 | R/W        | -         | 0_52             | <a href="#">5-16</a> |
|                                               | Z_CNTL                                                      | R/W        | -         | 0_53             | <a href="#">5-16</a> |
|                                               | ALPHA_TST_CNTL                                              | R/W        | -         | 0_54             | <a href="#">5-18</a> |

Table 3-1 Registers Listed by Offset Address

Cont'd

| Registers by Address                 |                    |            |           |                  |                      |
|--------------------------------------|--------------------|------------|-----------|------------------|----------------------|
| Register Class                       | Mnemonic           | Read/Write | Block I/O | DWORD Offset (h) | Page                 |
| <i>Draw Engine Source Trajectory</i> | SRC_OFF_PITCH      | R/W        | -         | 0_60             | <a href="#">5-26</a> |
|                                      | SRC_X              | R/W        | -         | 0_61             | <a href="#">5-28</a> |
|                                      | SRC_Y              | R/W        | -         | 0_62             | <a href="#">5-29</a> |
|                                      | SRC_Y_X            | W          | -         | 0_63             | <a href="#">5-31</a> |
|                                      | SRC_WIDTH1         | R/W        | -         | 0_64             | <a href="#">5-27</a> |
|                                      | SRC_HEIGHT1        | R/W        | -         | 0_65             | <a href="#">5-23</a> |
|                                      | SRC_HEIGHT1_WIDTH1 | W          | -         | 0_66             | <a href="#">5-24</a> |
|                                      | SRC_X_START        | R/W        | -         | 0_67             | <a href="#">5-29</a> |
|                                      | SRC_Y_START        | R/W        | -         | 0_68             | <a href="#">5-30</a> |
|                                      | SRC_Y_X_START      | W          | -         | 0_69             | <a href="#">5-31</a> |
|                                      | SRC_WIDTH2         | R/W        | -         | 0_6A             | <a href="#">5-27</a> |
|                                      | SRC_HEIGHT2        | R/W        | -         | 0_6B             | <a href="#">5-25</a> |
|                                      | SRC_HEIGHT2_WIDTH2 | W          | -         | 0_6C             | <a href="#">5-25</a> |
|                                      | SRC_CNTL           | R/W        | -         | 0_6D             | <a href="#">5-21</a> |
| <i>Host Data</i>                     | HOST_DATA[15:0]    | W          | -         | 0_80-8F          | <a href="#">5-32</a> |
|                                      | HOST_CNTL          | R/W        | -         | 0_90             | <a href="#">5-33</a> |
| <i>GUI Bus Mastering</i>             | BM_HOSTDATA        | W          | -         | 0_91             | <a href="#">6-12</a> |
|                                      | BM_ADDR            | W          | -         | 0_92             | <a href="#">6-13</a> |
|                                      | BM_DATA            | W          | -         | 0_92             | <a href="#">6-13</a> |
|                                      | BM_GUI_TABLE_CMD   | W          | -         | 0_93             | <a href="#">6-15</a> |
| <i>Pattern</i>                       | PAT_REG0           | R/W        | -         | 0_A0             | <a href="#">5-36</a> |
|                                      | PAT_REG1           | R/W        | -         | 0_A1             | <a href="#">5-37</a> |
|                                      | PAT_CNTL           | R/W        | -         | 0_A2             | <a href="#">5-37</a> |
| <i>Scissors</i>                      | SC_LEFT            | R/W        | -         | 0_A8             | <a href="#">5-38</a> |
|                                      | SC_RIGHT           | R/W        | -         | 0_A9             | <a href="#">5-39</a> |
|                                      | SC_LEFT_RIGHT      | W          | -         | 0_AA             | <a href="#">5-40</a> |
|                                      | SC_TOP             | R/W        | -         | 0_AB             | <a href="#">5-40</a> |
|                                      | SC_BOTTOM          | R/W        | -         | 0_AC             | <a href="#">5-41</a> |
|                                      | SC_TOP_BOTTOM      | W          | -         | 0_AD             | <a href="#">5-41</a> |

Table 3-1 Registers Listed by Offset Address

Cont'd

| Registers by Address                      |                          |            |           |                  |                      |
|-------------------------------------------|--------------------------|------------|-----------|------------------|----------------------|
| Register Class                            | Mnemonic                 | Read/Write | Block I/O | DWORD Offset (h) | Page                 |
| <i>Data Path</i>                          | USR1_DST_0FF_PITCH       | W          | -         | 0_AE             | <a href="#">5-52</a> |
|                                           | USR2_DST_0FF_PITCH       | W          | -         | 0_AF             | <a href="#">5-52</a> |
|                                           | DP_BKGD_CLR              | R/W        | -         | 0_B0             | <a href="#">5-42</a> |
|                                           | DP_FOG_CLR (DP_FRGD_CLR) | R/W        | -         | 0_B1             | <a href="#">5-43</a> |
|                                           | DP_WRITE_MSK             | R/W        | -         | 0_B2             | <a href="#">5-44</a> |
|                                           | DP_PIX_WIDTH             | R/W        | -         | 0_B4             | <a href="#">5-45</a> |
|                                           | DP_MIX                   | R/W        | -         | 0_B5             | <a href="#">5-50</a> |
|                                           | DP_SRC                   | R/W        | -         | 0_B6             | <a href="#">5-58</a> |
|                                           | DP_FRGD_CLR_MIX          | W          | -         | 0_B7             | <a href="#">5-44</a> |
| <i>Draw Engine Destination Trajectory</i> | DP_FRGD_BKGD_CLR         | W          | -         | 0_B8             | <a href="#">5-43</a> |
|                                           | DST_X_Y                  | W          | -         | 0_BA             | <a href="#">5-13</a> |
| <i>Data Path</i>                          | DST_WIDTH_HEIGHT         | W          | -         | 0_BB             | <a href="#">5-11</a> |
|                                           | USR_DST_PITCH            | W          | -         | 0_BC             | <a href="#">5-52</a> |
|                                           | DP_SET_GUI_ENGINE2       | W          | -         | 0_BE             | <a href="#">5-57</a> |
| <i>Color Compare</i>                      | DP_SET_GUI_ENGINE        | W          | -         | 0_BF             | <a href="#">5-53</a> |
|                                           | CLR_CMP_CLR              | R/W        | -         | 0_C0             | <a href="#">5-60</a> |
|                                           | CLR_CMP_MSK              | R/W        | -         | 0_C1             | <a href="#">5-60</a> |
| <i>Command FIFO</i>                       | CLR_CMP_CNTL             | R/W        | -         | 0_C2             | <a href="#">5-61</a> |
|                                           | FIFO_STAT                | R          | -         | 0_C4             | <a href="#">5-62</a> |
|                                           | GUI_TRAJ_CNTL            | R/W        | -         | 0_CC             | <a href="#">5-65</a> |
| <i>Engine Status/FIFO</i>                 | GUL_STAT                 | R          | -         | 0_CE             | <a href="#">5-68</a> |
| <i>Draw Engine Destination Trajectory</i> | COMPOSITE_SHADOW_ID      | R/W        | -         | 0_E6             | <a href="#">5-20</a> |
| <i>GenLocking</i>                         | SNAPSHOT_VH_COUNTS       | R          | -         | 1_1C             | <a href="#">4-64</a> |
|                                           | SNAPSHOT_F_COUNT         | R          | -         | 1_1D             | <a href="#">4-64</a> |
|                                           | N_VIF_COUNT              | R/W        | -         | 1_1E             | <a href="#">4-65</a> |
|                                           | SNAPSHOT_VIF_COUNT       | R/W        | -         | 1_1F             | <a href="#">4-66</a> |
| <i>GenLocking</i>                         | SNAPSHOT2_VH_COUNTS      | R          | -         | 1_2C             | <a href="#">4-66</a> |
|                                           | SNAPSHOT2_F_COUNT        | R          | -         | 1_2D             | <a href="#">4-65</a> |
|                                           | N_VIF2_COUNT             | R/W        | -         | 1_2E             | <a href="#">4-65</a> |
|                                           | SNAPSHOT2_VIF_COUNT      | R/W        | -         | 1_2F             | <a href="#">4-66</a> |
| <i>Test and Debug</i>                     | CRT_HORZ_VERT_LOAD       | R/W        | -         | 1_51             | <a href="#">4-31</a> |

Table 3-1 Registers Listed by Offset Address

Cont'd

| Registers by Address |                     |            |           |                  |                      |
|----------------------|---------------------|------------|-----------|------------------|----------------------|
| Register Class       | Mnemonic            | Read/Write | Block I/O | DWORD Offset (h) | Page                 |
| <i>AGP</i>           | AGP_BASE            | R/W        | -         | 1_52             | <a href="#">6-15</a> |
|                      | AGP_CNTL            | R/W        | -         | 1_53             | <a href="#">6-16</a> |
| <i>Command FIFO</i>  | GUI_CMDFIFO_DEBUG   | R/W        | -         | 1_5C             | <a href="#">5-63</a> |
|                      | GUI_CMDFIFO_DATA    | R/W        | -         | 1_5D             | <a href="#">5-64</a> |
|                      | GUI_CNTL            | R/W        | -         | 1_5E             | <a href="#">5-64</a> |
| <i>Bus Mastering</i> | BM_FRAME_BUF_OFFSET | R          | -         | 1_60             | <a href="#">6-11</a> |
|                      | BM_SYSTEM_MEM_ADDR  | R          | -         | 1_61             | <a href="#">6-11</a> |
|                      | BM_COMMAND          | R          | -         | 1_62             | <a href="#">6-11</a> |
|                      | BM_STATUS           | R          | -         | 1_63             | <a href="#">6-12</a> |
|                      | BM_GUI_TABLE        | R/W        | -         | 1_6E             | <a href="#">6-14</a> |
|                      | BM_SYSTEM_TABLE     | R/W        | -         | 1_6F             | <a href="#">6-12</a> |
| <i>TMDS</i>          | TMDS_CNTL           | R/W        | Index: 15 |                  | <a href="#">8-26</a> |
|                      | TMDS_SYNC_CHAR_SETA | R/W        | Index: 16 |                  | <a href="#">8-27</a> |
|                      | TMDS_SYNC_CHAR_SETB | R/W        | Index: 17 |                  | <a href="#">8-27</a> |
|                      | TMDS_CRC            | R          | Index: 18 |                  | <a href="#">8-27</a> |
|                      | PLTSTBLK_CNTL       | R/W        | Index: 19 |                  | <a href="#">8-28</a> |
|                      | SYNC_GEN_CNTL       | R/W        | -         | Index: 1A        | <a href="#">8-28</a> |
|                      | PATTERN_GEN_SEED    | R/W        | Index: 1B |                  | <a href="#">8-29</a> |
| <i>APC</i>           | APC_CNTL            | R/W        | -         | Index: 1C        | <a href="#">8-33</a> |
| <i>TMDS</i>          | PRI_ERR_PATTERN     | D          | Index: 1E |                  | <a href="#">8-29</a> |
|                      | CUR_ERR_PATTERN     | R          | Index: 1F |                  | <a href="#">8-29</a> |
|                      | PLTSTBLK_RPT        | R          | Index: 20 |                  | <a href="#">8-30</a> |
|                      | SYNC_RPT            | R          | -         | Index: 21        | <a href="#">8-30</a> |
|                      | CRC_PATTERN_RPT     | R          | -         | Index: 22        | <a href="#">8-30</a> |
|                      | PL_TRANSMITTER_CNTL | R/W        | Index: 23 |                  | <a href="#">8-31</a> |
|                      | PL_PLL_CNTL         | R/W        | Index: 24 |                  | <a href="#">8-31</a> |
|                      | TEST_IO             | R/W        | -         | Index: 28        | <a href="#">8-34</a> |

### 3.2.2 Registers listed by Mnemonic

Table 3-2 Registers Listed by Mnemonic

| Registers by Mnemonic                     |                     |            |           |                  |                      |
|-------------------------------------------|---------------------|------------|-----------|------------------|----------------------|
| Register Class                            | Mnemonic            | Read/Write | Block I/O | DWORD Offset (h) | Page                 |
| <i>AGP</i>                                | AGP_BASE            | R/W        | -         | 1_52             | <a href="#">6-15</a> |
|                                           | AGP_CNTL            | R/W        | -         | 1_53             | <a href="#">6-16</a> |
| <i>Draw Engine Destination Trajectory</i> | ALPHA_TST_CNTL      | R/W        | -         | 0_54             | <a href="#">5-18</a> |
| <i>APC</i>                                | APC_CNTL            | R/W        | -         | Index: 1C        | <a href="#">8-33</a> |
| <i>GUI Bus Mastering</i>                  | BM_ADDR             | W          | -         | 0_92             | <a href="#">6-13</a> |
| <i>Bus Mastering</i>                      | BM_COMMAND          | R          | -         | 1_62             | <a href="#">6-11</a> |
| <i>GUI Bus Mastering</i>                  | BM_DATA             | W          | -         | 0_92             | <a href="#">6-13</a> |
| <i>Bus Mastering</i>                      | BM_FRAME_BUF_OFFSET | R          | -         | 1_60             | <a href="#">6-11</a> |
|                                           | BM_GUI_TABLE        | R/W        | -         | 1_6E             | <a href="#">6-14</a> |
| <i>GUI Bus Mastering</i>                  | BM_GUI_TABLE_CMD    | W          | -         | 0_93             | <a href="#">6-15</a> |
|                                           | BM_HOSTDATA         | W          | -         | 0_91             | <a href="#">6-12</a> |
| <i>Bus Mastering</i>                      | BM_STATUS           | R          | -         | 1_63             | <a href="#">6-12</a> |
|                                           | BM_SYSTEM_MEM_ADDR  | R          | -         | 1_61             | <a href="#">6-11</a> |
|                                           | BM_SYSTEM_TABLE     | R/W        | -         | 1_6F             | <a href="#">6-12</a> |
| <i>Bus Control</i>                        | BUS_CNTL            | R/W        | ✓         | 0_28             | <a href="#">4-5</a>  |
| <i>Clock Control</i>                      | CLOCK_CNTL          | R/W        | ✓         | 0_24             | <a href="#">4-67</a> |
| <i>Color Compare</i>                      | CLR_CMP_CLR         | R/W        | -         | 0_C0             | <a href="#">5-60</a> |
|                                           | CLR_CMP_CNTL        | R/W        | -         | 0_C2             | <a href="#">5-61</a> |
|                                           | CLR_CMP_MSK         | R/W        | -         | 0_C1             | <a href="#">5-60</a> |
| <i>Draw Engine Destination Trajectory</i> | COMPOSITE_SHADOW_ID | R/W        | -         | 0_E6             | <a href="#">5-20</a> |
| <i>Configuration</i>                      | CONFIG_CHIP_ID      | R          | ✓         | 0_38             | <a href="#">4-33</a> |
|                                           | CONFIG_CNTL         | R/W        | ✓         | 0_37             | <a href="#">4-32</a> |
|                                           | CONFIG_STAT0        | R/W        | ✓         | 0_39             | <a href="#">4-34</a> |
|                                           | CONFIG_STAT1        | R          | ✓         | 0_25             | <a href="#">4-35</a> |
|                                           | CONFIG_STAT2        | R          | ✓         | 0_26             | <a href="#">4-36</a> |
| <i>Test and Debug</i>                     | CRC2_SIG            | R          | ✓         | 0_3A             | <a href="#">4-28</a> |
| <i>TMDS</i>                               | CRC_PATTERN_RPT     | R          | -         | Index: 22        | <a href="#">8-30</a> |
| <i>Test and Debug</i>                     | CRC_SIG             | R          | ✓         | 0_3A             | <a href="#">4-28</a> |

Table 3-2 Registers Listed by Mnemonic

Cont'd

| Registers by Mnemonic   |                        |            |           |                  |                      |
|-------------------------|------------------------|------------|-----------|------------------|----------------------|
| Register Class          | Mnemonic               | Read/Write | Block I/O | DWORD Offset (h) | Page                 |
| <i>Test and Debug</i>   | CRT_HORIZ_VERT_LOAD    | R/W        | -         | 1_51             | <a href="#">4-31</a> |
|                         | CRT_TRAP               | R/W        | ✓         | 0_0E             | <a href="#">4-57</a> |
|                         | CRTC2_H_SYNC_STRT_WID  | R/W        | ✓         | 0_01             | <a href="#">4-45</a> |
|                         | CRTC2_H_TOTAL_DISP     | R/W        | ✓         | 0_00             | <a href="#">4-44</a> |
|                         | CRTC2_OFF_PITCH        | R/W        | ✓         | 0_17             | <a href="#">4-50</a> |
|                         | CRTC2_V_SYNC_STRT_WID  | R/W        | ✓         | 0_03             | <a href="#">4-47</a> |
|                         | CRTC2_V_TOTAL_DISP     | R/W        | ✓         | 0_02             | <a href="#">4-46</a> |
|                         | CRTC2_VLINE_CRNT_VLINE | R/W        | ✓         | 0_04             | <a href="#">4-48</a> |
|                         | CRTC_GEN_CNTL          | R/W        | ✓         | 0_07             | <a href="#">4-54</a> |
|                         | CRTC_H_SYNC_STRT_WID   | R/W        | ✓         | 0_01             | <a href="#">4-44</a> |
|                         | CRTC_H_TOTAL_DISP      | R/W        | ✓         | 0_00             | <a href="#">4-43</a> |
|                         | CRTC_INT_CNTL          | R/W        | ✓         | 0_06             | <a href="#">4-50</a> |
|                         | CRTC_OFF_PITCH         | R/W        | ✓         | 0_05             | <a href="#">4-49</a> |
|                         | CRTC_V_SYNC_STRT_WID   | R/W        | ✓         | 0_03             | <a href="#">4-47</a> |
| <i>Accelerator CRTC</i> | CRTC_V_TOTAL_DISP      | R/W        | ✓         | 0_02             | <a href="#">4-46</a> |
|                         | CRTC_VLINE_CRNT_VLINE  | R/W        | ✓         | 0_04             | <a href="#">4-48</a> |
|                         | CUR2_CLR0              | R/W        | ✓         | 0_18             | <a href="#">4-62</a> |
|                         | CUR2_CLR1              | R/W        | ✓         | 0_19             | <a href="#">4-63</a> |
|                         | CUR2_HORIZ_VERT_OFF    | R/W        | ✓         | 0_1C             | <a href="#">4-63</a> |
|                         | CUR2_HORIZ_VERT_POSN   | R/W        | ✓         | 0_1B             | <a href="#">4-63</a> |
|                         | CUR2_OFFSET            | R/W        | ✓         | 0_1A             | <a href="#">4-63</a> |
|                         | CUR_CLR0               | R/W        | ✓         | 0_18             | <a href="#">4-61</a> |
|                         | CUR_CLR1               | R/W        | ✓         | 0_19             | <a href="#">4-62</a> |
| <i>TMDS</i>             | CUR_ERR_PATTERN        | R          | Index: 1F |                  | <a href="#">8-29</a> |
| <i>Hardware Cursor</i>  | CUR_HORIZ_VERT_OFF     | R/W        | ✓         | 0_1C             | <a href="#">4-61</a> |
|                         | CUR_HORIZ_VERT_POSN    | R/W        | ✓         | 0_1B             | <a href="#">4-61</a> |
|                         | CUR_OFFSET             | R/W        | ✓         | 0_1A             | <a href="#">4-61</a> |
| <i>Custom Macros</i>    | CUSTOM_MACRO_CNTL      | R/W        | ✓         | 0_35             | <a href="#">4-37</a> |
| <i>DAC Control</i>      | DAC_CNTL               | R/W        | ✓         | 0_31             | <a href="#">4-95</a> |
|                         | DAC_REGS               | R/W        | ✓         | 0_30             | <a href="#">4-94</a> |

Table 3-2 Registers Listed by Mnemonic

Cont'd

| Registers by Mnemonic                     |                                                       |            |           |                  |                      |
|-------------------------------------------|-------------------------------------------------------|------------|-----------|------------------|----------------------|
| Register Class                            | Mnemonic                                              | Read/Write | Block I/O | DWORD Offset (h) | Page                 |
| <i>Data Path</i>                          | DP_BKGD_CLR                                           | R/W        | -         | 0_B0             | <a href="#">5-42</a> |
|                                           | DP_FOG_CLR (DP_FRGD_CLR)                              | R/W        | -         | 0_B1             | <a href="#">5-43</a> |
|                                           | DP_FRGD_BKGD_CLR                                      | W          | -         | 0_B8             | <a href="#">5-43</a> |
|                                           | DP_FRGD_CLR_MIX                                       | W          | -         | 0_B7             | <a href="#">5-44</a> |
|                                           | DP_MIX                                                | R/W        | -         | 0_B5             | <a href="#">5-50</a> |
|                                           | DP_PIX_WIDTH                                          | R/W        | -         | 0_B4             | <a href="#">5-45</a> |
|                                           | DP_SET_GUI_ENGINE                                     | W          | -         | 0_BF             | <a href="#">5-53</a> |
|                                           | DP_SET_GUI_ENGINE2                                    | W          | -         | 0_BE             | <a href="#">5-57</a> |
|                                           | DP_SRC                                                | R/W        | -         | 0_B6             | <a href="#">5-58</a> |
| <i>Memory Buffer Control</i>              | DP_WRITE_MSK                                          | R/W        | -         | 0_B2             | <a href="#">5-44</a> |
|                                           | DSP2_CONFIG                                           | R/W        | ✓         | 0_15             | <a href="#">4-9</a>  |
|                                           | DSP2_ON_OFF                                           | R/W        | ✓         | 0_16             | <a href="#">4-10</a> |
|                                           | DSP_CONFIG                                            | R/W        | ✓         | 0_08             | <a href="#">4-9</a>  |
| <i>Draw Engine Destination Trajectory</i> | DSP_ON_OFF                                            | R/W        | ✓         | 0_09             | <a href="#">4-9</a>  |
|                                           | DST_BRES_DEC (LEAD_BRES_DEC, 3D)                      | R/W        | -         | 0_4B             | <a href="#">5-1</a>  |
|                                           | DST_BRES_ERR                                          | R/W        | -         | 0_49             | <a href="#">5-2</a>  |
|                                           | DST_BRES_INC (LEAD_BRES_INC, 3D)                      | R/W        | -         | 0_4A             | <a href="#">5-3</a>  |
|                                           | DST_BRES_LNTH (LEAD_BRES_LNTH) (aliased at 0_51h, 3D) | R/W        | -         | 0_48             | <a href="#">5-3</a>  |
|                                           | DST_CNTL                                              | R/W        | -         | 0_4C             | <a href="#">5-5</a>  |
|                                           | DST_HEIGHT                                            | R/W        | -         | 0_45             | <a href="#">5-8</a>  |
|                                           | DST_HEIGHT_WIDTH                                      | W          | -         | 0_46             | <a href="#">5-8</a>  |
|                                           | DST_OFF_PITCH                                         | R/W        | -         | 0_40             | <a href="#">5-9</a>  |
|                                           | DST_WIDTH                                             | R/W        | -         | 0_44             | <a href="#">5-10</a> |
|                                           | DST_WIDTH_HEIGHT                                      | W          | -         | 0_BB             | <a href="#">5-11</a> |
|                                           | DST_X                                                 | R/W        | -         | 0_41             | <a href="#">5-11</a> |
|                                           | DST_X_WIDTH                                           | W          | -         | 0_47             | <a href="#">5-12</a> |
|                                           | DST_X_Y                                               | W          | -         | 0_BA             | <a href="#">5-13</a> |
|                                           | DST_Y                                                 | R/W        | -         | 0_42             | <a href="#">5-13</a> |
| <i>DST_Y_X (aliased at 0_43h, 3D)</i>     | DST_Y_X (aliased at 0_43h, 3D)                        | W          | -         | 0_4D             | <a href="#">5-14</a> |
|                                           | DST_Y_X (aliased at 0_4Dh, 3D)                        | W          | -         | 0_43             | <a href="#">5-14</a> |

Table 3-2 Registers Listed by Mnemonic

Cont'd

| Registers by Mnemonic                          |                                          |            |           |                  |                      |
|------------------------------------------------|------------------------------------------|------------|-----------|------------------|----------------------|
| Register Class                                 | Mnemonic                                 | Read/Write | Block I/O | DWORD Offset (h) | Page                 |
| <i>Memory Control</i>                          | EXT_MEM_CNTL                             | R/W        | ✓         | 0_2B             | <a href="#">4-20</a> |
| <i>Command FIFO</i>                            | FIFO_STAT                                | R          | -         | 0_C4             | <a href="#">5-62</a> |
| <i>Test and Debug</i>                          | GEN_TEST_CNTL                            | R/W        | ✓         | 0_34             | <a href="#">4-24</a> |
| <i>General I/O Control</i>                     | GP_IO                                    | R/W        | ✓         | 0_1E             | <a href="#">4-1</a>  |
| <i>Command FIFO</i>                            | GUI_CMDFIFO_DATA                         | R/W        | -         | 1_5D             | <a href="#">5-64</a> |
|                                                | GUI_CMDFIFO_DEBUG                        | R/W        | -         | 1_5C             | <a href="#">5-63</a> |
|                                                | GUI_CNTL                                 | R/W        | -         | 1_5E             | <a href="#">5-64</a> |
| <i>Engine Status/FIFO</i>                      | GUI_STAT                                 | R          | -         | 0_CE             | <a href="#">5-68</a> |
| <i>Engine Control</i>                          | GUI_TRAJ_CNTL                            | R/W        | -         | 0_CC             | <a href="#">5-65</a> |
| <i>Host Data</i>                               | HOST_CNTL                                | R/W        | -         | 0_90             | <a href="#">5-33</a> |
|                                                | HOST_DATA[15:0]                          | W          | -         | 0_80-8F          | <a href="#">5-32</a> |
| <i>Test and Debug</i>                          | HW_DEBUG                                 | R/W        | ✓         | 0_1F             | <a href="#">4-29</a> |
| <i>For related registers<br/>see Table 3-3</i> | LCD_DATA                                 | R/W        | ✓         | 0_2A             | <a href="#">8-2</a>  |
|                                                | LCD_INDEX                                | R/W        | ✓         | 0_29             | <a href="#">8-1</a>  |
| <i>Draw Engine<br/>Destination Trajectory</i>  | LEAD_BRES_LNTH (aliased at 0_48h,<br>3D) | R/W        | -         | 0_51             | <a href="#">5-3</a>  |
| <i>Memory Buffer<br/>Control</i>               | MEM_ADDR_CONFIG                          | R/W        | ✓         | 0_0D             | <a href="#">4-15</a> |
|                                                | MEM_BUF_CNTL                             | R/W        | ✓         | 0_0B             | <a href="#">4-13</a> |
| <i>Memory Control</i>                          | MEM_CNTL                                 | R/W        | ✓         | 0_2C             | <a href="#">4-17</a> |
|                                                | MEM_VGA_RP_SEL                           | R/W        | ✓         | 0_2E             | <a href="#">4-24</a> |
|                                                | MEM_VGA_WP_SEL                           | R/W        | ✓         | 0_2D             | <a href="#">4-23</a> |
| <i>GenLocking</i>                              | N_VIF2_COUNT                             | R/W        | -         | 1_2E             | <a href="#">4-65</a> |
|                                                | N_VIF_COUNT                              | R/W        | -         | 1_1E             | <a href="#">4-65</a> |
| <i>Overscan</i>                                | OVR2_CLR                                 | R/W        | ✓         | 0_10             | <a href="#">4-59</a> |
|                                                | OVR2_WID_LEFT_RIGHT                      | R/W        | ✓         | 0_11             | <a href="#">4-60</a> |
|                                                | OVR2_WID_TOP_BOTTOM                      | R/W        | ✓         | 0_12             | <a href="#">4-60</a> |
|                                                | OVR_CLR                                  | R/W        | ✓         | 0_10             | <a href="#">4-58</a> |
|                                                | OVR_WID_LEFT_RIGHT                       | R/W        | ✓         | 0_11             | <a href="#">4-59</a> |
|                                                | OVR_WID_TOP_BOTTOM                       | R/W        | ✓         | 0_12             | <a href="#">4-59</a> |
| <i>Pattern</i>                                 | PAT_CNTL                                 | R/W        | -         | 0_A2             | <a href="#">5-37</a> |
|                                                | PAT_REG0                                 | R/W        | -         | 0_A0             | <a href="#">5-36</a> |
|                                                | PAT_REG1                                 | R/W        | -         | 0_A1             | <a href="#">5-37</a> |

Table 3-2 Registers Listed by Mnemonic

Cont'd

| Registers by Mnemonic                |                     |            |           |                  |                      |
|--------------------------------------|---------------------|------------|-----------|------------------|----------------------|
| Register Class                       | Mnemonic            | Read/Write | Block I/O | DWORD Offset (h) | Page                 |
| <b>TMDS</b>                          | PATTERN_GEN_SEED    | R/W        |           | Index: 1B        | <a href="#">8-29</a> |
|                                      | PL_PLL_CNTL         | R/W        |           | Index: 24        | <a href="#">8-31</a> |
|                                      | PL_TRANSMITTER_CNTL | R/W        |           | Index: 23        | <a href="#">8-31</a> |
|                                      | PLTSTBLK_CNTL       | R/W        |           | Index: 19        | <a href="#">8-28</a> |
|                                      | PLTSTBLK_RPT        | R          |           | Index: 20        | <a href="#">8-30</a> |
| <b>Memory Buffer Control</b>         | PM_DSP_CONFIG       | R/W        | ✓         | 0_08             | <a href="#">4-12</a> |
|                                      | PM_DSP_ON_OFF       | R/W        | ✓         | 0_09             | <a href="#">4-12</a> |
|                                      | PM_VGA_DSP_CONFIG \ | R/W        | ✓         | 0_13             | <a href="#">4-13</a> |
|                                      | PM_VGA_DSP_ON_OFF   | R/W        | ✓         | 0_14             | <a href="#">4-13</a> |
| <b>TMDS</b>                          | PRI_ERR_PATTERN     | D          |           | Index: 1E        | <a href="#">8-29</a> |
| <b>Scissors</b>                      | SC_BOTTOM           | R/W        | -         | 0_AC             | <a href="#">5-41</a> |
|                                      | SC_LEFT             | R/W        | -         | 0_A8             | <a href="#">5-38</a> |
|                                      | SC_LEFT_RIGHT       | W          | -         | 0_AA             | <a href="#">5-40</a> |
|                                      | SC_RIGHT            | R/W        | -         | 0_A9             | <a href="#">5-39</a> |
|                                      | SC_TOP              | R/W        | -         | 0_AB             | <a href="#">5-40</a> |
|                                      | SC_TOP_BOTTOM       | W          | -         | 0_AD             | <a href="#">5-41</a> |
| <b>Scratch Pad and Test</b>          | SCRATCH_REG0        | R/W        | ✓         | 0_20             | <a href="#">4-3</a>  |
|                                      | SCRATCH_REG1        | R/W        | ✓         | 0_21             | <a href="#">4-4</a>  |
|                                      | SCRATCH_REG2        | R/W        | ✓         | 0_22             | <a href="#">4-4</a>  |
|                                      | SCRATCH_REG3        | R/W        | ✓         | 0_23             | <a href="#">4-5</a>  |
| <b>GenLocking</b>                    | SNAPSHOT2_F_COUNT   | R          | -         | 1_2D             | <a href="#">4-65</a> |
|                                      | SNAPSHOT2_VH_COUNTS | R          | -         | 1_2C             | <a href="#">4-66</a> |
|                                      | SNAPSHOT2_VIF_COUNT | R/W        | -         | 1_2F             | <a href="#">4-66</a> |
|                                      | SNAPSHOT_F_COUNT    | R          | -         | 1_1D             | <a href="#">4-64</a> |
|                                      | SNAPSHOT_VH_COUNTS  | R          | -         | 1_1C             | <a href="#">4-64</a> |
|                                      | SNAPSHOT_VIF_COUNT  | R/W        | -         | 1_1F             | <a href="#">4-66</a> |
| <b>Draw Engine Source Trajectory</b> | SRC_CNTL            | R/W        | -         | 0_6D             | <a href="#">5-21</a> |
|                                      | SRC_HEIGHT1         | R/W        | -         | 0_65             | <a href="#">5-23</a> |
|                                      | SRC_HEIGHT1_WIDTH1  | W          | -         | 0_66             | <a href="#">5-24</a> |
|                                      | SRC_HEIGHT2         | R/W        | -         | 0_6B             | <a href="#">5-25</a> |
|                                      | SRC_HEIGHT2_WIDTH2  | W          | -         | 0_6C             | <a href="#">5-25</a> |
|                                      | SRC_OFF_PITCH       | R/W        | -         | 0_60             | <a href="#">5-26</a> |

Table 3-2 Registers Listed by Mnemonic

Cont'd

| Registers by Mnemonic                     |                     |            |           |                  |                      |
|-------------------------------------------|---------------------|------------|-----------|------------------|----------------------|
| Register Class                            | Mnemonic            | Read/Write | Block I/O | DWORD Offset (h) | Page                 |
| <i>Draw Engine Source Trajectory</i>      | SRC_WIDTH1          | R/W        | -         | 0_64             | <a href="#">5-27</a> |
|                                           | SRC_WIDTH2          | R/W        | -         | 0_6A             | <a href="#">5-27</a> |
|                                           | SRC_X               | R/W        | -         | 0_61             | <a href="#">5-28</a> |
|                                           | SRC_X_START         | R/W        | -         | 0_67             | <a href="#">5-29</a> |
|                                           | SRC_Y               | R/W        | -         | 0_62             | <a href="#">5-29</a> |
|                                           | SRC_Y_START         | R/W        | -         | 0_68             | <a href="#">5-30</a> |
|                                           | SRC_Y_X             | W          | -         | 0_63             | <a href="#">5-31</a> |
|                                           | SRC_Y_X_START       | W          | -         | 0_69             | <a href="#">5-31</a> |
| <i>TMDS</i>                               | SYNC_GEN_CNTL       | R/W        | -         | Index: 1A        | <a href="#">8-28</a> |
|                                           | SYNC_RPT            | R          | -         | Index: 21        | <a href="#">8-30</a> |
|                                           | TEST_IO             | R/W        | -         | Index: 28        | <a href="#">8-34</a> |
| <i>Memory Buffer Control</i>              | TIMER_CONFIG        | R/W        | ✓         | 0_0A             | <a href="#">4-10</a> |
| <i>TMDS</i>                               | TMDS_CNTL           | R/W        |           | Index: 15        | <a href="#">8-26</a> |
|                                           | TMDS_CRC            | R          |           | Index: 18        | <a href="#">8-27</a> |
|                                           | TMDS_SYNC_CHAR_SETA | R/W        |           | Index: 16        | <a href="#">8-27</a> |
|                                           | TMDS_SYNC_CHAR_SETB | R/W        |           | Index: 17        | <a href="#">8-27</a> |
| <i>Draw Engine Destination Trajectory</i> | TRAIL_BRES_DEC      | R/W        | -         | 0_50             | <a href="#">5-15</a> |
|                                           | TRAIL_BRES_ERR      | R/W        | -         | 0_4E             | <a href="#">5-15</a> |
|                                           | TRAIL_BRES_INC      | R/W        | -         | 0_4F             | <a href="#">5-15</a> |
| <i>Data Path</i>                          | USR1_DST_OFF_PITCH  | W          | -         | 0_AE             | <a href="#">5-52</a> |
|                                           | USR2_DST_OFF_PITCH  | W          | -         | 0_AF             | <a href="#">5-52</a> |
|                                           | USR_DST_PITCH       | W          | -         | 0_BC             | <a href="#">5-52</a> |
| <i>Draw Engine Destination Trajectory</i> | Z_CNTL              | R/W        | -         | 0_53             | <a href="#">5-16</a> |
|                                           | Z_OFF_PITCH         | R/W        | -         | 0_52             | <a href="#">5-16</a> |

### 3.3 Listings of Indexed Registers

#### 3.3.1 PLL Registers Sorted by Address

Table 3-3 PLL Registers by Address

| PLL Registers by Address |                  |            |                      |
|--------------------------|------------------|------------|----------------------|
| Address                  | Mnemonic         | Read/Write | Page                 |
| 0                        | MPLL_CNTL        | R/W        | <a href="#">4-70</a> |
| 1                        | VPLL_CNTL        | R/W        | <a href="#">4-71</a> |
| 2                        | PLL_REF_DIV      | R/W        | <a href="#">4-71</a> |
| 3                        | PLL_GEN_CNTL     | R/W        | <a href="#">4-72</a> |
| 4                        | MCLK_FB_DIV      | R/W        | <a href="#">4-72</a> |
| 5                        | PLL_VCLK_CNTL    | R/W        | <a href="#">4-73</a> |
| 6                        | VCLK_POST_DIV    | R/W        | <a href="#">4-73</a> |
| 7                        | VCLK0_FB_DIV     | R/W        | <a href="#">4-74</a> |
| 8                        | VCLK1_FB_DIV     | R/W        | <a href="#">4-74</a> |
| 9                        | VCLK2_FB_DIV     | R/W        | <a href="#">4-74</a> |
| 10                       | VCLK3_FB_DIV     | R/W        | <a href="#">4-75</a> |
| 11                       | PLL_EXT_CNTL     | R/W        | <a href="#">4-75</a> |
| 12                       | DLL1_CNTL        | R/W        | <a href="#">4-76</a> |
| 13                       | VFC_CNTL         | R/W        | <a href="#">4-76</a> |
| 14                       | PLL_TEST_CNTL    | R/W        | <a href="#">4-77</a> |
| 15                       | PLL_TEST_COUNT   | R/W        | <a href="#">4-78</a> |
| 16                       | LVDS_CNTL0       | R/W        | <a href="#">4-78</a> |
| 17                       | LVDS_CNTL1       | R/W        | <a href="#">4-79</a> |
| 18                       | AGP1_CNTL        | R/W        | <a href="#">4-79</a> |
| 19                       | AGP2_CNTL        | R/W        | <a href="#">4-79</a> |
| 20                       | DLL2_CNTL        | R/W        | <a href="#">4-80</a> |
| 21                       | SCLK_FB_DIV      | R/W        | <a href="#">4-80</a> |
| 22                       | SPLL_CNTL1       | R/W        | <a href="#">4-81</a> |
| 23                       | SPLL_CNTL2       | R/W        | <a href="#">4-81</a> |
| 24                       | APLL_STRAPS      | R/W        | <a href="#">4-82</a> |
| 25                       | EXT_VPLL_CNTL    | R/W        | <a href="#">4-82</a> |
| 26                       | EXT_VPLL_REF_DIV | R/W        | <a href="#">4-83</a> |
| 27                       | EXT_VPLL_FB_DIV  | R/W        | <a href="#">4-84</a> |

Table 3-3 PLL Registers by Address

Cont'd

| <b>PLL Registers by Address</b> |                   |                   |                      |
|---------------------------------|-------------------|-------------------|----------------------|
| <b>Address</b>                  | <b>Mnemonic</b>   | <b>Read/Write</b> | <b>Page</b>          |
| 28                              | EXT_VPLL_MSB      | R/W               | <a href="#">4-84</a> |
| 29                              | HTOTAL_CNTL       | R/W               | <a href="#">4-85</a> |
| 30                              | BYTE_CLK_CNTL     | R/W               | <a href="#">4-85</a> |
| 31                              | TV_PLL_CNTL1      | R/W               | <a href="#">4-86</a> |
| 32                              | TV_PLL_CNTL2      | R/W               | <a href="#">4-86</a> |
| 33                              | TV_PLL_CNTL       | R/W               | <a href="#">4-86</a> |
| 34                              | EXT_TV_PLL        | R/W               | <a href="#">4-87</a> |
| 35                              | HW_DEBUG_EXT      | R/W               | <a href="#">4-87</a> |
| 36                              | PLL_V2CLK_CNTL    | R/W               | <a href="#">4-88</a> |
| 37                              | EXT_V2PLL_REF_DIV | R/W               | <a href="#">4-89</a> |
| 38                              | EXT_V2PLL_FB_DIV  | R/W               | <a href="#">4-89</a> |
| 39                              | EXT_V2PLL_MSB     | R/W               | <a href="#">4-89</a> |
| 40                              | HTOTAL2_CNTL      | R/W               | <a href="#">4-91</a> |
| 41                              | PLL_YCLK_CNTL     | R/W               | <a href="#">4-91</a> |
| 42                              | PM_DYN_CLK_CNTL   | R/W               | <a href="#">4-92</a> |

### 3.3.2 PLL Registers Sorted by Mnemonic

Table 3-4 PLL Registers by Mnemonic

| <b>PLL Registers by Mnemonic</b> |                  |                   |                      |
|----------------------------------|------------------|-------------------|----------------------|
| <b>Address</b>                   | <b>Mnemonic</b>  | <b>Read/Write</b> | <b>Page</b>          |
| 18                               | AGP1_CNTL        | R/W               | <a href="#">4-79</a> |
| 19                               | AGP2_CNTL        | R/W               | <a href="#">4-79</a> |
| 24                               | APLL_STRAPS      | R/W               | <a href="#">4-82</a> |
| 30                               | BYTE_CLK_CNTL    | R/W               | <a href="#">4-85</a> |
| 12                               | DLL1_CNTL        | R/W               | <a href="#">4-76</a> |
| 20                               | DLL2_CNTL        | R/W               | <a href="#">4-80</a> |
| 34                               | EXT_TV_PLL       | R/W               | <a href="#">4-87</a> |
| 38                               | EXT_V2PLL_FB_DIV | R/W               | <a href="#">4-89</a> |
| 39                               | EXT_V2PLL_MSB    | R/W               | <a href="#">4-89</a> |

Table 3-4 PLL Registers by Mnemonic

Cont'd

| PLL Registers by Mnemonic |                   |            |                      |
|---------------------------|-------------------|------------|----------------------|
| Address                   | Mnemonic          | Read/Write | Page                 |
| 37                        | EXT_V2PLL_REF_DIV | R/W        | <a href="#">4-89</a> |
| 25                        | EXT_VPLL_CNTL     | R/W        | <a href="#">4-82</a> |
| 27                        | EXT_VPLL_FB_DIV   | R/W        | <a href="#">4-84</a> |
| 28                        | EXT_VPLL_MSB      | R/W        | <a href="#">4-84</a> |
| 26                        | EXT_VPLL_REF_DIV  | R/W        | <a href="#">4-83</a> |
| 40                        | HTOTAL2_CNTL      | R/W        | <a href="#">4-91</a> |
| 29                        | HTOTAL_CNTL       | R/W        | <a href="#">4-85</a> |
| 16                        | LVDS_CNTL0        | R/W        | <a href="#">4-78</a> |
| 17                        | LVDS_CNTL1        | R/W        | <a href="#">4-79</a> |
| 4                         | MCLK_FB_DIV       | R/W        | <a href="#">4-72</a> |
| 0                         | MPLL_CNTL         | R/W        | <a href="#">4-70</a> |
| 11                        | PLL_EXT_CNTL      | R/W        | <a href="#">4-75</a> |
| 3                         | PLL_GEN_CNTL      | R/W        | <a href="#">4-72</a> |
| 2                         | PLL_REF_DIV       | R/W        | <a href="#">4-71</a> |
| 14                        | PLL_TEST_CNTL     | R/W        | <a href="#">4-77</a> |
| 15                        | PLL_TEST_COUNT    | R/W        | <a href="#">4-78</a> |
| 36                        | PLL_V2CLK_CNTL    | R/W        | <a href="#">4-88</a> |
| 5                         | PLL_VCLK_CNTL     | R/W        | <a href="#">4-73</a> |
| 41                        | PLL_YCLK_CNTL     | R/W        | <a href="#">4-91</a> |
| 42                        | PM_DYN_CLK_CNTL   | R/W        | <a href="#">4-92</a> |
| 21                        | SCLK_FB_DIV       | R/W        | <a href="#">4-80</a> |
| 22                        | SPLL_CNTL1        | R/W        | <a href="#">4-81</a> |
| 23                        | SPLL_CNTL2        | R/W        | <a href="#">4-81</a> |
| 33                        | TV_PLL_CNTL       | R/W        | <a href="#">4-86</a> |
| 31                        | TV_PLL_CNTL1      | R/W        | <a href="#">4-86</a> |
| 32                        | TV_PLL_CNTL2      | R/W        | <a href="#">4-86</a> |
| 35                        | HW_DEBUG_EXT      | R/W        | <a href="#">4-87</a> |
| 7                         | VCLK0_FB_DIV      | R/W        | <a href="#">4-74</a> |
| 8                         | VCLK1_FB_DIV      | R/W        | <a href="#">4-74</a> |
| 9                         | VCLK2_FB_DIV      | R/W        | <a href="#">4-74</a> |
| 10                        | VCLK3_FB_DIV      | R/W        | <a href="#">4-75</a> |

Table 3-4 PLL Registers by Mnemonic

Cont'd

| PLL Registers by Mnemonic |               |            |                      |
|---------------------------|---------------|------------|----------------------|
| Address                   | Mnemonic      | Read/Write | Page                 |
| 6                         | VCLK_POST_DIV | R/W        | <a href="#">4-73</a> |
| 13                        | VFC_CNTL      | R/W        | <a href="#">4-76</a> |
| 1                         | VPLL_CNTL     | R/W        | <a href="#">4-71</a> |

### 3.3.3 LCD Panel Registers Sorted by Index Number

Table 3-5 LCD Panel Registers Sorted by Index Number

| LCD Registers by Index Number |            |       |           |                      |
|-------------------------------|------------|-------|-----------|----------------------|
| Mnemonic                      | Read/Write | Index | Offset(h) | Page                 |
| LCD_INDEX                     | R/W        |       | 0_29      | <a href="#">8-1</a>  |
| CONFIG_PANEL                  | R/W        | 0     | 0_2A      | <a href="#">8-3</a>  |
| LCD_GEN_CTRL                  | R/W        | 1     | 0_2A      | <a href="#">8-6</a>  |
| DSTN_CONTROL                  | R/W        | 2     | 0_2A      | <a href="#">8-8</a>  |
| HFB_PITCH_ADDR                | R/W        | 3     | 0_2A      | <a href="#">8-10</a> |
| HORZ_STRETCHING               | R/W        | 4     | 0_2A      | <a href="#">8-11</a> |
| VERT_STRETCHING               | R/W        | 5     | 0_2A      | <a href="#">8-12</a> |
| EXT_VERT_STRETCH              | R/W        | 6     | 0_2A      | <a href="#">8-13</a> |
| LT_GIO                        | R/W        | 7     | 0_2A      | <a href="#">8-14</a> |
| POWER_MANAGEMENT              | R/W        | 8     | 0_2A      | <a href="#">8-17</a> |
| ZVGPIO                        | R/W        | 9     | 0_2A      | <a href="#">8-15</a> |
| ICON_CLR0                     | R/W        | A     | 0_2A      | <a href="#">8-22</a> |
| ICON_CLR1                     | R/W        | B     | 0_2A      | <a href="#">8-22</a> |
| ICON_OFFSET                   | R/W        | C     | 0_2A      | <a href="#">8-22</a> |
| ICON_HORZ_VERT_POSN           | R/W        | D     | 0_2A      | <a href="#">8-23</a> |
| ICON_HORZ_VERT_OFF            | R/W        | E     | 0_2A      | <a href="#">8-23</a> |
| ICON2_CLR0                    | R/W        | F     | 0_2A      | <a href="#">8-23</a> |
| ICON2_CLR1                    | R/W        | 10    | 0_2A      | <a href="#">8-23</a> |
| ICON2_OFFSET                  | R/W        | 11    | 0_2A      | <a href="#">8-24</a> |
| ICON2_HORZ_VERT_POSN          | R/W        | 12    | 0_2A      | <a href="#">8-24</a> |
| ICON2_HORZ_VERT_OFF           | R/W        | 13    | 0_2A      | <a href="#">8-24</a> |

Table 3-5 LCD Panel Registers Sorted by Index Number

Cont'd

| LCD Registers by Index Number |            |       |           |                      |
|-------------------------------|------------|-------|-----------|----------------------|
| Mnemonic                      | Read/Write | Index | Offset(h) | Page                 |
| LCD_MISC_CNTL                 | R/W        | 14    | 0_2A      | <a href="#">8-24</a> |
| APC_CNTL                      | R/W        | 1C    | 0_2A      | <a href="#">8-33</a> |
| POWER_MANAGEMENT_2            | R/W        | 1D    | 0_2A      | <a href="#">8-18</a> |
| ALPHA BLENDING                | R/W        | 25    | 0_2A      | <a href="#">8-42</a> |
| APC_CTRL_IO (not supported)   | R/W        | 27    | 0_2A      | <a href="#">8-33</a> |
| TEST_IO                       | R/W        | 28    | 0_2A      | <a href="#">8-34</a> |
| TEST_OUTPUTS                  | R          | 29    | 0_2A      | <a href="#">8-35</a> |
| DP1_MEM_ACCESS                | R          | 2A    | 0_2A      | <a href="#">8-35</a> |
| DP0_MEM_ACCESS                | R/W        | 2B    | 0_2A      | <a href="#">8-35</a> |
| DP0_DEBUG_A                   | R/W        | 2C    | 0_2A      | <a href="#">8-36</a> |
| DP0_DEBUG_B                   | R          | 2D    | 0_2A      | <a href="#">8-37</a> |
| DP1_DEBUG_A                   | R/W        | 2E    | 0_2A      | <a href="#">8-37</a> |
| DP1_DEBUG_B                   | R          | 2F    | 0_2A      | <a href="#">8-37</a> |
| DPCTRL_DEBUG_A                | R          | 30    | 0_2A      | <a href="#">8-38</a> |
| DPCTRL_DEBUG_B                | R          | 31    | 0_2A      | <a href="#">8-39</a> |
| MEMBLK_DEBUG                  | R          | 32    | 0_2A      | <a href="#">8-40</a> |
| SCRATCH_PAD_4                 | R/W        | 33    | 0_2A      | <a href="#">8-40</a> |
| SCRATCH_PAD_5                 | R/W        | 34    | 0_2A      | <a href="#">8-40</a> |
| SCRATCH_PAD_6                 | R/W        | 35    | 0_2A      | <a href="#">8-41</a> |
| SCRATCH_PAD_7                 | R/W        | 36    | 0_2A      | <a href="#">8-41</a> |
| SCRATCH_PAD_8                 | R/W        | 37    | 0_2A      | <a href="#">8-41</a> |
| APC_LUT_KL                    | R/W        | 38    | 0_2A      | <a href="#">8-41</a> |
| APC_LUT_MN                    | R/W        | 39    | 0_2A      | <a href="#">8-42</a> |
| APC_LUT_OP                    | R/W        | 3A    | 0_2A      | <a href="#">8-42</a> |

### 3.3.4 LCD Panel Registers Sorted by Mnemonic

Table 3-6 LCD Panel Registers Sorted by Mnemonic

| LCD Registers by Mnemonic   |            |       |           |                      |
|-----------------------------|------------|-------|-----------|----------------------|
| Mnemonic                    | Read/Write | Index | Offset(h) | Page                 |
| ALPHA BLENDING              | R/W        | 25    | 0_2A      | <a href="#">8-42</a> |
| APC_CNTL                    | R/W        | 1C    | 0_2A      | <a href="#">8-33</a> |
| APC_CTRL_IO (not supported) | R/W        | 27    | 0_2A      | <a href="#">8-33</a> |
| APC_LUT_KL                  | R/W        | 38    | 0_2A      | <a href="#">8-41</a> |
| APC_LUT_MN                  | R/W        | 39    | 0_2A      | <a href="#">8-42</a> |
| APC_LUT_OP                  | R/W        | 3A    | 0_2A      | <a href="#">8-42</a> |
| CONFIG_PANEL                | R/W        | 0     | 0_2A      | <a href="#">8-3</a>  |
| DP0_DEBUG_A                 | R/W        | 2C    | 0_2A      | <a href="#">8-36</a> |
| DP0_DEBUG_B                 | R          | 2D    | 0_2A      | <a href="#">8-37</a> |
| DP0_MEM_ACCESS              | R/W        | 2B    | 0_2A      | <a href="#">8-35</a> |
| DP1_DEBUG_A                 | R/W        | 2E    | 0_2A      | <a href="#">8-37</a> |
| DP1_DEBUG_B                 | R          | 2F    | 0_2A      | <a href="#">8-37</a> |
| DP1_MEM_ACCESS              | R          | 2A    | 0_2A      | <a href="#">8-35</a> |
| DPCTRL_DEBUG_A              | R          | 30    | 0_2A      | <a href="#">8-38</a> |
| DPCTRL_DEBUG_B              | R          | 31    | 0_2A      | <a href="#">8-39</a> |
| DSTN_CONTROL                | R/W        | 2     | 0_2A      | <a href="#">8-8</a>  |
| EXT_VERT_STRETCH            | R/W        | 6     | 0_2A      | <a href="#">8-13</a> |
| HFB_PITCH_ADDR              | R/W        | 3     | 0_2A      | <a href="#">8-10</a> |
| HORZ_STRETCHING             | R/W        | 4     | 0_2A      | <a href="#">8-11</a> |
| ICON2_CLR0                  | R/W        | F     | 0_2A      | <a href="#">8-23</a> |
| ICON2_CLR1                  | R/W        | 10    | 0_2A      | <a href="#">8-23</a> |
| ICON2_HORZ_VERT_OFF         | R/W        | 13    | 0_2A      | <a href="#">8-24</a> |
| ICON2_HORZ_VERT_POSN        | R/W        | 12    | 0_2A      | <a href="#">8-24</a> |
| ICON2_OFFSET                | R/W        | 11    | 0_2A      | <a href="#">8-24</a> |
| ICON_CLR0                   | R/W        | A     | 0_2A      | <a href="#">8-22</a> |
| ICON_CLR1                   | R/W        | B     | 0_2A      | <a href="#">8-22</a> |
| ICON_HORZ_VERT_OFF          | R/W        | E     | 0_2A      | <a href="#">8-23</a> |
| ICON_HORZ_VERT_POSN         | R/W        | D     | 0_2A      | <a href="#">8-23</a> |
| ICON_OFFSET                 | R/W        | C     | 0_2A      | <a href="#">8-22</a> |

Table 3-6 LCD Panel Registers Sorted by Mnemonic

Cont'd

| LCD Registers by Mnemonic |            |       |           |                      |
|---------------------------|------------|-------|-----------|----------------------|
| Mnemonic                  | Read/Write | Index | Offset(h) | Page                 |
| LCD_GEN_CTRL              | R/W        | 1     | 0_2A      | <a href="#">8-6</a>  |
| LCD_INDEX                 | R/W        |       | 0_29      | <a href="#">8-1</a>  |
| LCD_MISC_CNTL             | R/W        | 14    | 0_2A      | <a href="#">8-24</a> |
| LT_GIO                    | R/W        | 7     | 0_2A      | <a href="#">8-14</a> |
| MEMBLK_DEBUG              | R          | 32    | 0_2A      | <a href="#">8-40</a> |
| POWER_MANAGEMENT          | R/W        | 8     | 0_2A      | <a href="#">8-17</a> |
| POWER_MANAGEMENT_2        | R/W        | 1D    | 0_2A      | <a href="#">8-18</a> |
| SCRATCH_PAD_4             | R/W        | 33    | 0_2A      | <a href="#">8-40</a> |
| SCRATCH_PAD_5             | R/W        | 34    | 0_2A      | <a href="#">8-40</a> |
| SCRATCH_PAD_6             | R/W        | 35    | 0_2A      | <a href="#">8-41</a> |
| SCRATCH_PAD_7             | R/W        | 36    | 0_2A      | <a href="#">8-41</a> |
| SCRATCH_PAD_8             | R/W        | 37    | 0_2A      | <a href="#">8-41</a> |
| TEST_IO                   | R/W        | 28    | 0_2A      | <a href="#">8-34</a> |
| TEST_OUTPUTS              | R          | 29    | 0_2A      | <a href="#">8-35</a> |
| VERT_STRETCHING           | R/W        | 5     | 0_2A      | <a href="#">8-12</a> |
| ZVGPIO                    | R/W        | 9     | 0_2A      | <a href="#">8-15</a> |

This page intentionally left blank.

# Chapter 4

## Display and Configuration

For an explanation of the notations used to describe the registers in this and the following chapters, refer to Chapter 1, section [1.3.3](#).

### 4.1 Setup and Control Registers

#### 4.1.1 General I/O Control Registers

|      |     | GP_IO       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Offset: 0_1E                                             |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
|------|-----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------------------------------------------------------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |
|      |     | dd          | cc | bb | aa | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  |    | n  | m  | l  | k  | j  | i | h | g | f                                                        | e | d | c | b | a |   |  |  |  |  |  |  |  |  |  |
| a    | R/W | GP_IO_0     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIR0 = output/input) for pin: GPIO(0)        |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| b    | R/W | GP_IO_1     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIR1 = output/input) for pin: GPIO(1)        |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| c    | R/W | GP_IO_2     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIR2 = output/input) for pin: GPIO(2)        |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| d    | R/W | GP_IO_3     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIR3 = output/input) for pin: GPIO(3)        |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| e    | R/W | GP_IO_4     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIR4 = output/input) for pin: GPIO(4)        |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| f    | R/W | GP_IO_5     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIR5 = output/input) for pin: GPIO(5)        |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| g    | R/W | GP_IO_6     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIR6 = output/input) for pin: GPIO(6)        |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| h    | R/W | GP_IO_7     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIR7 = output/input) for pin: GPIO(7)        |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| i    | R/W | GP_IO_8     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIR8 = output/input) for pin: GPIO(8)        |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| j    | R/W | GP_IO_9     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIR9 = output/input) for pin: GPIO(9)        |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| k    | R/W | GP_IO_A     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIRA = output/input) for pin: GPIO(10)       |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| l    | R/W | GP_IO_B     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIRB = output/input) for pin: GPIO(11)       |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| m    | R/W | GP_IO_C     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIRC = output/input) for pin: GPIO(12)       |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| n    | R/W | GP_IO_D     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Write/Read (DIRD = output/input) for pin: GPIO(13)       |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| o    | R/W | GP_IO_DIR_0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | I/O direction for pin GPIO(0)<br>0 = Input<br>1 = Output |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| p    | R/W | GP_IO_DIR_1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | I/O direction for pin GPIO(1)<br>0 = Input<br>1 = Output |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |

| Cont'd |     | GP_IO        |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_1E                                                                                         |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|--------------|--|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
|        |     | BITS         |  | 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 |
|        |     |              |  | dd | cc | bb | aa | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  |    |    | n                                                                                                    | m  | l  | k  | j | i | h | g | f | e | d | c | b | a |
| q      | R/W | GP_IO_DIR_2  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | I/O direction for pin GPIO(2)<br>0 = Input<br>1 = Output                                             |    |    |    |   |   |   |   |   |   |   |   |   |   |
| r      | R/W | GP_IO_DIR_3  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | I/O direction for pin GPIO(3)<br>0 = Input<br>1 = Output                                             |    |    |    |   |   |   |   |   |   |   |   |   |   |
| s      | R/W | GP_IO_DIR_4  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | I/O direction for pin GPIO(4)<br>0 = Input<br>1 = Output                                             |    |    |    |   |   |   |   |   |   |   |   |   |   |
| t      | R/W | GP_IO_DIR_5  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | I/O direction for pin GPIO(5)<br>0 = Input<br>1 = Output                                             |    |    |    |   |   |   |   |   |   |   |   |   |   |
| u      | R/W | GP_IO_DIR_6  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | I/O direction for pin GPIO(6)<br>0 = Input<br>1 = Output                                             |    |    |    |   |   |   |   |   |   |   |   |   |   |
| v      | R/W | GP_IO_DIR_7  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | I/O direction for pin GPIO(7):<br>0 = Input<br>1 = Output                                            |    |    |    |   |   |   |   |   |   |   |   |   |   |
| w      | R/W | GP_IO_DIR_8  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | I/O direction for pin GPIO(8):<br>0 = Input<br>1 = Output                                            |    |    |    |   |   |   |   |   |   |   |   |   |   |
| x      | R/W | GP_IO_DIR_9  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | I/O direction for pin GPIO(9)<br>0 = Input<br>1 = Output                                             |    |    |    |   |   |   |   |   |   |   |   |   |   |
| y      | R/W | GP_IO_DIR_A  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | I/O direction for pin GPIO(10)<br>0 = Input<br>1 = Output                                            |    |    |    |   |   |   |   |   |   |   |   |   |   |
| z      | R/W | GP_IO_DIR_B  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | I/O direction for pin GPIO(11)<br>0 = Input<br>1 = Output                                            |    |    |    |   |   |   |   |   |   |   |   |   |   |
| aa     | R/W | GP_IO_DIR_C  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | I/O direction for pin GPIO(12)<br>0 = Input<br>1 = Output                                            |    |    |    |   |   |   |   |   |   |   |   |   |   |
| bb     | R/W | GP_IO_DIR_D  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | I/O direction for pin GPIO(13)<br>0 = Input<br>1 = Output                                            |    |    |    |   |   |   |   |   |   |   |   |   |   |
| cc     | R/W | MPP_IO_DRIVE |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MPP I/O output drive strength<br>Applies to GPIO pins 0 to 11 inclusive<br>0 = No boost<br>1 = Boost |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Cont'd |     | GP_IO        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_1E                                                                                 |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | dd           | cc | bb | aa | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  |    |    | n  | m  | l                                                                                            | k  | j | i | h | g | f | e | d | c | b | a |
| dd     | R/W | I2C_IO_DRIVE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | I2C I/O output drive strength<br>Applies to GPIO pins 12 and 13<br>0 = No boost<br>1 = Boost |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register specifies the data and direction for pins GPIO[13:0] of the General Purpose I/O bus. For the data/direction of pins GPIO[46:44], refer to register [LT\\_GIO](#) on page 8-14.

### Usage

For details on the typical pin configurations used to support the various operational modes (VFC, DVS, etc.), refer to the RAGE XL Graphics Controller Specifications.

## 4.1.2 Scratch Pad Registers

|      |     | SCRATCH_REG0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | Offset: 0_20  |   |   |   |   |   |  |  |
|------|-----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---------------|---|---|---|---|---|--|--|
| BITS |     | 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 |  |  |
|      |     |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | a             |   |   |   |   |   |  |  |
| a    | R/W | SCRATCH_REG0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | Scratch pad 0 |   |   |   |   |   |  |  |

### Description

This register is a general-purpose, scratch-pad, storage register. Use these registers to allow two decoupled programs to exchange information. Typically, these registers are used by the BIOS to pass configuration information to drivers or used for BIOS data storage.

### Usage

Only the adapter BIOS should use this register.

### See Also

[SCRATCH\\_REG1](#) on page 4-4, [SCRATCH\\_REG2](#) on page 4-4, and [SCRATCH\\_REG3](#) on page 4-5.

*mach64* Programmer's Guide:

- Advanced Topics: Boot-time Initialization

|      |     |              | SCRATCH_REG1 |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Offset: 0_21 |   |   |   |   |
|------|-----|--------------|--------------|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------------|---|---|---|---|
| BITS |     | 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 |
|      |     | a            |              |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |
| a    | R/W | SCRATCH_REG1 |              |    |    |    |    |    |    |    |    |    |    | Scratch pad 1 |    |    |    |    |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |

**Description**

This register is similar to the SCRATCH\_REG0 register on [page 4-3](#).

**Usage**

Refer to the SCRATCH\_REG0 register on [page 4-3](#).

**See Also**

SCRATCH\_REG0 on [page 4-3](#), SCRATCH\_REG2 on [page 4-4](#), and SCRATCH\_REG3 on [page 4-5](#).

*mach64* Programmer's Guide:

- Advanced Topics: Boot-time Initialization

|      |     |              | SCRATCH_REG2 |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Offset: 0_22 |   |   |   |   |
|------|-----|--------------|--------------|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------------|---|---|---|---|
| BITS |     | 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 |
|      |     | a            |              |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |
| a    | R/W | SCRATCH_REG2 |              |    |    |    |    |    |    |    |    |    |    | Scratch pad 2 |    |    |    |    |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |

**Description**

This register is similar to the SCRATCH\_REG0 register on [page 4-3](#).

**Usage**

Refer to the SCRATCH\_REG0 register on [page 4-3](#).

**See Also**

SCRATCH\_REG0 on [page 4-3](#), SCRATCH\_REG1 on [page 4-4](#) and SCRATCH\_REG3 on [page 4-5](#)

*mach64* Programmer's Guide:

- Advanced Topics: Boot-time Initialization

|      |     |              | SCRATCH_REG3 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |               |   |   | Offset: 0_23 |   |   |   |   |
|------|-----|--------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------------|---|---|--------------|---|---|---|---|
| BITS |     | 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 |
|      |     | a            |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |               |   |   |              |   |   |   |   |
| a    | R/W | SCRATCH_REG3 |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Scratch pad 3 |   |   |              |   |   |   |   |

### Description

This register is similar to the SCRATCH\_REG0 register on [page 4-3](#).

### Usage

Refer to the SCRATCH\_REG0 register on [page 4-3](#).

### See Also

SCRATCH\_REG0 on [page 4-3](#), SCRATCH\_REG1 on [page 4-4](#), SCRATCH\_REG2 on [page 4-4](#).

*mach64* Programmer's Guide:

- Advanced Topics: Boot-time Initialization

## 4.1.3 Bus Control Registers

|      |     |                  | BUS_CNTL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                               |                                                                                                                    | Offset: 0_28 |   |   |   |   |   |
|------|-----|------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|--------------|---|---|---|---|---|
| BITS |     | 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 |
|      |     | x                | w        | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  | 1  | k  | j  | i  |    |    |    | h  | g  | f  | e | d | c                                                                             | b                                                                                                                  | a            |   |   |   |   |   |
| a    | R/W | BUS_DBL_RESETNC  |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Add 1 clock-settling time to BCLK and MCLK re-synchronizers:<br>(default = 1) |                                                                                                                    |              |   |   |   |   |   |
| b    | W   | BUS_MSTR_RESET   |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                               | To reset the bus master, write a '1' to this bit<br>(one shot, no need to write '0')                               |              |   |   |   |   |   |
| c    | W   | BUS_FLUSH_BUF    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                               | To flush data from the buffer, write a '1' to this bit<br>(one shot, no need to write '0')                         |              |   |   |   |   |   |
| d    | R/W | BUS_STOP_REQ_DIS |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                               | Disable the burst read requests after stop has been asserted: (default = 0)<br>0 = Normal operation<br>1 = Disable |              |   |   |   |   |   |

| Cont'd |     | BUS_CNTL              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Offset: 0_28                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |  |  |  |  |
|--------|-----|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|--|--|--|--|
| BITS   |     | 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 |  |  |  |  |
|        |     | x                     | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  |    | 1  | k  |    | j  | i  |    |    | h  | g  | f | e | d                                                                                                                                                                                                                                              | c | b | a |   |   |   |   |  |  |  |  |
| e      | R/W | BUS_APER_REG_DIS      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Disable memory-mapped register decoding in the linear aperture:<br>(default = 0)<br>0 = Enable<br>1 = Disable                                                                                                                                  |   |   |   |   |   |   |   |  |  |  |  |
| f      | R/W | BUS_EXTRA_PIPE_DIS    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Disable extra pipeline stage: (default = 0)<br>0 = Enable<br>1 = Disable                                                                                                                                                                       |   |   |   |   |   |   |   |  |  |  |  |
| g      | R/W | BUS_MASTER_DIS        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Disable bus master operation:<br>0 = Enable<br>1 = Disable                                                                                                                                                                                     |   |   |   |   |   |   |   |  |  |  |  |
| h      | R/W | ROM_WRT_EN            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable write to flash memory BIOS: (default = 0)<br>0 = Disable<br>1 = Enable (ROMWRDEN strap must also be enabled)                                                                                                                            |   |   |   |   |   |   |   |  |  |  |  |
| i      | R/W | DISROM                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Disable write to flash memory BIOS<br>0 = Enable<br>1 = Disable                                                                                                                                                                                |   |   |   |   |   |   |   |  |  |  |  |
| j      | R/W | BUS_PCI_READ_RETRY_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable retry for PCI read transfers: (default = 0)<br>0 = Normal operation (reads will hold bus until complete)<br>1 = Enable retry cycle in PCI (reads will retry when timeout counter expires)                                               |   |   |   |   |   |   |   |  |  |  |  |
| k      | R/W | BUS_PCI_WRT_RETRY_EN  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable retry for PCI write transfers: (default = 0)<br>0 = Normal operation (writes will hold bus until complete)<br>1 = Enable retry cycle in PCI (writes will retry when timeout counter expires)                                            |   |   |   |   |   |   |   |  |  |  |  |
| l      | R/W | BUS_RETRY_WS          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Control value for timeout counter. See <a href="#">Table 4-1</a> below under usage for translation to actual wait states.                                                                                                                      |   |   |   |   |   |   |   |  |  |  |  |
| m      | R/W | BUS_MSTR_RD_MULT      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable 'read multiple' command for bus master: (default = 0)<br>0 = When transfer length greater than cache line size reg., use 'read line' command<br>1 = When transfer length greater than cache line size reg., use 'read multiple' command |   |   |   |   |   |   |   |  |  |  |  |
| n      | R/W | BUS_MSTR_RD_LINE      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Set the 'read line' command for bus master: (default = 0)<br>0 = Use 'read' command exclusively<br>1 = When transfer length greater than 1, use 'read line' command                                                                            |   |   |   |   |   |   |   |  |  |  |  |
| o      | R/W | BUS_SUSPEND           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Set mode for current bus master transfer<br>1 = Suspend (this transfer will resume when this bit is cleared)<br>0 = Resume                                                                                                                     |   |   |   |   |   |   |   |  |  |  |  |
| p      | R   | LAT16X                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Set value of the latency timer<br>1 = Multiply the latency timer value by 16<br>0 = Use the latency timer value as is                                                                                                                          |   |   |   |   |   |   |   |  |  |  |  |

| Cont'd |     | BUS_CNTL               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Offset: 0_28                                                                                                                                                                             |   |   |   |   |   |   |   |
|--------|-----|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | x                      | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  |    | 1  |    | k  |    | j  | i  |    |    |    | h | g | f                                                                                                                                                                                        | e | d | c | b | a |   |   |
| q      | R/W | BUS_RD_DISCARD_EN      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable PCI slave read data: (default = 0)<br>1 = Enable<br>0 = Disable                                                                                                                   |   |   |   |   |   |   |   |
| r      | R/W | BUS_RD_ABORT_EN        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable the slave's delayed read transaction abort (for BM conflicts)<br>1 = Enable<br>0 = Disable                                                                                        |   |   |   |   |   |   |   |
| s      | R/W | BUS_MSTR_WS            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Number of wait states to allow until bus master transaction is terminated:<br>0 = 8 wait states<br>1 = 32 wait states<br>Note: This is valid only when BUS_MSTR_DISCONNECT_EN is enabled |   |   |   |   |   |   |   |
| t      | R/W | BUS_EXT_REG_EN         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable extended register block 1: (default = 0)<br>0 = Disable<br>1 = Enable                                                                                                             |   |   |   |   |   |   |   |
| u      | R/W | BUS_MSTR_DISCONNECT_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable bus master disconnect after allowed wait states has elapsed:<br>(default = 0)<br>1 = Enable<br>0 = Disable                                                                        |   |   |   |   |   |   |   |
| v      | R/W | BUS_WRT_BURST          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable burst write transfers: (default = 0)<br>0 = Disable<br>1 = Enable                                                                                                                 |   |   |   |   |   |   |   |
| w      | R/W | BUS_READ_BURST         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable burst read transfers: (default = 0)<br>0 = Disable<br>1 = Enable                                                                                                                  |   |   |   |   |   |   |   |
| x      | R/W | BUS_RDY_READ_DLY       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Set delay for the bus memory read RDY signal: (default = 1)<br>0 = No delay<br>1 = Delay RDY by 1 memory clock                                                                           |   |   |   |   |   |   |   |

### Description

This register configures the on-chip bus interface, controls the bus mastering, and controls the error condition interrupts.

### Usage

Error condition flags that generate hard interrupts should be used only for software debugging and not included in the final retail software.

Other control bits in this register should be used only by the adapter ROM at boot-time.

[Table 4.2](#) specifies conversion of the BUS\_RETRY\_WS field into actual wait states on BCLK when BUS\_PCI\_WRT\_RETRY\_EN = 1 or BUS\_PCI\_READ\_RETRY\_EN = 1.

**Table 4-1 Conversion of the BUS\_RETRY\_WS Field**

| <b>BUS_RETRY_WS</b> | <b>Actual Number of Clocks to TRDY or STOP</b> | <b>Time (@33 MHz)</b> |
|---------------------|------------------------------------------------|-----------------------|
| 0                   | 3                                              | 90 ns                 |
| 1                   | 5                                              | 150 ns                |
| 2h                  | 7h                                             | 210 ns                |
| 3h                  | 8h                                             | 240 ns                |
| 4h                  | 9h                                             | 270 ns                |
| 5h                  | Bh                                             | 330 ns                |
| 6h                  | Eh                                             | 420 ns                |
| 7h                  | Fh                                             | 470 ns                |
| 8h                  | 13h                                            | 570 ns                |
| 9h                  | 35h                                            | 1.59 ms               |
| Ah                  | 57h                                            | 2.61 µs               |
| Bh                  | 78h                                            | 3.6 µs                |
| Ch                  | 99h                                            | 4.59 µs               |
| Dh                  | BBh                                            | 5.61 µs               |
| Eh                  | FFh                                            | 7.65 µs               |
| Fh                  | Infinite                                       | Infinite              |

Note: First datapath response = 8 clks + actual clocks from the above table.

### See Also

*mach64* Programmer's Guide:

- *Advanced Topics: Interrupts*
- *Advanced Topics: Boot-time Initialization*

#### 4.1.4 Memory Buffer Control Registers

|      |     | DSP_CONFIG       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Offset: 0_08                                                                                                                   |   |   |   |   |   |   |  |  |  |  |  |  |  |
|------|-----|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |
|      |     | d                |    |    |    |    |    |    |    |    |    |    |    | c  |    |    |    | b  |    | a  |    |    |    |   |   |   |                                                                                                                                |   |   |   |   |   |   |  |  |  |  |  |  |  |
| a    | R/W | DSP_XCLKS_PER_QW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Amount of time in XCLKs that one QWORD in the display FIFO occupies                                                            |   |   |   |   |   |   |  |  |  |  |  |  |  |
| b    | R/W | DSP_FLUSH_WB     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Flush the write buffer at VSYNC:<br>0 = Flush at VSYNC, at threshold or on read (default)<br>1 = Flush at threshold or on read |   |   |   |   |   |   |  |  |  |  |  |  |  |
| c    | R/W | DSP_LOOP_LATENCY |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Display FIFO control parameter                                                                                                 |   |   |   |   |   |   |  |  |  |  |  |  |  |
| d    | R/W | DSP_PRECISION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Integer.fraction precision point for:<br>DSP_XCLKS_PER_QW<br>DSP_ON<br>DSP_OFF                                                 |   |   |   |   |   |   |  |  |  |  |  |  |  |

|      |     | DSP_ON_OFF |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Offset: 0_09                                                    |   |   |   |   |   |   |  |  |  |  |  |  |  |
|------|-----|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----------------------------------------------------------------|---|---|---|---|---|---|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |
|      |     | b          |    |    |    |    |    |    |    |    |    |    |    | c  |    |    |    | b  |    | a  |    |    |    |   |   |   |                                                                 |   |   |   |   |   |   |  |  |  |  |  |  |  |
| a    | R/W | DSP_OFF    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | The display memory request off threshold time in terms of XCLKs |   |   |   |   |   |   |  |  |  |  |  |  |  |
| b    | R/W | DSP_ON     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | The display memory request on threshold time in terms of XCLKs  |   |   |   |   |   |   |  |  |  |  |  |  |  |

(NOT supported in RAGE XL)

|      |     | DSP2_CONFIG       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Offset: 0_15                                                                      |   |   |   |   |   |   |  |  |  |  |  |  |  |
|------|-----|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----------------------------------------------------------------------------------|---|---|---|---|---|---|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |
|      |     | c                 |    |    |    |    |    |    |    |    |    |    |    | b  |    |    |    | b  |    | a  |    |    |    |   |   |   |                                                                                   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| a    | R/W | DSP2_XCLKS_PER_QW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Amount of time in XCLKs that one QWORD in the second display FIFO occupies        |   |   |   |   |   |   |  |  |  |  |  |  |  |
| b    | R/W | DSP_LOOP_LATENCY  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Display FIFO control parameter                                                    |   |   |   |   |   |   |  |  |  |  |  |  |  |
| c    | R/W | DSP2_PRECISION    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Integer.fraction precision point for:<br>DSP2_XCLKS_PER_QW<br>DSP2_ON<br>DSP2_OFF |   |   |   |   |   |   |  |  |  |  |  |  |  |

(NOT supported in RAGE XL)

|      |     |          | DSP2_ON_OFF |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                 | Offset: 0_16 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|----------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------|--------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | b        |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                                                               |              |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | DSP2_OFF |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    | The display memory request off threshold time in terms of XCLKs |              |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b    | R/W | DSP2_ON  |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    | The display memory request on threshold time in terms of XCLKs  |              |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

The next two registers are used to set DSP parameters for second display.

|      |     |                           | TIMER_CONFIG |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Offset: 0_0A |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|---------------------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | e                         | d            |    |    |    | c  |    |    |    |    |    |    |    | b  |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | a            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | VID_INTRA_ACCESS_TIMER    |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Video intra-access time for memory accesses (in XCLKs)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |              |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | PM_VID_INTRA_ACCESS_TIMER |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Video intra-access time for memory accesses<br>(in PM_XCLKs)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | PM_MEM_REFRESH_RATE       |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Refresh rate for Set depending on PM_XCLK frequency:<br>0000 = 10 to 49 MHz, 1 refresh every 156 PM_XCLKs<br>0001 = 50 to 65 MHz, 1 refresh every 781 PM_XCLKs<br>0010 = 66 to 74 MHz, 1 refresh every 1031 PM_XCLKs<br>0011 = 75 to 82 MHz, 1 refresh every 1172 PM_XCLKs<br>0100 = 83 to 89 MHz, 1 refresh every 1297 PM_XCLKs<br>0101 = 90 to 94 MHz, 1 refresh every 1406 PM_XCLKs<br>0110 = 95 to 99 MHz, 1 refresh every 1484 PM_XCLKs<br>0111 = 100 to 104 MHz, 1 refresh every 1563 PM_XCLKs<br>1000 = 105 to 109 MHz, 1 refresh every 1641 PM_XCLKs<br>1001 = 110 to 114 MHz, 1 refresh every 1719 PM_XCLKs<br>1010 = 115 to 119 MHz, 1 refresh every 1797 PM_XCLKs<br>1011 = 120 to 124 MHz, 1 refresh every 1875 PM_XCLKs<br>1100 = 125 to 132 MHz, 1 refresh every 1953 PM_XCLKs<br>1101 = 133 to 142 MHz, 1 refresh every 2078 PM_XCLKs<br>1110 = 143 to 165 MHz, 1 refresh every 2234 PM_XCLKs<br>1111 = 166 and above, 1 refresh every 2594 PM_XCLKs |              |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d    | R/W | VID_TIMER_MODE            |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Video timer mode<br>0 = Free running (independent)<br>1 = Relative to end of display burst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Cont'd |     | TIMER_CONFIG  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_0A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | e             |    |    | d  |    |    |    |    |    |    |    |    |    |    | c  |    |    |    |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |    |   |   |   |   |   | a |   |   |   |   |
| e      | R/W | PM_DSP_RW_SEL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Toggles register access/definition from XCLK display FIFO registers:<br>DSP_CONFIG, DSP_ON_OFF, DSP2_CONFIG, DSP2_ON_OFF,<br>VGA_DSP_CONFIG and VGA_DSP_ON_OFF to<br>PM_XCLK display FIFO registers (PM_DSP_CONFIG,<br>PM_DSP_ON_OFF, PM_DSP2_CONFIG,<br>PM_VGA_DSP_CONFIG, PM_VGA_DSP_ON_OFF)<br>These registers share the same offset<br>0 = Register read/writes go to XCLK version of display FIFO registers (default )<br>1 = Register read/writes go to PM_XCLK version of display FIFO registers |    |   |   |   |   |   |   |   |   |   |   |

### 4.1.5 Power Management Mode Registers (for RAGE XL only)

This mode is used only in the RAGE XL chip. The power management mode uses the following memory controller registers (denoted by the prefix PM\_). To use the slower version of XCLK, referred to as PM\_XCLK, set the requester activity in a specific state that is defined by the POWER\_MANAGEMENT\_2 registers.

The PM\_DSP\_RW\_SEL bit in TIMER\_CONFIG will select which display FIFO registers (which share the same offset) to access. For example:

- To access DSP\_ON/OFF, set PM\_DSP\_RW\_SEL=0.
- To access PM\_DSP\_ON/OFF, set PM\_DSP\_RW\_SEL=1 (for that register offset).

|      |     | PM_DSP_CONFIG       |    |    |    |    |    |    |    |    |    |    |    |                                                                                                   |    |    |    |    |    |    |    | Offset: 0_08 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
|------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|--------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |  |
| XL   |     | c                   |    |    |    |    |    |    |    |    |    |    |    | b                                                                                                 | d  |    | a  |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | PM_DSP_XCLKS_PER_QW |    |    |    |    |    |    |    |    |    |    |    | Amount of time (in PM_XCLKs) that one QWORD in the display FIFO occupies                          |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | PM_DSP_LOOP_LATENCY |    |    |    |    |    |    |    |    |    |    |    | Display FIFO control parameter (for PM_XCLK mode)                                                 |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | PM_DSP_PRECISION    |    |    |    |    |    |    |    |    |    |    |    | Integer.fraction precision point for (for PM_XCLK mode):<br>DSP_XCLKS_PER_QW<br>DSP_ON<br>DSP_OFF |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |

|      |     | PM_DSP_ON_OFF |    |    |    |    |    |    |    |    |    |    |    |                                                                    |    |    |    |    |    |    |    | Offset: 0_09 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|------|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------|----|----|----|----|----|----|----|--------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |
| XL   |     | b             |    |    |    |    |    |    |    |    |    |    |    | d                                                                  |    | a  |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| a    | R/W | PM_DSP_OFF    |    |    |    |    |    |    |    |    |    |    |    | The display memory request off threshold time in terms of PM_XCLKs |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| b    | R/W | PM_DSP_ON     |    |    |    |    |    |    |    |    |    |    |    | The display memory request on threshold time in terms of PM_XCLKs  |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |



|      |     | MEM_BUF_CNTL        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_0B                                                                                                                    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------------------------------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |
|      |     |                     |    |    |    |    |    |    |    |    |    | f  |    | e  |    |    |    | d  |    |                                                                                                                                 |    | c  |    |   |   | b |   |   |   | a |   |   |   |  |  |  |  |  |  |  |  |
| d    | R/W | HST_WB_FLUSH        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Host write buffer flush<br>000 = Flush when buffer is full<br>001-111 = Flush when [001-111] QWORDs are present in write buffer |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| e    | R/W | SCL_THRESH          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Scaler threshold<br>Maximum difference in QWORDs between Y, U and V components before switching                                 |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| f    | W   | INVALIDATE_RB_CACHE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Write a '1' to invalidate (clear) the readback cache                                                                            |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

|      |     | VGA_DSP_CONFIG       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                            |    |    |    |   |   |   |   |   | Offset: 0_13 |   |   |   |   |  |  |  |  |  |  |  |  |
|------|-----|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------------------------------------|----|----|----|---|---|---|---|---|--------------|---|---|---|---|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |
|      |     |                      |    |    |    |    |    |    |    |    |    | c  |    | b  |    |    |    |    |    |                                                                            |    |    |    |   |   |   |   | a |              |   |   |   |   |  |  |  |  |  |  |  |  |
| a    | R/W | VGA_DSP_XCLKS_PER_QW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Amount of time in XCLKs that one QWORD in the display FIFO occupies        |    |    |    |   |   |   |   |   |              |   |   |   |   |  |  |  |  |  |  |  |  |
| b    | R/W | VGA_DSP_PREC_PCLKBY2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Integer.fraction precision point for VGA_DSP_PREC_PCLK+1                   |    |    |    |   |   |   |   |   |              |   |   |   |   |  |  |  |  |  |  |  |  |
| c    | R/W | VGA_DSP_PREC_PCLK    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Integer.fraction precision point for DSP_XCLKS_PER_QW<br>DSP_ON<br>DSP_OFF |    |    |    |   |   |   |   |   |              |   |   |   |   |  |  |  |  |  |  |  |  |

|      |     | VGA_DSP_ON_OFF |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                 |    |    |    |   |   |   |   |   |   | Offset: 0_14 |   |   |   |  |  |  |  |  |  |  |  |
|------|-----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------|----|----|----|---|---|---|---|---|---|--------------|---|---|---|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |
|      |     |                |    |    |    |    |    |    |    |    |    | b  |    |    |    |    |    |    |    |                                                                 |    |    |    |   |   | a |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |
| a    | R/W | VGA_DSP_OFF    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | The display memory request off threshold time in terms of XCLKs |    |    |    |   |   |   |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |
| b    | R/W | VGA_DSP_ON     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | The display memory request on threshold time in terms of XCLKs  |    |    |    |   |   |   |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |

|      |     | MEM_ADDR_CONFIG  |    |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_0D |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|------------------|----|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     |                  |    |    |    | h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | g  | f  |    |    |    |    | e  |    |    |    |    | d  |    |    |    |              | c  |   |   |   |   | b |   |   |   |   | a |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | MEM_ROW_MAPPING  |    |    |    | Row Address Mapping: (default = 0)<br>MA: 12 11 10 9 8 7 6 5 4 3 2 1 0<br>0 = X A22 A21 A11 A20 A19 A18 A17 A16 A15 A14 A13 A12<br>1 = X A22 A11 A21 A20 A19 A18 A17 A16 A15 A14 A13 A12<br>2 = X A11 A22 A21 A20 A19 A18 A17 A16 A15 A14 A13 A12<br>3 = A22 A10 A21 A20 A19 A18 A17 A16 A15 A14 A13 A12 A11<br>4 = A10 A22 A21 A20 A19 A18 A17 A16 A15 A14 A13 A12 A11<br>5 - 7 = reserved                                                                                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | MEM_COL_MAPPING  |    |    |    | Column Address Mapping: (default = 0)<br>MA: 12 11 10 9 8 7 6 5 4 3 2 1 0<br>0 = A11 A11 A11 A11 A11 A10 A9 A8 A7 A6 A5 A4 A3<br>1 = A10 A10 A10 A10 A10 A9 A8 A7 A6 A5 A4 A3 A2<br>2 - 7 = reserved                                                                                                                                                                                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | MEM_GROUP_SIZE   |    |    |    | Memory group size:<br>00 = 2MB<br>01 = 4MB<br>10 = 8MB or 4MB 32 bit interface<br>11 = 8MB for 32 bit interface<br><br>This register field will be used in 11x8,12x8 and 13x8 SD/SGRAM configurations. Otherwise it is 00.<br>The SGRAM's address pins will connect to our chip as follows:<br>SGRAM's A0-A9 <=> RAGE XL's MA0-MA9<br>SGRAM's A10 <=> RAGE XL's CS2(2)<br>SGRAM's A11 <=> RAGE XL's CS2(3)<br>SGRAM's A12 <=> RAGE XL's DSF<br><br>For 4MB with 11x8 SGRAM, tie SGRAM's CS to low.<br>For 8MB with 11x8 SGRAM, tie SGRAM's CS to RAGE XL's CS0 and CS1. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d    | R/W | MEM_LATCHL       |    |    |    | Memory data latching mechanism for lower 32 bits:<br>00 = Inverted HCLK feedback by 2 (used for 2:1 SDR mode)<br>01 = HCLK feedback<br>10 = Positive edge of XCLK<br>11 = Negative edge of XCLK                                                                                                                                                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| e    | R/W | MEM_LATCHU       |    |    |    | Memory data latching mechanism for upper 32-bits:<br>00 = Reserved<br>01 = HCLK feedback<br>10 = Positive edge of XCLK<br>11 = Negative edge of XCLK                                                                                                                                                                                                                                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| f    | R/W | MEM_LATCH_ALWAYS |    |    |    | Dynamically controls read latching flops in memory data pads to reduce power<br>0 = Clock selected by MEM_LATCH[U L] only active during read cycles<br>1 = Clock selected by MEM_LATCH[U L] always active                                                                                                                                                                                                                                                                                                                                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Cont'd |     | MEM_ADDR_CONFIG |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                   |    |    |    |    |    |    |    |    |    |   |   |   |   | Offset: 0_0D |   |   |   |   |   |
|--------|-----|-----------------|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|--------------|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | h               | g  | f  |    |    | e  |    |    | d  |    |    |    |                                                                                                                                                   |    |    |    |    |    |    |    |    | c  |   |   | b |   |              | a |   |   |   |   |
| g      | R/W | MEM_CKE_ALWAYS  |    |    |    |    |    |    |    |    |    |    |    | Controls CKE signal to memory chip for power<br>0 = CKE pin always active except for power management modes<br>1 = CKE pin controlled dynamically |    |    |    |    |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |
| h      | R/W | MEM_REQ_LOCK    |    |    |    |    |    |    |    |    |    |    |    | Memory lock out control (default = 0)<br>0 = Unlocked<br>1 = Lock out requestors                                                                  |    |    |    |    |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |

**Table 4-2** Memory Combinations

| Memory Configuration | MEM_ROW_MAPPING | MEM_COL_MAPPING | MEM_GROUP_SIZE |
|----------------------|-----------------|-----------------|----------------|
| 10x8 SGRAM           | 0               | 0               | 0              |
| 11x8 SGRAM           | 1               | 0               | 1              |
| 12x8 SDRAM           | 2               | 0               | 2              |
| 12x8x16 Bit SDRAM    | 3               | 1               | 2              |
| 12x8x32 Bit SDRAM    | 4               | 1               | 3              |

**Table 4-3**

| Interface | Memory Device | MEM_ROW_MAPPING | MEM_COL_MAPPING | MEM_GROUP_SIZE |
|-----------|---------------|-----------------|-----------------|----------------|
| 64 bit    | 10x8x32 bit   | 0               | 0               | 0              |
| 64 bit    | 11x8x32 bit   | 1               | 0               | 1              |
| 64 bit    | 12x8x32 bit   | 2               | 0               | 2              |
| 64 bit    | 12x8x16 bit   | 2               | 0               | 2              |
| 32 bit    | 12x8x16 bit   | 3               | 1               | 2              |
| 32 bit    | 13x8x32 bit   | 4               | 1               | 3              |

## 4.1.6 Memory Control Registers

|      |     | MEM_CNTL      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |    |    |    |    |    |    |   |   |   |   |   |   |   | Offset: 0_2C |   |   |
|------|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|--------------|---|---|
| BITS |     | 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 |
|      |     | n             | m  | l  | k  |    |    | j  | i  | h  | g  | f  | e  | d  | c  | b  | a                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |    |    |    |    |    |   |   |   |   |   |   |   |              |   |   |
| a    | R/W | MEM_SIZE      |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Memory size:<br>0 = Reserved<br>1 = 1MB<br>2 = Reserved<br>3 = 2MB<br>4 - 6 = Reserved<br>7 = 4MB<br>8 = Reserved<br>9 = 6MB<br>10 = Reserved<br>11 = 8MB<br>12 - 15 = Reserved<br><b>Note:</b> Only the above sizes are implemented. Reserved settings are for future use according to the following:<br>a: Memory sizes for 0 to 7 increment by 0.5MB steps<br>b: Memory sizes for 8 - 11 increment by 1MB steps<br>c: Memory sizes for 12 - 15 increment by 2MB steps |    |    |    |    |    |    |   |   |   |   |   |   |   |              |   |   |
| b    | R/W | MEM_LATENCY   |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Memory read data latching delay from CAS:<br>(Typically same setting as MEM_CAS_LATENCY)<br>00 = 1 clock<br>01 = 2 clocks (DRAM setting or SDRAM CL=1)<br>10 = 3 clocks (SDRAM CL = 2)<br>11 = 4 clocks (SDRAM CL = 3)                                                                                                                                                                                                                                                   |    |    |    |    |    |    |   |   |   |   |   |   |   |              |   |   |
| c    | R/W | MEM_WDOE_CNTL |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Data pad output enable timing control (default = 00)<br>00 = 1 clock before write<br>01 = 1/2 clock before write<br>10 = 0 clock before write<br>11 = 1/2 clock after write                                                                                                                                                                                                                                                                                              |    |    |    |    |    |    |   |   |   |   |   |   |   |              |   |   |
| d    | R/W | MEM_TRP       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RAS precharge time, or PRE to ACTV time:<br>00 = 1 clock<br>01 = 2 clock<br>10 = 3 clock<br>11 = 4 clock                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |    |   |   |   |   |   |   |   |              |   |   |
| e    | R/W | MEM_TRCD      |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RAS to CAS delay, or ACTV to CMD time:<br>00 = 1 clock<br>01 = 2 clock<br>10 = 3 clock<br>11 = 4 clock                                                                                                                                                                                                                                                                                                                                                                   |    |    |    |    |    |    |   |   |   |   |   |   |   |              |   |   |
| f    | R/W | MEM_TCRD      |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CAS to RAS delay, provided primarily for EDO:<br>0 = no clock delay between CAS high and RAS high<br>1 = one clock delay between CAS high and RAS high                                                                                                                                                                                                                                                                                                                   |    |    |    |    |    |    |   |   |   |   |   |   |   |              |   |   |

| Cont'd |     | MEM_CNTL                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2C |    |   |   |                                                             |   |   |   |   |   |   |   |
|--------|-----|-----------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|----|---|---|-------------------------------------------------------------|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | n                                                         | m  | l  | k  |    | j  | i  | h  | g  | f  | e  | d  | c  | b  | a  |    |    |    |    |    |              |    |   |   |                                                             |   |   |   |   |   |   |   |
| g      | R/W | MEM_TR2W                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | Read to write delay                                         |   |   |   |   |   |   |   |
|        |     | 0 = 1 clock dead cycle between read to writes             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 = 2 clock dead cycles between read to writes              |   |   |   |   |   |   |   |
| h      | R/W | MEM_TWR                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | Write recovery time (default = 01)                          |   |   |   |   |   |   |   |
|        |     | 00 = 0 clock                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 01 = 1 clock                                                |   |   |   |   |   |   |   |
|        |     | 10 = 2 clock                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 11 = 3 clock                                                |   |   |   |   |   |   |   |
| i      | R/W | MEM_TRAS                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | RAS low minimum pulse width, or ACTV to PRE same bank:      |   |   |   |   |   |   |   |
|        |     | 000 = 1 clock                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 001 = 2 clock                                               |   |   |   |   |   |   |   |
|        |     | 010 = 3 clock                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 011 = 4 clock                                               |   |   |   |   |   |   |   |
|        |     | 100 = 5 clock                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 101 = 6 clock                                               |   |   |   |   |   |   |   |
|        |     | 110 = 7 clock                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 111 = 8 clock                                               |   |   |   |   |   |   |   |
| j      | R/W | MEM_REFRESH_DIS                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | Disable memory refresh                                      |   |   |   |   |   |   |   |
|        |     | 0 = Enable                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 = Disable                                                 |   |   |   |   |   |   |   |
|        |     | <b>NOTE:</b> Must be turned off in shared configurations. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |                                                             |   |   |   |   |   |   |   |
| k      | R/W | MEM_REFRESH_RATE                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | Set memory refresh rate (depends on XCLK frequency)         |   |   |   |   |   |   |   |
|        |     | 0000 = 10 to 49 MHz                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 156 XCLKs                                   |   |   |   |   |   |   |   |
|        |     | 0001 = 50 to 65 MHz                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 781 XCLKs                                   |   |   |   |   |   |   |   |
|        |     | 0010 = 66 to 74 MHz                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 1031 XCLKs                                  |   |   |   |   |   |   |   |
|        |     | 0011 = 75 to 82 MHz                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 1172 XCLKs                                  |   |   |   |   |   |   |   |
|        |     | 0100 = 83 to 89 MHz                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 1297 XCLKs                                  |   |   |   |   |   |   |   |
|        |     | 0101 = 90 to 94 MHz                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 1406 XCLKs                                  |   |   |   |   |   |   |   |
|        |     | 0110 = 95 to 99 MHz                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 1484 XCLKs                                  |   |   |   |   |   |   |   |
|        |     | 0111 = 100 to 104MHz                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 1563 XCLKs                                  |   |   |   |   |   |   |   |
|        |     | 1000 = 105 to 109 MHz                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 1641 XCLKs                                  |   |   |   |   |   |   |   |
|        |     | 1001 = 110 to 114 MHz                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 1719 XCLKs                                  |   |   |   |   |   |   |   |
|        |     | 1010 = 115 to 119 MHz                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 1797 XCLKs                                  |   |   |   |   |   |   |   |
|        |     | 1011 = 120 to 124 MHz                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 1875 XCLKs                                  |   |   |   |   |   |   |   |
|        |     | 1100 = 125 to 132 MHz                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 1953 XCLKs                                  |   |   |   |   |   |   |   |
|        |     | 1101 = 133 to 142 MHz                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 2078 XCLKs                                  |   |   |   |   |   |   |   |
|        |     | 1110 = 143 to 165 MHz                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 2234 XCLKs                                  |   |   |   |   |   |   |   |
|        |     | 1111 = 166 MHz and above                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 1 refresh every 2594 XCLKs                                  |   |   |   |   |   |   |   |
| l      | R/W | LOWER_APER_ENDIAN                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | Lower aperture 'byte endian' sense (0 - 8MB): (default = 0) |   |   |   |   |   |   |   |
|        |     | 00 = Little endian: no swapping                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 01 = Big endian: 16 bpp swapping                            |   |   |   |   |   |   |   |
|        |     | 10 = Big endian: 32 bpp swapping                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   | 11 = Reserved                                               |   |   |   |   |   |   |   |

| Cont'd |     | MEM_CNTL          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2C                                                                                                                                                                               |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | n                 | m  | l  | k  |    |    | j  | i  | h  | g  | f  | e  | d  | c  | b  | a  |    |    |    |    |                                                                                                                                                                                            |    |   |   |   |   |   |   |   |   |   |   |
| m      | R/W | UPPER_APER_ENDIAN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Upper aperture 'byte endian' sense (8 - 16MB): (default = 0)<br>00 = Little endian: (no swapping)<br>01 = Big endian: 16 bpp swapping<br>10 = Big endian: 32 bpp swapping<br>11 = Reserved |    |   |   |   |   |   |   |   |   |   |   |
| n      | R/W | MEM_PAGE_SIZE     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Memory Page Size: (default = 01)<br>00 = 2KB<br>01 = 4KB<br>10 = 8KB<br>11 = 16KB                                                                                                          |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register configures the on-chip memory interface unit.

### Usage

This register is normally configured only by the adapter ROM during the power-up initialization. Applications should touch only the MEM\_BNDRY and MEM\_BNDRY\_EN fields for relocating the memory boundary between the accelerator and VGA.

### See Also

*mach64* Programmer's Guide:

- *Linear Aperture: VGA Interaction*
- *Advanced Topics: Boot-time Initialization*

|      |     | EXT_MEM_CNTL                                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Offset: 0_2B                                                 |   |   |   |   |   |   |   |
|------|-----|-------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------------------------------------------------------------|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | y                                                                                                                             | x  | w  | v  | u  |    | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  | h  | g  | f  | e  | d | c | b                                                            | a |   |   |   |   |   |   |
| a    | R/W | MEM_TBWC                                                                                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Set block write cycle control                                |   |   |   |   |   |   |   |
|      |     | 0 = 1 clock block write                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 1 = 2 clock block write (previous default)                   |   |   |   |   |   |   |   |
| b    | R/W | MEM_SDRAM_RESET                                                                                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Invoke reset of SDRAM on transition from 0 to 1              |   |   |   |   |   |   |   |
|      |     | 0 = Normal                                                                                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 1 = Reset                                                    |   |   |   |   |   |   |   |
|      |     | See note below for resetting SDRAM.                                                                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | * sends sequence to SDRAM consisting of PALL, 8 refresh, MRS |   |   |   |   |   |   |   |
|      |     | After writing a '1', ensure to write a '0' before next reset.                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | This bit has no effect in shared configurations.             |   |   |   |   |   |   |   |
| c    | R/W | MEM_CYC_TEST                                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Invoke memory cycle test mode.                               |   |   |   |   |   |   |   |
|      |     | (note: the chip WILL NOT FUNCTION NORMALLY in this mode)                                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 00 = Normal operation (default)                              |   |   |   |   |   |   |   |
|      |     | 01 = Reserved                                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 10 = Test mode initiate                                      |   |   |   |   |   |   |   |
|      |     | 11 = Test mode sequence run. After test sequence finished, to run another cycle test, this field must be first reset to '10'. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                              |   |   |   |   |   |   |   |
| d    | R/W | MEM_MA_YCLK                                                                                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Output clock select for MA pins                              |   |   |   |   |   |   |   |
|      |     | 0 = Propagate off of XCLK                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 1 = Propagate off of YCLK                                    |   |   |   |   |   |   |   |
| e    | R/W | MEM_CNTL_YCLK                                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Output clock select for RAS, CAS, WE and CKE pins            |   |   |   |   |   |   |   |
|      |     | 0 = Propagate off of XCLK                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 1 = Propagate off of YCLK                                    |   |   |   |   |   |   |   |
| f    | R/W | MEM_CS_YCLK                                                                                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Output clock select for CS pins                              |   |   |   |   |   |   |   |
|      |     | 0 = Propagate off of XCLK                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 1 = Propagate off of YCLK                                    |   |   |   |   |   |   |   |
| g    | R/W | MEM_EXTND_ERST                                                                                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Extend enable reset (for MD pad) by 1 clock cycle:           |   |   |   |   |   |   |   |
|      |     | (default = 1)                                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0 = No extension                                             |   |   |   |   |   |   |   |
|      |     | 1 = Extend                                                                                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                              |   |   |   |   |   |   |   |
| h    | R/W | MEM_ERST_CNTL                                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable reset (for MD pad) timing control: (default = 00)     |   |   |   |   |   |   |   |
|      |     | 00 = (CL - 1) clocks                                                                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 01 = (CL - 1/2) clocks                                       |   |   |   |   |   |   |   |
|      |     | 10 = CL clock                                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 11 = Always enabled                                          |   |   |   |   |   |   |   |
| i    | R/W | MEM_CAS_LATENCY                                                                                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Memory latency between CAS and data present                  |   |   |   |   |   |   |   |
|      |     | Typically, same setting as MEM_CAS_LATENCY                                                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 00 = 1 clock                                                 |   |   |   |   |   |   |   |
|      |     | 01 = 2 clocks (SDRAM CL = 1)                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 10 = 3 clocks (SDRAM CL = 2)                                 |   |   |   |   |   |   |   |
|      |     | 11 = 4 clocks (SDRAM CL = 3)                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                              |   |   |   |   |   |   |   |

| Cont'd |     | EXT_MEM_CNTL        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2B                                                                                               |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | y                   | x  | w  | v  |    | u  |    | t  | s  |    | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  |                                                                                                            | h  | g | f | e | d | c | b | a |   |   |   |
| j      | R/W | MEM_SSTL_EN         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Interface select for MD pins<br>0 = LVTTL interface<br>1 = SSTL interface                                  |    |   |   |   |   |   |   |   |   |   |   |
| k      | R/W | MEM_MD_REC          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Receiver select for MD pins<br>0 = Hysteresis receiver<br>1 = Differential receiver                        |    |   |   |   |   |   |   |   |   |   |   |
| l      | R/W | MEM_HCLK_DRIVE      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Boost drive strength of HCLK pin<br>0 = No boost<br>1 = Boost                                              |    |   |   |   |   |   |   |   |   |   |   |
| m      | R/W | MEM_CS_DRIVE        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Boost drive strength of CS pins<br>0 = No boost<br>1 = Boost                                               |    |   |   |   |   |   |   |   |   |   |   |
| n      | R/W | MEM_MDA_DRIVE       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Boost drive strength of upper 32 MD pins not connected to BIOS<br>(49, 52-55)<br>0 = No boost<br>1 = Boost |    |   |   |   |   |   |   |   |   |   |   |
| o      | R/W | MEM_MDB_DRIVE       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Boost drive strength of pins not connected to BIOS (32-48, 50-51,<br>56-63)<br>0 = No boost<br>1 = Boost   |    |   |   |   |   |   |   |   |   |   |   |
| p      | R/W | MEM_MDL_DRIVE       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Boost drive strength of low 32 MD pins (0-31)<br>0 = No boost<br>1 = Boost                                 |    |   |   |   |   |   |   |   |   |   |   |
| q      | R/W | MEM_GROUP_CHANGE_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable group change signaling: (default = 0)<br>0 = Disable<br>1 = Enable                                  |    |   |   |   |   |   |   |   |   |   |   |
| r      | R/W | MEM_MA_DRIVE        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Boost drive strength of MA pins<br>0 = No boost<br>1 = Boost                                               |    |   |   |   |   |   |   |   |   |   |   |
| s      | R/W | MEM_CNTL_DRIVE      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Boost drive strength of RAS, CAS, WE, DSF pins<br>0 = No boost<br>1 = Boost                                |    |   |   |   |   |   |   |   |   |   |   |
| t      | R/W | MEM_DQM_DRIVE       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Boost drive strength of DQM pins<br>0 = No boost<br>1 = Boost                                              |    |   |   |   |   |   |   |   |   |   |   |

| Cont'd |     | EXT_MEM_CNTL       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Offset: 0_2B                             |                                                                                                                         |   |   |   |   |   |   |  |  |  |  |
|--------|-----|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|--|--|--|--|
| BITS   |     | 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 |  |  |  |  |
|        |     | y                  | x  | w  | v  |    | u  |    | t  | s  |    | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  | h  | g  | f | e | d                                        | c                                                                                                                       | b | a |   |   |   |   |  |  |  |  |
| u      | R/W | MEM_GCMRS          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Set mode for graphics controller (SDRAM) |                                                                                                                         |   |   |   |   |   |   |  |  |  |  |
|        |     |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | Bit (1:0)                                                                                                               |   |   |   |   |   |   |  |  |  |  |
|        |     |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | 00 = Burst length of 1 (not always valid)<br>01 = Burst length of 2<br>10 = Burst length of 4<br>11 = Burst length of 8 |   |   |   |   |   |   |  |  |  |  |
|        |     |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | Bit (2)                                                                                                                 |   |   |   |   |   |   |  |  |  |  |
|        |     |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | 0 = Sequential<br>1 = Interleave                                                                                        |   |   |   |   |   |   |  |  |  |  |
|        |     |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | Bit (3)                                                                                                                 |   |   |   |   |   |   |  |  |  |  |
|        |     |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | 0 = Burst read and burst write<br>1 = Burst read and single write                                                       |   |   |   |   |   |   |  |  |  |  |
| v      | R   | MEM_CS_STRAP       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | Chip select enable/disable strap read at hardware reset (read only)                                                     |   |   |   |   |   |   |  |  |  |  |
|        |     |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | 0 = Enable CS pins (strap MD(47) to VCC)<br>1 = Disable CS pins (no strap on MD(47), built-in pull-down)                |   |   |   |   |   |   |  |  |  |  |
|        |     |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | Forced to 0 (enable) in UMA mode.                                                                                       |   |   |   |   |   |   |  |  |  |  |
| w      | R/W | SDRAM_MEM_CFG      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | Select configuration of RAS, CAS & CS pins in SDRAM and SGRAM                                                           |   |   |   |   |   |   |  |  |  |  |
|        |     |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | 0 = 2 RAS, 2 CAS, 2 CS<br>1 = 1 RAS, 1 CAS, 4 CS                                                                        |   |   |   |   |   |   |  |  |  |  |
| x      | R/W | MEM_ALL_PAGE_DIS   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | Controls all page memory cycles                                                                                         |   |   |   |   |   |   |  |  |  |  |
|        |     |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | 0 = Enable<br>1 = Disable                                                                                               |   |   |   |   |   |   |  |  |  |  |
| y      | R/W | MEM_GROUP_FAULT_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | Controls page faulting between 2MB groups                                                                               |   |   |   |   |   |   |  |  |  |  |
|        |     |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | 0 = Enable<br>1 = Disable                                                                                               |   |   |   |   |   |   |  |  |  |  |

### Usage

Changes in settings to this register will not take affect until MEM\_SDRAM\_RESET is pulsed (from 0 → 1).

The sequence should be as follows:

1. Write EXT\_MEM\_CNTL with the desired settings, setting MEM\_SDRAM\_RESET = 0 (use readmodify/write).
2. Rewrite EXT\_MEM\_CNTL, setting MEM\_SDRAM\_RESET = 1.
3. Rewrite EXT\_MEM\_CNTL, setting MEM\_SDRAM\_RESET = 0 (clear reset bit).

In order to reset SDRAM, the following steps must be performed:

1. Set MEM\_SDRAM\_RESET to '1'

2. Set MEM\_CYC\_TEST to ‘10’
3. Set MEM\_CYC\_TEST to ‘11’. Wait at least 3ns.
4. Set MEM\_CYC\_TEST to ‘00’
5. Set MEM\_SDRAM\_RESET to ‘0’

|      |     | MEM_VGA_WP_SEL |    |    |    |    |    |    |    |    |    |    |    |                                                                   |    |    |    |    |    |    |    |    |    |   |   |   | Offset: 0_2D |   |   |   |   |   |   |              |
|------|-----|----------------|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|--------------|---|---|---|---|---|---|--------------|
| BITS |     | 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 | Offset: 0_2D |
|      |     | b              |    |    |    |    |    |    |    |    |    |    |    | a                                                                 |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |              |
| a    | R/W | MEM_VGA_WPS0   |    |    |    |    |    |    |    |    |    |    |    | Write page pointer for lower 32KB aperture into 8MB video memory. |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |              |
| b    | R/W | MEM_VGA_WPS1   |    |    |    |    |    |    |    |    |    |    |    | Write page pointer for upper 32KB aperture into 8MB video memory. |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |              |

### Description

This register contains the two write page pointers used for the two small 32K apertures at 0xA000 and 0xA800. Pages are selectable only on 32K boundaries. These write pages are independent of the read pages.

### Usage

This register is needed only when writing to the small apertures. Small apertures are required only if the big linear aperture is not available. The big linear aperture may not be available on ISA configurations.

Apertures exist only in accelerator modes, and only if CFG\_MEM\_VGA\_AP\_EN@CONFIG\_CNTL is set. VGA apertures are not supported if CFG\_BUS\_TYPE = PCI. A 4M or 8M linear aperture must be used for PCI bus implementation.

### See Also

CONFIG\_CNTL on [page 4-32](#)

MEM\_VGA\_RP\_SEL on [page 4-24](#)

*mach64* Programmer’s Guide:

- *Getting Started: Linear Aperture vs. VGA Aperture*

|      |     | MEM_VGA_RP_SEL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                  |    |    |    |    |    |   |   |   | Offset: 0_2E |   |   |   |   |   |   |
|------|-----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------|----|----|----|----|----|---|---|---|--------------|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | b              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                                                                |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |
| a    | R/W | MEM_VGA_RPS0   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Read page pointer for lower 32KB aperture into 8MB video memory. |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |
| b    | R/W | MEM_VGA_RPS1   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Read page pointer for upper 32KB aperture into 8MB video memory. |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |

### Description

This register contains the two read page pointers used for the two small 32K apertures at 0xA000 and 0xA800. Pages are selectable only on 32K boundaries. These read pages are independent of the write pages.

### Usage

This register is needed only when writing to the small apertures. Small apertures are required only if the big linear aperture is not available. The big linear aperture may not be available on ISA configurations.

Apertures exist only in accelerator modes, and only if CFG\_MEM\_VGA\_AP\_EN@CONFIG\_CNTL is set. VGA apertures are not supported if CFG\_BUS\_TYPE = PCI. A 4M or 8M linear aperture must be used for PCI bus implementation.

### See Also

CONFIG\_CNTL on [page 4-32](#)

MEM\_VGA\_WP\_SEL on [page 4-23](#)

*mach64* Programmer's Guide:

- *Getting Started: Linear Aperture vs. VGA Aperture*

## 4.1.7 Test and Debug

|      |     | GEN_TEST_CNTL    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |   |   |   |   | Offset: 0_34 |   |   |   |   |   |   |  |  |  |   |  |  |  |   |  |  |  |
|------|-----|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|---|---|---|---|--------------|---|---|---|---|---|---|--|--|--|---|--|--|--|---|--|--|--|
| BITS |     | 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 |   |  |  |  |   |  |  |  |   |  |  |  |
|      |     | k                |    |    |    | j  |    |    |    | i  |    |    |    | h  |    |    |    | g               |    |    |    | f  |    |   |   | e |   |              |   | d |   |   |   | c |  |  |  | b |  |  |  | a |  |  |  |
| a    | R/W | GEN_ICON2_ENABLE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | (NOT supported) |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |   |  |  |  |   |  |  |  |   |  |  |  |

| Cont'd   |     | GEN_TEST_CNTL      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_34                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|----------|-----|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| BITS     |     | 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 |  |  |  |  |
|          |     | k                  |    |    |    | j  |    | i  |    | h  |    | g  |    | f  | e  | d  | c  | b  | a  |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| <b>b</b> | R/W | GEN_CUR2_ENABLE    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | (NOT supported)                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| <b>c</b> | R/W | GEN_ICON_ENABLE    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable hardware icon: (default = 0). <b>MUST set to 0.</b><br>0 = Disable<br>1 = Enable                                                                                                                                                                                                                                                                                                                                                                                           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| <b>d</b> | R/W | GEN_CUR_ENABLE     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable hardware cursor*: (default = 0)<br>0 = Disable<br>1 = Enable                                                                                                                                                                                                                                                                                                                                                                                                               |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| <b>e</b> | R/W | GEN_GUI_RESETB     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Reset GUI engine on high to low transition: (default = 0)<br>0 = Normal operation<br>1 = Reset                                                                                                                                                                                                                                                                                                                                                                                    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| <b>f</b> | R/W | GEN_SOFT_RESET     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Reset the memory controller: (default = 0)<br>0 = Normal operation<br>1 = Reset                                                                                                                                                                                                                                                                                                                                                                                                   |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| <b>g</b> | R/W | GEN_MEM_TRISTATE   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Tristate memory interface signals<br>0 = Normal operation<br>1 = Tristate memory interface signals                                                                                                                                                                                                                                                                                                                                                                                |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| <b>h</b> | R/W | GEN_TEST_VECT_MODE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Test Vector Mode (default = 0)<br>0 = Normal<br>1 = Reserved<br>2 = Reserved<br>3 = IDDQ Test Mode: I/O pull-ups and pull-downs disabled                                                                                                                                                                                                                                                                                                                                          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| <b>i</b> | R/W | GEN_TEST_MODE      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Set test mode:<br>0000 = Disable test mode<br>0001 = Reserved<br>0010 = Reserved<br>0011 = Palette2 test<br>0100 = RAMDAC2 functional test<br>0101 = Video port window test<br>0110 = Command FIFO test (lock the FIFO)<br>0111 = DEBUG mode select (see: GEN_DEBUG_MODE)<br>1000 = Ring oscillator test<br>1001 = Delay path test<br>1010 = Register block test<br>1011 = PLL test<br>1100 = Palette test<br>1101 = DAC test<br>1110 = RAMDAC functional test<br>1111 = Reserved |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| <b>j</b> | R/W | GEN_CRC_EN         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable both CRC and CRC2 signature block: (default = 0)<br>0 = Disable<br>1 = Enable                                                                                                                                                                                                                                                                                                                                                                                              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

| Cont'd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     | GEN_TEST_CNTL  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_34 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------------|--|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     | BITS           |  | 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 |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     | k              |  |    |    | j  |    | i  |    |    |    | h  |    |    |    | g  |    | f  | e  | d            | c  | b  | a  |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| <b>k</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R/W | GEN_DEBUG_MODE |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| Select debug mode:<br>00 = Memory cycle debug<br>01 = Display debug<br>02 = reserved<br>03 = SDRAM state machine debug<br>04 = Display2 debug<br>05 = Memory 2:1 debug<br>06 = ROM Controller debug<br>07 - 0F = Reserved<br>10 = HBIU host request signals<br>11 = HBIU slave state machine signals<br>12 = HBIU buffer control signals<br>13 = HBIU bus master state machine signals<br>14 = HBIU bus master status flags<br>15 - 1F = Reserved<br>20 = Top guien pipe<br>21 = Bottom of guien pipe<br>22 = 3D interface to guien<br>23 - 29 = GUI stuff<br>2A - 2B = MC/IDCT parser<br>2C - 2E = MC/IDCT buffer control<br>2F = Reserved<br>30 = GUI write buffer<br>31 = Host write buffer<br>32 = Video write buffer<br>33 = GUI read request<br>34 = Read buffer bus master<br>35 - 3F = Reserved<br>4x = LCD engine debug<br>5x = Display engine<br>60 - 6F = AGP debug<br>7x = Power management states<br>8x = Palette read/write state machine debug<br>90 = IDCT1 (9:0)<br>91 = IDCT2 (10:1)<br>92 = IDCT3 (10 - 7:0)<br>93 - 9F = Reserved<br>Ax = APC debug<br>Bx = TMDS debug<br>Cx = Subpic debug<br>Dx = Scaler debug<br>E0 - FF = Reserved |     |                |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |

### Description

This register is used for general control and diagnostic control. Most of the test modes are only used during ASIC testing or for debugging purposes.

- Bit [4] enables the second hardware icon. (**NOT supported**)
- Bit [5] enables the second hardware cursor. (**NOT supported**)
- Bit [6] (or bit [5] in LCD\_GEN\_CTRL, backward compatibility) enables the hardware icon.
- Bit [7] enables the hardware cursor.
- Bit [8] resets the Draw engine.
- Bits [19:16] enable various test modes of the ASIC.
- Bit [21] enables the cyclic redundancy checkers (CRC and CRC2).
- Bits [31:24] enable various debug modes of the ASIC.

### ***Usage***

The DAC and memory configuration should be touched only by the adapter BIOS. Similarly, the diagnostic fields should be touched only by the diagnostic programs.

Application level programs should touch only the following bits:

GEN\_ICON\_ENABLE  
GEN\_CUR\_ENABLE

For GEN\_DEBUG\_MODE, it is required to set GPIO\_DIR1 through GPIO\_DIRA to 1's in order to see the selected debug mode.

### ***See Also***

*mach64* Programmer's Guide:

- *Engine Initialization: FIFO Queue: Resetting the FIFO*
- *Engine Operations: Miscellaneous Operations: Hardware Cursor*
- *Advanced Topics: Boot-time Initialization*
- *Advanced Topics: Accessing the EEPROM*
- *Advanced Topics: DAC Programming*

| CRC_SIG |   |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                                    |   |   |   |   |   |
|---------|---|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|------------------------------------|---|---|---|---|---|
| BITS    |   | 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 |
|         |   | a       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                                    |   |   |   |   |   |
| a       | R | CRC_SIG |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | CRC signature value: (default = 0) |   |   |   |   |   |

**Description**

This register is used to accumulate the display CRC check.

**Usage**

Use this register for diagnostics of the CRTC, DAC, hardware cursor, and overscan.

**See Also**

GEN\_TEST\_CNTL on [page 4-24](#)

(NOT supported in RAGE XL)

| CRC2_SIG |   |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                                               |   |   |   |   |   |  |
|----------|---|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----------------------------------------------|---|---|---|---|---|--|
| BITS     |   | 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 |  |
|          |   | a        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                                               |   |   |   |   |   |  |
| a        | R | CRC2_SIG |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | Second DAC CRC signature value: (default = 0) |   |   |   |   |   |  |

**Description**

This register accumulates the signature for the second display CRC.

**Usage**

Use this register to perform diagnostics on the second CRTC, DAC, hardware cursor, and overscan. Before reading this register, set CRTC\_RW\_SELECT = 1.

|      |     | HW_DEBUG               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |                                                                                                                                      | Offset: 0_1F                                                                                                                                   |   |   |   |
|------|-----|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|
| BITS |     | 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 |
|      |     | D                      | C  | B  | A  | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  | h | g | f | e | d | c                                                                                                                                    | b                                                                                                                                              | a |   |   |
| a    | R/W | BYPASS_SUBPIC_DBF      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |                                                                                                                                      | Bypass double buffering of overlay/scaler/subpic registers: (default = 0)<br>0 = Do not bypass double buffering<br>1 = Bypass double buffering |   |   |   |
| b    | R/W | GRPH_AB_YUV_FIX_DIS    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |                                                                                                                                      | Graphic alpha blender YUV fix disable<br>0 = Graphic data are converted to YCrCb (default)<br>1 = Graphic data remain in RGB format            |   |   |   |
| c    | R/W | DISP_QW_FIX_DIS        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Enable extra display qword fix<br>1 = Disable extra display qword fix                                                            |                                                                                                                                                |   |   |   |
| d    | R/W | FRAM_DET_EN            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Enable frame detection when RAGE Theater is used with RAGE XL<br>0 = Disable frame detection<br>1 = Enable frame detection           |                                                                                                                                                |   |   |   |
| e    | R/W | GUI_BEATS_HOST         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Set arbitration between host and GUI request channels<br>0 = Normal operation<br>1 = Lock out arbitration to host when GUI is active |                                                                                                                                                |   |   |   |
| f    | R/W | INTER_BLIT_FIX_DIS     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Enable inter-blit performance improvement<br>1 = Disable inter-blit performance improvement                                      |                                                                                                                                                |   |   |   |
| g    | R/W | INTER_PRIM_DIS         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Enable fast-fill/block-write scissoring<br>1 = Disable fast-fill/block-write scissoring                                          |                                                                                                                                                |   |   |   |
| h    | R/W | SRC_TRACK_DST_DIS      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Enable SRC_TRACK_DIS fix<br>1 = Disable SRC_TRACK_DIS fix                                                                        |                                                                                                                                                |   |   |   |
| i    | R/W | AUTO_BLKWRIT_COLOR_DIS |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Enable auto-color register updates for block writes<br>1 = Disable auto-color register updates for block writes                  |                                                                                                                                                |   |   |   |
| j    | R/W | INTER_LINE_OVERLAP_DIS |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Enable inter-line overlapping<br>1 = Disable inter-line overlapping                                                              |                                                                                                                                                |   |   |   |
| k    | R/W | DBL_BUFFER_EN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Disable double buffering feature<br>1 = Enable double buffering feature                                                          |                                                                                                                                                |   |   |   |
| l    | R/W | CMDFIFO_SIZE_MODE_EN   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Disable CMDFIFO size change<br>1 = Enable CMDFIFO size change                                                                    |                                                                                                                                                |   |   |   |
| m    | R/W | AUTO_FF_DIS            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Enable auto-fast-fills<br>1 = Disable auto-fast-fills                                                                            |                                                                                                                                                |   |   |   |
| n    | R/W | AUTO_BLKWRIT_DIS       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Enable auto-block writes<br>1 = Disable auto-block writes                                                                        |                                                                                                                                                |   |   |   |
| o    | R/W | ORed_INVLDRB_CACHE     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = invalidate the readback cache<br>1 = invalidate the readback cache<br>(ORed with INVALIDATE_RB_CACHE pulse)                      |                                                                                                                                                |   |   |   |

| Cont'd |     | HW_DEBUG                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      | Offset: 0_1F                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |
|--------|-----|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | D                          | C  | B  | A  | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  | h | g | f                                                    | e                                                                                                                                                                                                                                                                                                                                                                                                   | d | c | b | a |   |   |
| p      | R/W | BLOCK_DBL_BUF              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Blocks double-buffering of CRTC_OFFSET value if set. |                                                                                                                                                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |
| q      | R/W | HCLK_FB_SKEW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      | 000 = Earliest<br>111 = Latest<br>64 bit memory interface :<br>HCLK feedback skew adjustement for memory read data latching<br>This register only has an effect when MEM_LATCHL and<br>MEM_LATCHU @ MEMCNTL = 01<br>32 bit memory interface :<br>XCLKb feedback skew adjustement for memory read data latching<br>This register only has an effect when MEM_LATCHL and<br>MEM_LATCHU @ MEMCNTL = 11 |   |   |   |   |   |   |
| r      | R/W | MCLK_START_EN              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      | 0 = Do not start MCLK during VBLANK<br>1 = Restart MCLK during VBLANK when host write buffer is not empty (default)                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |
| s      | R/W | SEL_VBLANK_DBL_BUF         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      | 0 = VBLANK_BIT2 will output the state of VBLANK<br>1 = VBLANK_BIT2 will output the state of the CRTC_OFFSET double buffering status                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |
| t      | R/W | CMD FIFO2_EN               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      | Control of GUI bus mastering path. Must be set to 1 if IDCT_EN bit is set to 1.<br>0 = cmdfifo2 and mcidctparser are not in the path (default).<br>1 = cmdfifo2 and mcidctparser are in the path                                                                                                                                                                                                    |   |   |   |   |   |   |
| u      | R/W | BM_FIX_DIS                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      | 0 = Enable bus master mode<br>1 = Disable bus master mode                                                                                                                                                                                                                                                                                                                                           |   |   |   |   |   |   |
| v      | R/W | Z_SWITCH_EN                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      | 0 = Do not flush the z-buffer before accepting new data<br>1 = Flush the z-buffer before accepting new data                                                                                                                                                                                                                                                                                         |   |   |   |   |   |   |
| w      | R/W | FLUSH_HOST_WB              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      | 0 = Do not flush the host write buffer<br>1 = Flush the host write buffer                                                                                                                                                                                                                                                                                                                           |   |   |   |   |   |   |
| x      | R/W | HW_DEBUG_WRITE_MSK_FIX_DIS |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      | 0 = Enable write mask fix<br>1 = Disable write mask fix                                                                                                                                                                                                                                                                                                                                             |   |   |   |   |   |   |
| y      | R/W | Z_NO_WRITE_EN              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      | 0 = Do not write to the memory when Z compare fails (default)<br>1 = Write to memory when Z compare fails enable                                                                                                                                                                                                                                                                                    |   |   |   |   |   |   |
| z      | R/W | DONT_RST_PCLK              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      | 0 = Enable resetting of PCLK (default)<br>1 = Disable resetting of PCLK                                                                                                                                                                                                                                                                                                                             |   |   |   |   |   |   |
| A      | R/W | PM_D3_SUPPORT_EN           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      | 0 = Disable D3 mode<br>1 = Enable D3 mode (default)                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |
| B      | R/W | DONT_RST_CHAREN            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      | To be used in VGA mode if panel connected only<br>0 = Enable resetting of character enable<br>1 = Disable resetting of character enable (default)                                                                                                                                                                                                                                                   |   |   |   |   |   |   |

| Cont'd |     | HW_DEBUG      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_1F                                                                                                                |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | D             | C  | B  | A  | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j                                                                                                                           | i  | h | g | f | e | d | c | b | a |   |   |
| C      | R/W | BM_HOSTRA_EN  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Disable prevention of slave reads between BM cycles (default)<br>1 = Enable prevention of slave reads between BM cycles |    |   |   |   |   |   |   |   |   |   |   |
| D      | R   | AGP_RDCIP_DIS |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = AGP read cycles are ignored during PCI bm<br>1 = AGP read cycles are granted during PCI bm                              |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register is used for debugging hardware. The BIOS will set this register correctly and no other drivers or applications should use it.

|      |     |             | CRT_HORZ_VERT_LOAD |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       | MM: 1_51 |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|-------------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|----------|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | f           | e                  | d  | c  |    |    |    |    | b  |    |    |    |    |    |    |    |    |    |    |    | a                     |          |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | VCNTR_VALUE |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Vertical count        |          |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | HCNTR_VALUE |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Horizontal count      |          |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | HCNTR_LOAD  |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Horizontal count load |          |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d    | R/W | VCNTR_LOAD  |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Vertical count load   |          |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| e    | R/W | EOL_STOP    |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | End of line stop      |          |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| f    | R/W | EOF_STOP    |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | End of field stop     |          |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### Description

This register affects the CRT controller, but was not put in Block 0 for backward compatibility (there is no block I/O mapping for this register).

### Usage

Use this register for ASIC test purposes.

## 4.1.8 Configuration Registers

|      |     | CONFIG_CNTL       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                            |    |    |    |   |   |   | Offset: 0_37 |   |   |   |   |   |   |
|------|-----|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|---|---|---|--------------|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                            |    |    |    |   |   |   |              |   |   |   |   |   |   |
| a    | R   | CFG_MEM_AP_SIZE   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Linear memory aperture size: (default = 10)<br>00 = Reserved<br>01 = Reserved<br>10 = 2x8MB apertures<br>11 = Reserved                                     |    |    |    |   |   |   |              |   |   |   |   |   |   |
| b    | R/W | CFG_MEM_VGA_AP_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Register mapping to VGA aperture (Default = 0)<br>0 = Memory mapped registers not in VGA aperture<br>1 = Memory mapped registers available in VGA aperture |    |    |    |   |   |   |              |   |   |   |   |   |   |
| c    | R   | CFG_MEM_AP_LOC    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Linear memory aperture location on 16MB boundary (bits 5:0 = 00)                                                                                           |    |    |    |   |   |   |              |   |   |   |   |   |   |
| d    | R/W | CFG_VGA_DIS       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Disable VGA: (default = 0)<br>0 = Enable if CFG_VGA_EN@CONFIG_STAT0 = 1<br>1 = Disable                                                                     |    |    |    |   |   |   |              |   |   |   |   |   |   |

### Description

This register configures the linear memory aperture and for soft configuration of multiple *mach64* systems. The aperture size (CFG\_MEM\_AP\_SIZE) is always set to 2x8 MB, and the location (CFG\_MEM\_AP\_LOC) is fixed by the PCI configuration space (see [Chapter 6](#)). These two fields of the CONFIG\_CNTL register are read-only for PCI systems.

### Usage

Aperture configuration should be done in the adapter BIOS only, during an aperture service function call. Configuration data is stored in non-volatile memory. Both CFG\_CARD\_ID and CFG\_VGA\_DIS are touched only in the adapter ROM on power-up to configure the board for multiple *mach64* usage.

All offset registers are expanded to allow 8 Mb pointers, with 64-bit granularity. Texture map pointers must have byte granularity.

### See Also

*mach64* Programmer's Guide:

- *Advanced Topics: Boot-time Initialization*

|      |   | CONFIG_CHIP_ID    |    |    |    |    |    |    |    |                                              |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_38 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
|------|---|-------------------|----|----|----|----|----|----|----|----------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|--------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|
| BITS |   | 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 |  |  |  |  |  |  |  |
|      |   | e                 | d  | c  | b  |    |    |    |    |                                              |    |    | a  |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| a    | R | CFG_CHIP_TYPE     |    |    |    |    |    |    |    | Product type code, see DEVICE ID table below |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| b    | R | CFG_CHIP_CLASS    |    |    |    |    |    |    |    | Product class code (0x00)                    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| c    | R | CFG_CHIP_VERSION  |    |    |    |    |    |    |    | ASIC major revision number                   |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| d    | R | CFG_CHIP_FOUNDARY |    |    |    |    |    |    |    | ASIC foundary (0x4) (TSMC)                   |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| e    | R | CFG_CHIP_REV      |    |    |    |    |    |    |    | ASIC minor revision number                   |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |

### Description

This register is a read-only register. It returns the revision details of the queried chip. CFG\_CHIP\_TYPE (Device ID) is an alphanumeric code consisting of two ASCII codes, for example, 4752h denotes GR (see table below).

The Device ID field also appears in the PCI configuration space (see [Chapter 6](#)).

### Usage

The 16 bits Device ID for the RAGE XL in the PCI address 2 and CONFIG\_CHIP\_ID non-GUI register are as follows:

**Table 4-4 Device ID**

| DEVICE ID  | Description     |
|------------|-----------------|
| 4752h (GR) | PCI-33/BGA      |
| 4753h (GS) | PCI-33/PQFP     |
| 474Dh (GM) | AGP 1X, 2X/BGA  |
| 474Eh (GN) | AGP 1X, 2X/PQFP |
| 474Fh (GO) | PCI-66/BGA      |
| 474Ch (GL) | PCI-66/PQFP     |

The 8 bits at PCI address 8h are also known as the ASIC ID. The ASIC ID also appears in the CONFIG\_CHIP\_ID non-GUI register. The following table shows a list of ASIC IDs used to date:

**Table 4-5 ASIC ID**

| <b>ASIC ID</b> | <b>Description</b> |
|----------------|--------------------|
| 24h            | TSMC B11           |
| 25h            | TSMC B21           |
| 65h            | TSMC B22           |
| 26h            | TSMC B31           |
| 27h            | TSMC B41           |

**See Also***mach64 Programmer's Guide:*

- *Getting Started: mach64 Detection: Card Detection*

|             |     | <b>CONFIG_STAT0</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>Offset: 0_39</b> |                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |
|-------------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|
| <b>BITS</b> |     | 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 |
|             |     |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                     |                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |
|             |     |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                     |                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |
| <b>a</b>    | R/W | CFG_MEM_TYPE        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                     | Select memory type:<br>000 = Disable memory access<br>001 = Reserved for basic DRAM<br>010 = Reserved for EDO<br>011 = Reserved for hyper page DRAM or EDO<br>100 = SDRAM (1:1)<br>101 = SGRAM (1:1) (default)<br>110 = SDRAM (2:1) (32-bit memory interface)<br>111 = Reserved |   |   |   |   |   |   |
| <b>b</b>    | R/W | CFG_VGA_EN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                     | 0 = Disable VGA<br>1 = Enable VGA                                                                                                                                                                                                                                               |   |   |   |   |   |   |
| <b>c</b>    | R/W | CFG_CLOCK_EN        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                     | Select control for GUI clock: (default = 0)<br>0 = GUI clock controlled by GUI activity<br>1 = GUI clock always on                                                                                                                                                              |   |   |   |   |   |   |

| Cont'd   |   | CONFIG_STAT0       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_39                                                 |    |   |   |   |   |   |   |   |   |   |   |
|----------|---|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS     |   | 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 |
|          |   | e                  |    |    |    |    |    |    |    |    |    |    |    | d  |    |    |    |    |    |    |    |                                                              |    |   |   |   | c | b |   | a |   |   |   |
| <b>d</b> | R | MACROVISION_ENABLE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Macrovision enable (bonding option) ( <b>Not Supported</b> ) |    |   |   |   |   |   |   |   |   |   |   |
| <b>e</b> | R | ARITHMOS_ENABLE    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Arithmos enable (bonding option) ( <b>Not Supported</b> )    |    |   |   |   |   |   |   |   |   |   |   |
|          |   |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                              |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register returns the configuration of the current board.

### Usage

This register is used by the adapter BIOS for query functions and for determining appropriate action for other function calls. It is also used for determining the initialization parameters and boot-times.

### See Also

*mach64* Programmer's Guide:

- *Advanced Topics: Manual Mode Switching and Custom CRT Modes: Manual Mode Switching*

For a complete description of the strapping scheme, refer to the RAGE XL Controller Specifications.

|          |     | CONFIG_STAT1         |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    | Offset: 0_25            |    |   |   |   |   |   |   |   |   |   |   |
|----------|-----|----------------------|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|----|-------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS     |     | 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 |
|          |     | <b>b</b>             |    |    |    |    |    |    |    |    |    |    |    | <b>a</b> |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |
| <b>a</b> | R/W | SUBSYS_DEV_ID (15:0) |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    | PCI subsystem Device ID |    |   |   |   |   |   |   |   |   |   |   |
| <b>b</b> | R/W | SUBSYS_VEN_ID (15:0) |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    | PCI subsystem Vendor ID |    |   |   |   |   |   |   |   |   |   |   |
|          |     |                      |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |

|          |     | CONFIG_STAT2    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                 |                                                               | Offset: 0_26 |   |   |   |   |   |
|----------|-----|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------|--------------|---|---|---|---|---|
| BITS     |     | 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               |    |    | h  | g  | f  |    | e  |    |    |    |    |    |    |    | d  |    | c  | b  | a  |    |    |   |   |                                                                                                 |                                                               |              |   |   |   |   |   |
| <b>a</b> | R/W | AGPVCOGAIN(1:0) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Set VCO gain<br>00 = Default                                                                    |                                                               |              |   |   |   |   |   |
| <b>b</b> | R/W | BUS_CLK_SEL     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                 | Select bus type<br>0 = External bus clock<br>1 = Internal PLL |              |   |   |   |   |   |
| <b>c</b> | R/W | X1CLKSKEW(1:0)  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Adjustment for AGP X2 clock skew<br>00 = Default                                                |                                                               |              |   |   |   |   |   |
| <b>d</b> | R/W | AGPSKEW         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Adjustment for AGP clock skew<br>00 = Default                                                   |                                                               |              |   |   |   |   |   |
| <b>e</b> | R/W | ID_DISABLE      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0 = Normal operation<br>1 = IDSEL not connected                                                 |                                                               |              |   |   |   |   |   |
| <b>f</b> | R/W | BUS_TYPE        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Determines signaling on the PCI<br>0 = PCI 3.3 V signaling (default)<br>1 = PCI 5.0 V signaling |                                                               |              |   |   |   |   |   |
| <b>g</b> | R/W | VGA_DISABLE     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Disable VGA<br>0 = Enable<br>1 = Disable                                                        |                                                               |              |   |   |   |   |   |
| <b>h</b> | R/W | ENINTB          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Disable interrupt<br>0 = Enable<br>1 = Disable                                                  |                                                               |              |   |   |   |   |   |
| <b>i</b> | R/W | IDSEL           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Set connection for IDSEL<br>0 = Connect IDSEL to AD16<br>1 = Connect IDSEL to AD17              |                                                               |              |   |   |   |   |   |

### 4.1.9 Custom Macro Registers

|      |     | CUSTOM_MACRO_CNTL   |    |    |    |    |    |    |    |    |    |                                                                                                                         |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Offset: 0_35 |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|---------------------|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     |                     |    |    |    |    |    |    |    |    |    | q                                                                                                                       | p  | o  | n  | m  | l  | k  |    |    |    |    |    |   |   |   |              |   | a |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | IDCT_FIFO_EXTSENSE  |    |    |    |    |    |    |    |    |    | IDCT FIFO mode:<br>(hardware default = 0, BIOS should set '1')<br>0 = Normal<br>1 = Enable extended sense               |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | MEM_DQML_DRIVE      |    |    |    |    |    |    |    |    |    | Boost drive strength of lower four DQM pins (0 - 3)<br>0 = normal<br>1 = slow<br>Note: available only on chip rev. B21. |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | MEM_DQML_SLEWRATE   |    |    |    |    |    |    |    |    |    | Slew rate control of lower four DQM pins (0 - 3)<br>0 = normal<br>1 = slow<br>Note: only available on chip rev. B21     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d    | R/W | GWBUF_FIFO_EXTSENSE |    |    |    |    |    |    |    |    |    | GUI write buffer FIFO mode<br>0 = Normal operation<br>1 = Enable extended sense                                         |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| e    | R/W | RDRET_FIFO_EXTPRE   |    |    |    |    |    |    |    |    |    | Read return FIFO precharge<br>0 = Normal operation<br>1 = Extended precharge                                            |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| f    | R/W | RDRET_FIFO_EXTDIS   |    |    |    |    |    |    |    |    |    | Read return FIFO discharge<br>0 = Normal operation<br>1 = Extended discharge                                            |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| g    | R/W | TAG_RAM_EXTSENSE    |    |    |    |    |    |    |    |    |    | Tag RAM mode:<br>0 = normal<br>1 = enable extended sense                                                                |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| h    | R/W | RDRET_FIFO_EXTSENSE |    |    |    |    |    |    |    |    |    | Read Return FIFO mode<br>0 = Normal operation<br>1 = Enable extended sense                                              |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| i    | R/W | MEM_MA12_EN         |    |    |    |    |    |    |    |    |    | Controls the functionality of the DSF pin<br>0 =DSF<br>1 = MA12                                                         |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| j    | R/W | DISP_CPR_DIS        |    |    |    |    |    |    |    |    |    | Disable "close page read" for display<br>0 = Normal<br>1 = Disable                                                      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| k    | R/W | MEM_CS_SLEWRATE     |    |    |    |    |    |    |    |    |    | Slew rate control of CS pins<br>0 = Normal operation<br>1 = Slow                                                        |    |    |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Cont'd |     | CUSTOM_MACRO_CNTL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_35                                                                                                |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | q                 | p  | o  | n  | m  | l  | k  |    |    |    |    | j  | i  | h  | g  | f  | e  | d  | c  | b  |                                                                                                             | a  |   |   |   |   |   |   |   |   |   |   |
| l      | R/W | MEM_MDA_SLEWRATE  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Slew rate control of upper 32 MD pins not connected to BIOS (49, 52-55)<br>0 = Normal operation<br>1 = Slow |    |   |   |   |   |   |   |   |   |   |   |
| m      | R/W | MEM MDB_SLEWRATE  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Slew rate control of pins connected to BIOS (32-48, 50-51, 56-63):<br>0 = Normal operation<br>1 = Slow      |    |   |   |   |   |   |   |   |   |   |   |
| n      | R/W | MEM_MDL_SLEWRATE  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Slew rate control of low 32 MD pins (0-31)<br>0 = Normal operation<br>1 = Slow                              |    |   |   |   |   |   |   |   |   |   |   |
| o      | R/W | MEM_MA_SLEWRATE   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Slew rate control of MA pins<br>0 = Normal operation<br>1 = Slow                                            |    |   |   |   |   |   |   |   |   |   |   |
| p      | R/W | MEM_CNTL_SLEWRATE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Slew rate control of RAS, CAS, WE, DSF pins: (default = 0)<br>0 = Normal operation<br>1 = Slow              |    |   |   |   |   |   |   |   |   |   |   |
| q      | R/W | MEM_DQM_SLEWRATE  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Slew rate control of DQM pins: (default = 0)<br>0 = Normal operation<br>1 = Slow                            |    |   |   |   |   |   |   |   |   |   |   |

## 4.2 Accelerator CRTC and DAC Registers

### 4.2.1 Accelerator CRTC Registers

The registers in this group generate the horizontal sync, vertical sync, and blank signals used to position the pixel data on the display monitor. All horizontal parameters are in terms of characters (\*8 pixels). All vertical parameters are in terms of lines. Accurate display centering is possible by adjusting CRTC\_HORZ\_SYNC\_DLY. A vertical blank and vertical line interrupt allows video synchronization without motion tearing artifacts. Monitor power management is controlled through CRTC\_HSYNC\_DIS and CRTC\_VSYNC\_DIS.

### 4.2.2 Shadowed and Second CRTC Registers

The shadow CRTC registers are controlled by the following bits inside the LCD\_GEN\_CTRL register:

CRTC\_RW\_SELECT, SHADOW\_RW\_EN, USE\_SHADOW,  
USE\_SHADOWED\_ROW CUR, USE\_SHADOWED\_VEND

| Shadowed VGA CRTC Registers   |       |       |                                                    |
|-------------------------------|-------|-------|----------------------------------------------------|
| Name                          | I/O   | Index | Bits Shadowed                                      |
| Horizontal Total              | 03?5* | 0     | 7:0                                                |
| Horizontal Display Enable End | 03?5* | 1     | 7:0                                                |
| Start Horizontal Blanking     | 03?5* | 2     | 7:0                                                |
| End Horizontal Blanking       | 03?5* | 3     | 6:0                                                |
| Start Horizontal Retrace      | 03?5* | 4     | 7:0                                                |
| End Horizontal Retrace        | 03?5* | 5     | 7:0                                                |
| Vertical Total                | 03?5* | 6     | 7:0                                                |
| CRTC Overflow                 | 03?5* | 7     | 7:5, 3:0                                           |
| Maximum Scan Line             | 03?5* | 9     | 5:0                                                |
| Cursor Start                  | 03?5* | A     | 4:0                                                |
| Cursor End                    | 03?5* | B     | 4:0                                                |
| Start Vertical Retrace        | 03?5* | 10    | 7:0                                                |
| End Vertical Retrace          | 03?5* | 11    | 3:0                                                |
| Vertical Display Enable End   | 03?5* | 12    | 7:0                                                |
| Underline Location            | 03?5* | 14    | 4:0                                                |
| Start Vertical Blanking       | 03?5* | 15    | 7:0                                                |
| End Vertical Blanking         | 03?5* | 16    | 7:0                                                |
| CRT Mode                      | 03?5* | 17    | 2 (forced to 0)<br>Still read back as 1 if written |

Note that the CRTC base address will be 3B4 or 3D4 depending on the I/O Address Select field in the GENMO (Miscellaneous Output Register, 3C2).

| Shadowed Accelerator CRTC Registers |        |                 |                                                   |
|-------------------------------------|--------|-----------------|---------------------------------------------------|
| Name                                | Offset | Bits Shadowed   | Description                                       |
| CRTC_H_TOTAL_DISP                   | 0      | 24:16, 8:0      | Horizontal display total and display end          |
| CRTC_H_SYNC_STRT_WID                | 1      | 20:16, 12, 10:0 | Horizontal sync start and width                   |
| CRTC_V_TOTAL_DISP                   | 2      | 26:16, 10:0     | Vertical display total and display end            |
| CRTC_V_SYNC_STRT_WID                | 3      | 20:16, 10:0     | Vertical sync start and width                     |
| CRTC_VLINE_CRNT_VLINE               | 4      | 26:16, 10:0     | Current vertical line and vertical line interrupt |

The access and the usage of the shadowed CRTC registers are controlled by the following bits inside the LCD\_GEN\_CTRL register: CRTC\_RW\_SELECT, SHADOW\_RW\_EN, USE\_SHADOW, USE\_SHADOWED\_ROWCUR, USE\_SHADOWED\_VEND and DONT\_SHADOW\_VPAR.

The following tables show how the shadowed registers are used.

| CRTC_RW_SELECT | SHADOW_RW_EN | HOST READ/WRITE                                                                        |
|----------------|--------------|----------------------------------------------------------------------------------------|
| 0              | 0            | Host read/writes are directed to the <b>non-shadowed</b> CRTC registers                |
| 0              | 1            | Host read/writes are directed to the <b>shadowed</b> CRTC registers of the primary CRT |
| 1              | don't care   | Host read/writes are directed to the secondary CRT's registers                         |

| USE_SHADOW | CRTC Registers Used                                               |                                                    |
|------------|-------------------------------------------------------------------|----------------------------------------------------|
| 0          | Normal CRTC registers are used instead of the shadowed registers. |                                                    |
| 1          | The following shadowed registers will be used:                    |                                                    |
|            | Register:                                                         | Bits:                                              |
|            | 3?5 index 0                                                       | 7:0                                                |
|            | 3?5 index 1                                                       | 7:0                                                |
|            | 3?5 index 2                                                       | 7:0                                                |
|            | 3?5 index 3                                                       | 6:0                                                |
|            | 3?5 index 4                                                       | 7:0                                                |
|            | 3?5 index 5                                                       | 7:0                                                |
|            | 3?5 index 6                                                       | 7:0                                                |
|            | 3?5 index 7                                                       | 7:5, 3:0                                           |
|            | 3?5 index 9                                                       | 5                                                  |
|            | 3?5 index 10                                                      | 7:0                                                |
|            | 3?5 index 11                                                      | 3:0                                                |
|            | 3?5 index 12                                                      | 7:0                                                |
|            | 3?5 index 15                                                      | 7:0                                                |
|            | 3?5 index 16                                                      | 7:0                                                |
|            | 3?5 index 17                                                      | 2 (forced to '0'), still reads back '1' if written |
|            | CRTC_H_TOTAL_DISP                                                 | 24:16, 8:0                                         |
|            | CRTC_H_SYNC_STRT_WID                                              | 20:16, 12,10:0                                     |
|            | CRTC_V_TOTAL_DISP **                                              | 10:0                                               |
|            | CRTC_V_SYNC_STRT_WID                                              | 20:16, 10:0                                        |

| <b>USE_SHADOWED_ROWCUR</b> | <b>CRTC registers used</b>                                                                                                                         |  |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0                          | Normal CRTC registers: 3?5 index 9, A, B, 14                                                                                                       |  |
| 1                          | The following shadowed registers will be used:<br><br>Register: Bits:<br>3?5 index 9 4:0<br>3?5 index A 4:0<br>3?5 index B 4:0<br>3?5 index 14 4:0 |  |

| <b>USE_SHADOWED_VEND</b> | <b>CRTC registers used</b>                                                      |
|--------------------------|---------------------------------------------------------------------------------|
| 0                        | Normal CRTC registers: 3?5 index 12 or CRTC_V_TOTAL_DISP bits 26:16             |
| 1                        | Shadowed register CRTC_V_TOTAL_DISP bits 26:16 are used as vertical display end |

- When the shadowed registers are used to generate the horizontal timing, the bit SEQ\_PCLKBY2 (bit 3 of VGA sequencer data register 1) has the following effect on the timing:

| <b>SEQ_PCLKBY2</b> | <b>CRTC Registers Used</b>                                                                                                                                                                                                                                                                                                                                                    |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                  | The horizontal timing parameters from the shadowed registers are used as programmed.                                                                                                                                                                                                                                                                                          |
| 1                  | The contents of the following shadow registers are divided by 2 (by the hardware) before they are used:<br>VGA CRTC index 0 bits 7:0 (HTOTAL)<br>VGA CRTC index 1 bits 7:0 (HDISP end)<br>VGA CRTC index 2 bits 7:0 (HBLANK start)<br>VGA CRTC index 3 bits 6:5, 4:0 (HBLANK end)<br>VGA CRTC index 4 bits 7:0 (HSYNC start)<br>VGA CRTC index 5 bits 7, 6:5, 4:0 (HSYNC end) |

- When vertical expansion is enabled, the vertical CRT counter will be stalled if a line duplication happens. The vertical display end register should not be shadowed in non-vertical expansion modes to allow maximum VGA compatibility.

When vertical expansion is enabled, the vertical display end register can either be shadowed or non-shadowed.

If the vertical end register is non-shadowed, part of the screen will be missing due to the application programming the vertical end to be greater than the vertical end originally written by the video BIOS.

If the vertical end register is shadowed, applications programming a vertical end value other than 350, 400 and 480 will not work properly. To minimize problems with VGA compatibility, there is an option of not to shadow vertical parameters when expansion is turned on. Based the vertical display end value as well as blank start and end values, hardware will select proper ratio for vertical expansion.

- During simultaneous CRT/LCD display, the shadowed H\_SYNC/V\_SYNC registers should be used to generate H\_SYNC/V\_SYNC for the LCD panel while the CRT H\_SYNC/V\_SYNC should be generated by the non-shadowed CRT H\_SYNC/V\_SYNC registers. This way, both CRT and LCD timing can be met. If vertical parameters are not shadowed, vertical SYNC for the panel should be generated from non-shadow CRT registers.

**Note:** *The following CRTC2\_\* registers are NOT supported in RAGE XL.*

## Second CRTC Registers

- Second CRT only supports accelerator mode (no VGA mode support). Ratiometric expansion is not supported. If second CRT is driving LCD panel whose resolution is bigger than current graphics mode, display will be centered. For the second CRT controller, **the following registers are accessible when CRTC\_RW\_SELECT is set:**

|      |     | CRTC_H_TOTAL_DISP |    |    |    |    |    |    |    |    |    |    |    |                                      |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Offset: 0_00 |   |   |   |   |
|------|-----|-------------------|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------------|---|---|---|---|
| BITS |     | 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 |
|      |     | b                 |    |    |    |    |    |    |    |    |    |    |    | a                                    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |
| a    | R/W | CRTC_H_TOTAL      |    |    |    |    |    |    |    |    |    |    |    | Horizontal display total (*8 pixels) |    |    |    |    |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |
| b    | R/W | CRTC_H_DISP       |    |    |    |    |    |    |    |    |    |    |    | Horizontal display end (*8 pixels)   |    |    |    |    |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |

### Description

This register specifies the horizontal total and horizontal displayed parameters for the accelerator CRTC. This register is used for the first display path.

(\*8) means the unit value (in decimal) contained in the bits represents 8 pixels.

Example: to set the CRTC for a total horizontal display of 640 pixels (i.e. a 640x480 display format), insert 50h (i.e., 80 decimal) into bits [8:0]; therefore,  $80*8 = 640$ .

### Usage

Use this register only for mode switching, and should be touched only by the adapter BIOS.

### See Also

*mach64* Programmer's Guide:

- *Advanced Topics: Manual Mode Switching and Custom CRT Modes: Manual Mode Switching*
- *Advanced Topics: Manual Mode Switching and Custom CRT Modes: Designing a Custom CRT Mode*
- *Appendix C, CRTC Parameters*

(NOT supported in RAGE XL)

|      |     |                                                                                       | CRTC2_H_TOTAL_DISP |  |  |  |  |  |  |  |  |  |  |                                                           |  |  |  |  |  |  |  |  |  |  |  |  | Offset: 0_00 |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|---------------------------------------------------------------------------------------|--------------------|--|--|--|--|--|--|--|--|--|--|-----------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--------------|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |                    |  |  |  |  |  |  |  |  |  |  |                                                           |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |
|      |     | b                                                                                     |                    |  |  |  |  |  |  |  |  |  |  | a                                                         |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | CRTC2_H_TOTAL                                                                         |                    |  |  |  |  |  |  |  |  |  |  | Horizontal display total (*8 pixels) for a second display |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | CRTC2_H_DISP                                                                          |                    |  |  |  |  |  |  |  |  |  |  | Horizontal display end (*8 pixels) for a second display   |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |

### Description

This register is similar to the CRTC\_H\_TOTAL\_DISP register. This register is used for the second display path.

|      |     |                                                                                       | CRTC_H_SYNC_STRT_WID |  |  |  |  |  |  |  |  |  |  |                                         |  |  |  |   |  |  |  |   |  |  |  |   |  |  | Offset: 0_01 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|---------------------------------------------------------------------------------------|----------------------|--|--|--|--|--|--|--|--|--|--|-----------------------------------------|--|--|--|---|--|--|--|---|--|--|--|---|--|--|--------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |                      |  |  |  |  |  |  |  |  |  |  |                                         |  |  |  |   |  |  |  |   |  |  |  |   |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | e                                                                                     |                      |  |  |  |  |  |  |  |  |  |  | d                                       |  |  |  | c |  |  |  | b |  |  |  | a |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | CRTC_H_SYNC_STRT                                                                      |                      |  |  |  |  |  |  |  |  |  |  | Horizontal sync start (*8 pixels)       |  |  |  |   |  |  |  |   |  |  |  |   |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | CRTC_H_SYNC_DLY                                                                       |                      |  |  |  |  |  |  |  |  |  |  | Horizontal sync start delay (in pixels) |  |  |  |   |  |  |  |   |  |  |  |   |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Cont'd |     | CRTC_H_SYNC_STRT_WID |    |    |    |    |    |    |    |    |    |    |    |                                            |    |    |    |    |    |    |    | Offset: 0_01 |    |   |   |   |   |   |   |   |   |   |   |   |
|--------|-----|----------------------|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------|----|----|----|----|----|----|----|--------------|----|---|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |   |
|        |     |                      |    |    |    |    |    |    |    |    |    |    |    | e                                          | d  |    |    |    |    | c  | b  |              |    |   |   |   |   |   |   |   |   |   |   | a |
| c      | R/W | CRTC_H_SYNC_STRT_HI  |    |    |    |    |    |    |    |    |    |    |    | High bit for Horizontal sync start         |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |   |
| d      | R/W | CRTC_H_SYNC_WID      |    |    |    |    |    |    |    |    |    |    |    | Horizontal sync width (*8 pixels)          |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |   |
| e      | R/W | CRTC_H_SYNC_POL      |    |    |    |    |    |    |    |    |    |    |    | Horizontal sync polarity (1 -> active low) |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |   |

### Description

This register specifies the horizontal sync attributes for the accelerator CRTC. This register is used for the first display path.

(\*8 pixels) means the unit value (in decimal) contained in the bits represents 8 pixels. For an complete explanation, refer to CRTC\_H\_TOTAL\_DISP (offset = 0\_00).

### Usage

Use this register only for mode switching and should be touched only by the adapter BIOS.

### See Also

*mach64* Programmer's Guide:

- *Advanced Topics: Manual Mode Switching and Custom CRT Modes: Manual Mode Switching*
- *Advanced Topics: Manual Mode Switching and Custom CRT Modes: Designing a Custom CRT Mode*
- *Appendix C, CRTC Parameters*

(NOT supported in RAGE XL)

|      |     | CRTC2_H_SYNC_STRT_WID |    |    |    |    |    |    |    |    |    |    |    |                                                                  |    |    |    |    |    |    |    | Offset: 0_01 |    |   |   |   |   |   |   |   |   |   |   |   |
|------|-----|-----------------------|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------|----|----|----|----|----|----|----|--------------|----|---|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |   |
|      |     |                       |    |    |    |    |    |    |    |    |    |    |    | e                                                                | d  |    |    |    |    | c  | b  |              |    |   |   |   |   |   |   |   |   |   |   | a |
| a    | R/W | CRTC2_H_SYNC_STRT     |    |    |    |    |    |    |    |    |    |    |    | Horizontal sync start (*8 pixels) for the second display         |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |   |
| b    | R/W | CRTC2_H_SYNC_DLY      |    |    |    |    |    |    |    |    |    |    |    | Horizontal sync start delay (in pixels)for the second display    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |   |
| c    | R/W | CRTC2_H_SYNC_STRT_HI  |    |    |    |    |    |    |    |    |    |    |    | High bit for Horizontal sync start for the second display        |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |   |
| d    | R/W | CRTC2_H_SYNC_WID      |    |    |    |    |    |    |    |    |    |    |    | Horizontal sync width (*8 pixels) for the second display         |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |   |
| e    | R/W | CRTC2_H_SYNC_POL      |    |    |    |    |    |    |    |    |    |    |    | Horizontal sync polarity (1-> active low) for the second display |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |   |

**Description**

This register is similar to the CRTC\_H\_SYNC\_STRT\_WID register. This register is used for the second display path.

|      |     | CRTC_V_TOTAL_DISP |    |    |    |    |    |    |    |    |    |    |    |                      |    |    |    |    |    |    |    |    |    |   |   | Offset: 0_02 |   |   |   |   |   |   |   |
|------|-----|-------------------|----|----|----|----|----|----|----|----|----|----|----|----------------------|----|----|----|----|----|----|----|----|----|---|---|--------------|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | b                 |    |    |    |    |    |    |    |    |    |    |    | a                    |    |    |    |    |    |    |    |    |    |   |   |              |   |   |   |   |   |   |   |
| a    | R/W | CRTC_V_TOTAL      |    |    |    |    |    |    |    |    |    |    |    | Vertical total       |    |    |    |    |    |    |    |    |    |   |   |              |   |   |   |   |   |   |   |
| b    | R/W | CRTC_V_DISP       |    |    |    |    |    |    |    |    |    |    |    | Vertical display end |    |    |    |    |    |    |    |    |    |   |   |              |   |   |   |   |   |   |   |

**Description**

This register specifies the vertical total and vertical displayed parameters for the accelerator CRTC. This register is used for the first display path. All vertical parameters are specified in lines.

**Usage**

Use this register only for mode switching, and should be touched only by the adapter BIOS.

**See Also**

*mach64 Programmer's Guide:*

- *Advanced Topics: Manual Mode Switching and Custom CRT Modes: Manual Mode Switching*
- *Advanced Topics: Manual Mode Switching and Custom CRT Modes: Designing a Custom CRT Mode*
- *Appendix C, CRTC Parameters*

(NOT supported in RAGE XL)

|      |     | CRTC2_V_TOTAL_DISP |    |    |    |    |    |    |    |    |    |    |    |                                             |    |    |    |    |    |    |    |    |    |   |   | Offset: 0_02 |   |   |   |   |   |   |   |
|------|-----|--------------------|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|--------------|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | b                  |    |    |    |    |    |    |    |    |    |    |    | a                                           |    |    |    |    |    |    |    |    |    |   |   |              |   |   |   |   |   |   |   |
| a    | R/W | CRTC2_V_TOTAL      |    |    |    |    |    |    |    |    |    |    |    | Vertical total for the second display       |    |    |    |    |    |    |    |    |    |   |   |              |   |   |   |   |   |   |   |
| b    | R/W | CRTC2_V_DISP       |    |    |    |    |    |    |    |    |    |    |    | Vertical display end for the second display |    |    |    |    |    |    |    |    |    |   |   |              |   |   |   |   |   |   |   |

### Description

This register is similar to the CRTC\_V\_TOTAL\_DISP register. This register is used for the second display path.

|      |     | CRTC_V_SYNC_STRT_WID |    |    |    |    |    |    |    |    |    |    |    |                                          |    |    |    |    |    |    |    | Offset: 0_03 |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|----------------------|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------|----|----|----|----|----|----|----|--------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | c                    |    |    |    |    |    |    |    |    |    |    |    | b                                        |    |    |    | a  |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | CRTC_V_SYNC_STRT     |    |    |    |    |    |    |    |    |    |    |    | Vertical sync start                      |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |
| b    | R/W | CRTC_V_SYNC_WID      |    |    |    |    |    |    |    |    |    |    |    | Vertical sync width                      |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |
| c    | R/W | CRTC_V_SYNC_POL      |    |    |    |    |    |    |    |    |    |    |    | Vertical sync polarity (1 -> active low) |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register specifies the vertical sync attributes for the accelerator CRTC. This register is used for the first display path. All vertical parameters are specified in lines.

### Usage

Use this register only for mode switching, and should be touched only by the adapter BIOS.

### See Also

*mach64* Programmer's Guide:

- *Advanced Topics: Manual Mode Switching and Custom CRT Modes: Manual Mode Switching*
- *Advanced Topics: Manual Mode Switching and Custom CRT Modes: Designing a Custom CRT Mode*
- *Appendix C, CRTC Parameters*

(NOT supported in RAGE XL)

|      |     | CRTC2_V_SYNC_STRT_WID |    |    |    |    |    |    |    |    |    |    |    |                                                                 |    |    |    |    |    |    |    | Offset: 0_03 |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|-----------------------|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------|----|----|----|----|----|----|----|--------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | c                     |    |    |    |    |    |    |    |    |    |    |    | b                                                               |    |    |    | a  |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | CRTC2_V_SYNC_STRT     |    |    |    |    |    |    |    |    |    |    |    | Vertical sync start for the second display                      |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |
| b    | R/W | CRTC2_V_SYNC_WID      |    |    |    |    |    |    |    |    |    |    |    | Vertical sync width for the second display                      |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |
| c    | R/W | CRTC2_V_SYNC_POL      |    |    |    |    |    |    |    |    |    |    |    | Vertical sync polarity (1 -> active low) for the second display |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |

**Description**

This register is similar to the CRTC\_V\_SYNC\_STRT\_WID register. This register is used for the second display path.

|      |     | CRTC_VLINE_CRNT_VLINE |    |    |    |    |    |    |    |    |    |    |    |                                                             |    |    |    |    |    |    |    | Offset: 0_04 |    |   |   |   |   |   |   |   |   |   |   |  |
|------|-----|-----------------------|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------|----|----|----|----|----|----|----|--------------|----|---|---|---|---|---|---|---|---|---|---|--|
| BITS |     | 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 |  |
|      |     | b                     |    |    |    |    |    |    |    |    |    |    |    | a                                                           |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |
| a    | R/W | CRTC_VLINE            |    |    |    |    |    |    |    |    |    |    |    | Vertical line at which vertical line interrupt is triggered |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |
| b    | R   | CRTC_CRNT_VLINE       |    |    |    |    |    |    |    |    |    |    |    | Current vertical line                                       |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |

**Description**

The CRTC\_VLINE field determines the line at which a CRTC interrupt will be triggered if the interrupts are enabled. The CRTC\_CRNT\_VLINE field is read-only and it returns the current value of the accelerator CRTC vertical line counter. This register is used for the first display path.

**Usage**

Use this register only in applications that require synchronization to the CRTC, such as smooth animation.

**See Also**

CRTC\_INT\_CNTL on [page 4-50](#)

*mach64* Programmer's Guide:

- *Advanced Topics: Interrupts*
- *Advanced Topics: CRT Synchronization and Animation*

(NOT supported in RAGE XL)

|      |     | CRTC2_VLINE_CRNT_VLINE |    |    |    |    |    |    |    |    |    |    |    |                                                                                |    |    |    |    |    |    |    | Offset: 0_04 |    |   |   |   |   |   |   |   |   |   |   |  |
|------|-----|------------------------|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------------------|----|----|----|----|----|----|----|--------------|----|---|---|---|---|---|---|---|---|---|---|--|
| BITS |     | 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 |  |
|      |     | b                      |    |    |    |    |    |    |    |    |    |    |    | a                                                                              |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |
| a    | R/W | CRTC2_VLINE            |    |    |    |    |    |    |    |    |    |    |    | Vertical line of the second CRT at which vertical line interrupt is triggered. |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |
| b    | R   | CRTC2_CRNT_VLINE [R]   |    |    |    |    |    |    |    |    |    |    |    | Current vertical line of the second CRT controller.                            |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |  |

### Description

This register is similar to the CRTC\_VLINE\_CRNT\_VLINE register. This register is used for the second display path.

|      |     | CRTC_OFF_PITCH   |    |    |    |    |                                                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_05 |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|------------------|----|----|----|----|----------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | c                |    |    |    |    | b                                                                                                                                |    | a  |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | CRTC_OFFSET      |    |    |    |    | Display address offset in qword of primary display path                                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |
| b    | R   | CRTC_OFFSET_LOCK |    |    |    |    | CRTC display address offset status bit<br>0 = Indicates CRTC_OFFSET has been used<br>1 = Indicates CRTC_OFFSET has not been used |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |
| c    | R/W | CRTC_PITCH       |    |    |    |    | Display pitch (*8 pixels) of primary display path                                                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register specifies the starting memory offset and pitch of the accelerator CRTC. This register is used for the first display path. The pitch value must correspond exactly to the destination draw engine pitch for visible screen memory. If the memory boundary is enabled, the offset must be set to a value above or equal to the boundary offset.

(\*8 pixels) means the unit value (in decimal) contained in the bits represents 8 pixels. For an complete explanation, refer to CRTC\_H\_TOTAL\_DISP (offset = 0\_00).

### Usage

The offset register may be used for scrolling and panning on a large desktop if the pitch is set to a value larger than the display resolution. This register may also be used for double buffering applications.

### See Also

MEM\_CNTL on [page 4-17](#)

SRC\_OFF\_PITCH on [page 5-26](#)

DST\_OFF\_PITCH on [page 5-9](#)

*mach64* Programmer's Guide:

- *Linear Aperture: VGA Interaction*
- *Advanced Topics: Scrolling and Panning*
- *Advanced Topics: CRT Synchronization and Animation: Double Buffering (Memory)*

(NOT supported in RAGE XL)

|      |     | CRTC2_OFF_PITCH   |    |    |    |    |    |    |    |                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_17 |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|-------------------|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|--------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | c                 |    |    |    |    |    |    |    | b                                                                                                                                        | a  |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | CRTC2_OFFSET      |    |    |    |    |    |    |    | Display address offset in terms of 64 bit words                                                                                          |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |
| b    | R   | CRTC2_OFFSET_LOCK |    |    |    |    |    |    |    | CRTC2 display address offset status bit.<br>0 = Indicates address offset has been used<br>1 = Indicates address offset has not been used |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |
| c    | R/W | CRTC2_PITCH       |    |    |    |    |    |    |    | Display pitch (*8 pixels)                                                                                                                |    |    |    |    |    |    |    |    |    |    |    |              |    |   |   |   |   |   |   |   |   |   |   |

**Description**

This register is similar to the CRTC\_OFF\_PITCH register. This register defines the start address for the second display. This register is used for the second display path.

|      |     | CRTC_INT_CNTL        |    |    |    |    |    |    |    |                                                                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|----------------------|----|----|----|----|----|----|----|-------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | F                    | E  | D  | C  | B  | A  | z  | y  | x                                                                                         | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j | i | h | g | f | e | d | c | b | a |
| a    | R   | CRTC_VBLANK          |    |    |    |    |    |    |    | Vertical blank                                                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b    | R/W | CRTC_VBLANK_INT_EN * |    |    |    |    |    |    |    | Enable vertical blank interrupt (active high): (default = 0)<br>0 = Disable<br>1 = Enable |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| c    | R   | CRTC_VBLANK_INT *    |    |    |    |    |    |    |    | Vertical blank interrupt (active high)                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|      | W   | CRTC_VBLANK_INT_AK * |    |    |    |    |    |    |    | Vertical blank acknowledge (to clear interrupt, write '1')                                |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| d    | R/W | CRTC_VLINE_INT_EN *  |    |    |    |    |    |    |    | Enable vertical line interrupt (active high): (default = 0)<br>0 = Disable<br>1 = Enable  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|      | R   | CRTC_VLINE_INT *     |    |    |    |    |    |    |    | Vertical line interrupt (active high)                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| e    | R   | CRTC_VLINE_INT_AK *  |    |    |    |    |    |    |    | Vertical line interrupt acknowledge (to clear interrupt, write '1')                       |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|      | W   | CRTC_VLINE_SYNC      |    |    |    |    |    |    |    | Vertical line sync<br>0 = Even scan line<br>1 = Odd scan line                             |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| g    | R   | CRTC_FRAME           |    |    |    |    |    |    |    | Interlace odd/even frame<br>0 = Even frame<br>1 = Odd frame                               |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Cont'd |     | CRTC_INT_CNTL         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                                                    |   |   |   |   |   |   |   |
|--------|-----|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | F                     | E  | D  | C  | B  | A  | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j | i | h                                                                                                                                  | g | f | e | d | c | b | a |
| h      | R/W | SNAPSHOT_INT_EN       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable snapshot interrupt: (default = 0)<br>0 = Disable<br>1 = Enable                                                              |   |   |   |   |   |   |   |
| i      | R   | SNAPSHOT_INT          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0 = No snapshot taken<br>1 = Snapshot taken                                                                                        |   |   |   |   |   |   |   |
| j      | R/W | SNAPSHOT_INT_AK       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 1 = Clear snapshot interrupt                                                                                                       |   |   |   |   |   |   |   |
|        |     | I2C_INT_EN            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable I2C interrupt: (default = 0)<br>0 = Disable<br>1 = Enable                                                                   |   |   |   |   |   |   |   |
| k      | R   | I2C_INT               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 0 = No I2C interrupt<br>1 = I2C interrupt took place                                                                               |   |   |   |   |   |   |   |
|        | W   | I2C_INT_AK            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 1 = Clear I2C interrupt                                                                                                            |   |   |   |   |   |   |   |
| l      | R   | CRTC2_VBLANK          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Vertical blank of the second CRT                                                                         |   |   |   |   |   |   |   |
| m      | R/W | CRTC2_VBLANK_INT_EN * |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Enable vertical blank interrupt for second CRT (active high):<br>0 = Disable (default )<br>1 = Enable    |   |   |   |   |   |   |   |
| n      | R   | CRTC2_VBLANK_INT *    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Vertical blank interrupt of the second CRT (active high)                                                 |   |   |   |   |   |   |   |
|        | W   | CRTC2_VBLANK_INT_AK * |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Vertical blank acknowledge for the second CRT<br>(to clear interrupt, write '1')                         |   |   |   |   |   |   |   |
| o      | R/W | CRTC2_VLINE_INT_EN *  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Enable vertical line interrupt for the second CRT (active high):<br>0 = Disable (default )<br>1 = Enable |   |   |   |   |   |   |   |
| p      | R   | CRTC2_VLINE_INT *     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Vertical line interrupt of the second CRT (active high)                                                  |   |   |   |   |   |   |   |
|        | W   | CRTC2_VLINE_INT_AK *  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Vertical line acknowledge for the second CRT (to clear<br>interrupt, write '1')                          |   |   |   |   |   |   |   |
| q      | R/W | CUPBUFO_INT_EN        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable continuous capture buffer 0 interrupt: (default = 0)<br>0 = Disable<br>1 = Enable                                           |   |   |   |   |   |   |   |
| r      | R   | CUPBUFO_INT *         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Continuous capture buffer 0 interrupt (active high)                                                                                |   |   |   |   |   |   |   |
|        | W   | CUPBUFO_INT_AK *      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Continuous capture buffer 0 (to clear interrupt, write '1')                                                                        |   |   |   |   |   |   |   |

| Cont'd |     | CRTC_INT_CNTL          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_06                                                                                              |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | F                      | E  | D  | C  | B  | A  | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  | l                                                                                                         | k  | j | i | h | g | f | e | d | c | b | a |
| s      | R/W | CUPBUF1_INT_EN         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable continuous capture buffer 1 interrupt: (default = 0)<br>0 = Disable<br>1 = Enable                  |    |   |   |   |   |   |   |   |   |   |   |
| t      | R   | CUPBUF1_INT *          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Continuous capture buffer 1 interrupt (active high)                                                       |    |   |   |   |   |   |   |   |   |   |   |
|        | W   | CUPBUF1_INT_AK *       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Continuous capture buffer 1 acknowledge (to clear interrupt, write '1')                                   |    |   |   |   |   |   |   |   |   |   |   |
| u      | R/W | OVERLAY_EOF_INT_EN     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable overlay end-of-frame interrupt: (default = 0)<br>0 = Disable<br>1 = Enable                         |    |   |   |   |   |   |   |   |   |   |   |
| v      | R   | OVERLAY_EOF_INT *      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Overlay end-of-frame interrupt (active high)                                                              |    |   |   |   |   |   |   |   |   |   |   |
|        | W   | OVERLAY_EOF_INT_AK *   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Overlay end-of-frame acknowledge (to clear interrupt, write '1')                                          |    |   |   |   |   |   |   |   |   |   |   |
| w      | R/W | ONESHOT_CAP_INT_EN     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable one-shot host capture complete interrupt: (default = 0)<br>0 = Disable<br>1 = Enable               |    |   |   |   |   |   |   |   |   |   |   |
| x      | R   | ONESHOT_CAP_INT *      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | One-shot host capture complete interrupt (active high)                                                    |    |   |   |   |   |   |   |   |   |   |   |
|        | W   | ONESHOT_CAP_INT_AK *   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | One-shot host capture complete acknowledge (to clear interrupt, write '1')                                |    |   |   |   |   |   |   |   |   |   |   |
| y      | R/W | BUSMASTER_EOL_INT_EN   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable bus master end of system list interrupt: (default = 0)<br>0 = Disable<br>1 = Enable                |    |   |   |   |   |   |   |   |   |   |   |
| z      | R   | BUSMASTER_EOL_INT *    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bus master end of system list interrupt (active high)                                                     |    |   |   |   |   |   |   |   |   |   |   |
|        | W   | BUSMASTER_EOL_INT_AK * |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bus master end of system list acknowledge (to clear interrupt, writer '1')                                |    |   |   |   |   |   |   |   |   |   |   |
| A      | R/W | GP_INT_EN              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable general purpose I/O interrupt: (default = 0)<br>0 = Disable<br>1 = Enable                          |    |   |   |   |   |   |   |   |   |   |   |
| B      | R   | GP_INT *               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | General purpose I/O interrupt                                                                             |    |   |   |   |   |   |   |   |   |   |   |
|        | W   | GP_INT_AK *            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | General purpose I/O acknowledge (to clear interrupt, write '1')                                           |    |   |   |   |   |   |   |   |   |   |   |
| C      | R   | CRTC2_VLINE_SYNC       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>(NOT supported)</b><br>Vertical line sync of the second CRT<br>0 = Even scan line<br>1 = Odd scan line |    |   |   |   |   |   |   |   |   |   |   |

| Cont'd |     | CRTC_INT_CNTL        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                           |   |   |   |   |   |   |   |
|--------|-----|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | F                    | E  | D  | C  | B  | A  | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j | i | h                                                                                                         | g | f | e | d | c | b | a |
| D      | R/W | SNAPSHOT2_INT_EN *   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Enable snapshot interrupt (active high):<br>0 = Disable (default)<br>1 = Enable |   |   |   |   |   |   |   |
| E      | R   | SNAPSHOT2_INT *      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Snapshot interrupt (active high)                                                |   |   |   |   |   |   |   |
|        | W   | SNAPSHOT2_INT_AK *   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Snapshot interrupt acknowledge (to clear interrupt, write '1')                  |   |   |   |   |   |   |   |
| F      | R   | VBLANK_BIT2_INT *    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Secondary VBLZNK bit interrupt                                                                            |   |   |   |   |   |   |   |
|        | W   | VBLANK_BIT2_INT_AK * |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Secondary VBLZNK bit acknowledge                                                                          |   |   |   |   |   |   |   |

\*Two separate writes are required to program this register correctly. The first write should be used to clear the appropriate interrupts (prior to enabling), the second write should then be used to enable the interrupts. Clearing and enabling of interrupts should **not** be attempted in a single write.

### Description

This register is used for enabling and acknowledging interrupts generated by the accelerator CRTC, video capture and overlay display, and for reading the status of the CRTC.

### Usage

Use this register to achieve smooth animation, or reduce flickering and tearing.

### See Also

CRTC\_VLINE\_CRNT\_VLINE on [page 4-48](#)

*mach64* Programmer's Guide:

- *Advanced Topics: Interrupts*
- *Advanced Topics: CRT Synchronization and Animation*

|      |     | CRTC_GEN_CNTL       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                                                                                                                                                                                         |   | Offset: 0_07 |   |   |   |   |   |
|------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------------|---|---|---|---|---|
| BITS |     | 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 |
|      |     | B                   | A  | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  | h  | g  | f | e | d                                                                                                                                                                                                                                                                       | c | b            | a |   |   |   |   |
| a    | R/W | CRTC_DBL_SCAN_EN    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable double scan<br>0 = Disable (default)<br>1= Enable                                                                                                                                                                                                                |   |              |   |   |   |   |   |
| b    | R/W | CRTC_INTERLACE_EN   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable Interlace<br>0 = Disable (default)<br>1= Enable                                                                                                                                                                                                                  |   |              |   |   |   |   |   |
| c    | R/W | CRTC_HSYNC_DIS      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Disable horizontal sync output: (default = 0)<br>0 = Enable<br>1= Disable                                                                                                                                                                                               |   |              |   |   |   |   |   |
| d    | R/W | CRTC_VSYNC_DIS      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Disable vertical sync output: (default = 0)<br>0 = Enable<br>1= Disable                                                                                                                                                                                                 |   |              |   |   |   |   |   |
| e    | R/W | CRTC_CSYNC_EN       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable composite sync on horizontal sync output: (default = 0)<br>0 = Disable<br>1= Enable                                                                                                                                                                              |   |              |   |   |   |   |   |
| f    | R/W | CRTC2_DBL_SCAN_EN   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Enable double scan on the secondary display: (default = 0)<br>0 = Disable<br>1= Enable                                                                                                                                                        |   |              |   |   |   |   |   |
| g    | R/W | CRTC_DISPLAY_DIS    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Disable the display (forcing the blanking signal to be active):<br>0 = Enable (default)<br>1= Disable                                                                                                                                                                   |   |              |   |   |   |   |   |
| h    | R/W | CRTC_VGA_XOVERSCAN  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable overscan in VGA mode: (default = 0)<br>0 = Disable<br>1 = Enable                                                                                                                                                                                                 |   |              |   |   |   |   |   |
| i    | R/W | CRTC_PIX_WIDTH      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Display pixel width:<br>0 = Reserved<br>1 = 4 bpp pseudo (DAC_DIRECT must be 0)<br>2 = 8 bpp pseudo when DAC_DIRECT = 0, OR 8 bpp (3,3,2) when DAC_DIRECT = 1<br>3 = 15 bpp (5,5,5)<br>4 = 16 bpp (5,6,5)<br>5 = 24 bpp (8,8,8)<br>6 = 32 bpp (a,8,8,8)<br>7 = Reserved |   |              |   |   |   |   |   |
| j    | R/W | CRTC_BYTE_PIX_ORDER |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable reversing pixel order within each memory byte in 4 bpp mode.<br>0 = Pixel order from MSNibble to LSNibble.<br>1 = Pixel order from LSNibble to MSNibble.                                                                                                         |   |              |   |   |   |   |   |

| Cont'd   |     | CRTC_GEN_CNTL      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                                                                                                                                                         |   |   | Offset: 0_07 |   |   |   |   |
|----------|-----|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|--------------|---|---|---|---|
| BITS     |     | 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 |
|          |     | B                  | A  | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  | h  | g  | f | e | d                                                                                                                                                                                                                                       | c | b | a            |   |   |   |   |
| <b>k</b> | R/W | CRTC_VSYNC_INT_EN  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Vertical sync interrupt enable of primary display<br>0 = Disable<br>1 = Enable                                                                                                                                                          |   |   |              |   |   |   |   |
| <b>l</b> | R   | CRTC_VSYNC_INT     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Vertical sync started since last cleared<br>0 = No event<br>1 = Event has occurred, interrupting if enabled                                                                                                                             |   |   |              |   |   |   |   |
|          | W   | CRTC_VSYNC_INT_AK  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 1 = Clear CRTC_VSYNC_INT status                                                                                                                                                                                                         |   |   |              |   |   |   |   |
| <b>m</b> | R/W | CRTC2_VSYNC_INT_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Enable vertical sync interrupt of second display:<br>0 = Disable (default )<br>1 = Enable                                                                                                                     |   |   |              |   |   |   |   |
| <b>n</b> | R   | CRTC2_VSYNC_INT    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Vertical sync started since last cleared<br>0 = No event<br>1 = Event has occurred, interrupting if enabled                                                                                                   |   |   |              |   |   |   |   |
|          | W   | CRTC2_VSYNC_INT    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>To clear the status of CRTC2_VSYNC_INT, write '1'                                                                                                                                                             |   |   |              |   |   |   |   |
| <b>o</b> | R/W | HVSYNC_IO_DRIVE    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Set output drive strength for the HSYNC and VSYNC pins: (default = 1)<br>0 = No boost<br>1 = Boost                                                                                                                                      |   |   |              |   |   |   |   |
| <b>p</b> | R/W | CRTC2_PIX_WIDTH    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Set second display pixel width<br>000 = Disable second CRT<br>001 = Reserved<br>010 = 8 bpp<br>011 = 15 bpp (5,5,5)<br>100 = 16 bpp (5,6,5)<br>101 = 24 bpp (8,8,8)<br>110 = 32 bpp (a,8,8,8)<br>111 = YUV422 |   |   |              |   |   |   |   |
| <b>q</b> | R/W | VGA_128KAP_PAGING  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable extended aperture paging in 128K VGA aperture mode:<br>(default = 0)<br>0 = Disable<br>1 = Enable                                                                                                                                |   |   |              |   |   |   |   |
| <b>r</b> | R/W | CRTC2_ENABLE       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | <b>(NOT supported)</b><br>Enable second CRT controller<br>0 = Reset CRTC2 (default)<br>1 = Enable                                                                                                                                       |   |   |              |   |   |   |   |

| Cont'd |     | CRTC_GEN_CNTL        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Offset: 0_07                                                                                  |                                                                                                            |   |   |   |   |   |   |  |  |  |  |
|--------|-----|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|--|--|--|--|
| BITS   |     | 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 |  |  |  |  |
|        |     | B                    | A  | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  | h  | g  | f | e | d                                                                                             | c                                                                                                          | b | a |   |   |   |   |  |  |  |  |
| s      | R/W | CRTC_LOCK_REGS       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                               | Lock extended CRTC registers from being written to:<br>0 = Unlock (read and write)<br>1 = Lock (read only) |   |   |   |   |   |   |  |  |  |  |
| t      | R/W | CRTC_SYNC_TRISTATE   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                               | 0 = Normal<br>1 = Tri-state hsync and vsync                                                                |   |   |   |   |   |   |  |  |  |  |
| u      | R/W | CRTC_EXT_DISP_EN     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                               | Enable extended display mode: (default = 0)<br>0 = Disable (i.e. use VGA display)<br>1 = Enable            |   |   |   |   |   |   |  |  |  |  |
| v      | R/W | CRTC_ENABLE          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                               | Enable CRT controller: (default = 0)<br>0 = Disable (i.e. resets CRTC)<br>1 = Enable CRTC                  |   |   |   |   |   |   |  |  |  |  |
| w      | R/W | CRTC_DISP_REQ_ENB    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                               | Enable display requests: (default = 1)<br>0 = Enable<br>1 = Disable                                        |   |   |   |   |   |   |  |  |  |  |
| x      | R/W | VGA_ATI_LINEAR       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                               | Enable linear addressing through VGA aperture: (default = 0)<br>0 = Disable<br>1 = Enable                  |   |   |   |   |   |   |  |  |  |  |
| y      | R/W | CRTC_VSYNC_FALL_EDGE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                               | Select VSYNC edge to start frame sequence<br>0 = Rising edge of VSYNC<br>1 = Falling edge of VSYNC         |   |   |   |   |   |   |  |  |  |  |
| z      | R/W | VGA_TEXT_132         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Select extended text mode (linear address 132 column text mode)<br>1 = Active<br>0 = Inactive |                                                                                                            |   |   |   |   |   |   |  |  |  |  |
| A      | R/W | VGA_XCRT_CNT_EN      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                               | Enable extended CRTC display address counter (active high)                                                 |   |   |   |   |   |   |  |  |  |  |
| B      | R/W | VGA_CUR_B_TEST       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                               | Test cursor blinking (active high)                                                                         |   |   |   |   |   |   |  |  |  |  |

### Description

All miscellaneous initialization bits for the accelerator CRTC are contained in CRTC\_GEN\_CNTL.

CRTC\_HSYNC\_DIS and CRTC\_VSYNC\_DIS are used specifically for the Display Power Management System (DPMS).

CRTC\_PIX\_WIDTH and CRTC\_BYTE\_PIX\_ORDER are used to specify pixel arrangement in memory. These bits correspond exactly to their respective fields in DP\_PIX\_WIDTH.

CRTC\_FIFO\_LWM is used only in DRAM configurations. It specifies the emptiness of the display FIFO that must be reached before the CRTC should get more data from

memory. There is a lower limit before the display becomes corrupted. The upper limit is 15 because the size of the display FIFO is 16 entries deep. The higher the number, the greater the number of memory page faults. This leads to a decrease in available memory bandwidth, which in turn leads to a slower draw engine.

### Usage

Use this register only for mode switching. It should be touched only by the adapter BIOS.

### See Also

*mach64* Programmer's Guide:

- *Advanced Topics: Manual Mode Switching and Custom CRT Modes: Manual Mode Switching*
- *Advanced Topics: Manual Mode Switching and Custom CRT Modes: Designing a Custom CRT Mode*
- *Appendix C, CRTC Parameters*

|      |     |                    | <b>CRT_TRAP</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                         |    |    |    |    |    |    |   |   |   |   | Offset: 0_0E |   |   |   |   |   |
|------|-----|--------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|--------------|---|---|---|---|---|
| BITS |     |                    | 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 |
|      |     | c                  | b               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                         |    | a  |    |    |    |    |   |   |   |   |              |   |   |   |   |   |
| a    | R/W | CRT_TRAP_BASE_ADDR |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Base address bits [22:12] for writing CRT trapped addresses<br>Note: This implies the address is 4K aligned                                                                             |    |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |
| b    | R   | DAC_RGB_STATE      |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Status of RGB DAC index reads/writes:<br>00 = All RGB colors written<br>01 = Red color index written (await green/blue)<br>10 = Green color index written (await blue)<br>11 = Reserved |    |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |
| c    | R/W | CRT_TRAP_EN        |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable VGA CRT register trapping: (default = 0)<br>0 = Disable<br>1 = Enable                                                                                                            |    |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |

### Usage

This register is used to trap all accesses through VGA I/O space to VGA CRTC registers or DAC palette when trapping is enabled.

### 4.2.3 Overscan Registers

In order to do centering on the high resolution LCD panels, the width for Left, Right, Top and Bottom Overscan is increased (the field names have not changed but their bit sizes have).

Similar to the case of Second CRTC registers, the two Overscan registers, OVER\_WID\_LEFT\_RIGHT and OVER\_WID\_TOP\_BOTTOM, and OVR\_CLR are duplicated and accessed using CRTC\_RW\_SELECT@LCD\_GEN\_CRTL = 1

Display overscan is enabled if any of the overscan width values are non-zero. The left and right overscan widths are described in terms of pixels\*8 and the top and bottom overscan widths are described in terms of vertical lines.

The overscan color is defined by an 8-bit index and a 24-bit color. In all display modes, the 24-bit color will be used by the internal RAMDAC and displayed on the monitor attached to the RAGE XL. Note this is always a true color that is not mapped through the palette. The 8-bit index color is used in 4 bpp and 8 bpp modes for data going out on the 8-bit feature connector. The receiving board is expected to index all 4 bpp and 8 bpp data through its own palette.

|      |     | OVR_CLR   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                        |    |    |    |    |    |   |   |   |   | Offset: 0_10 |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------|----|----|----|----|----|---|---|---|---|--------------|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | c         |    |    |    |    |    |    |    | b  |    |    |    |    |    |    |    | a                                      |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | OVR_CLR_B |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Blue overscan color (to internal DAC)  |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | OVR_CLR_G |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Green overscan color (to internal DAC) |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | OVR_CLR_R |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Red overscan color (to internal DAC)   |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### Description

This register specifies the overscan color for the first display path.

#### Usage

This register should be touched only by the adapter BIOS when mode switching, or by the adapter installation program for overscan configuration.

#### See Also

CUR\_CLR0 on [page 4-61](#)

*mach64* Programmer's Guide:

- Advanced Topics: Manual Mode Switching and Custom CRT Modes: Designing a Custom CRT Mode

In order to do centering on the high resolution LCD panels, the width for Left, Right, Top and Bottom overscan is increased.

| OVR_WID_LEFT_RIGHT |     |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Offset: 0_11 |  |
|--------------------|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------------|--|
| BITS               |     | 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            |  |
|                    |     | b             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |              |  |
| a                  | R/W | OVR_WID_LEFT  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Left overscan width (8*pixels)  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |              |  |
| b                  | R/W | OVR_WID_RIGHT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Right overscan width (8*pixels) |    |    |    |    |    |   |   |   |   |   |   |   |   |   |              |  |

| OVR_WID_TOP_BOTTOM |     |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                       |    |    |    |    |    |   |   |   |   |   |   |   | Offset: 0_12 |   |   |
|--------------------|-----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|--------------|---|---|
| BITS               |     | 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 |
|                    |     | b              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                                     |    |    |    |    |    |   |   |   |   |   |   |   |              |   |   |
| a                  | R/W | OVR_WID_TOP    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Top overscan width (in scan lines)    |    |    |    |    |    |   |   |   |   |   |   |   |              |   |   |
| b                  | R/W | OVR_WID_BOTTOM |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bottom overscan width (in scan lines) |    |    |    |    |    |   |   |   |   |   |   |   |              |   |   |

The following OVR2\_\* registers are NOT supported in Rage XL.

| OVR2_CLR |     |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                              |    |    |    |    |    |   |   |   |   |   |   | Offset: 0_10 |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------|-----|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|--------------|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS     |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| LT       |     | c          |    |    |    |    |    |    |    | b  |    |    |    |    |    |    |    | a                                            |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a        | R/W | OVR2_CLR_B |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Blue overscan color for second display path  |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b        | R/W | OVR2_CLR_G |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Green overscan color for second display path |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c        | R/W | OVR2_CLR_R |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Red overscan color for second display path   |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| OVR2_WID_LEFT_RIGHT |     |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|-----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS                |     | 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 |
|                     |     | b              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a                   | R/W | OVR2_WID_LEFT  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Left overscan width (8*pixels)  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b                   | R/W | OVR2_WID_RIGHT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Right overscan width (8*pixels) |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| OVR2_WID_TOP_BOTTOM |     |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|-----|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS                |     | 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 |
|                     |     | b               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                                     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a                   | R/W | OVR2_WID_TOP    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Top overscan width (in scan lines)    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b                   | R/W | OVR2_WID_BOTTOM |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bottom overscan width (in scan lines) |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### 4.2.4 Hardware Cursor Registers

The Rage XL supports a single hardware cursor of maximum size 64x64 pixels. The registers for the hardware cursor are shown below.

|      |     |            | CUR_OFFSET |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                     |    |    |    |    |    |   |   |   |   |   | Offset: 0_1A |   |   |   |   |
|------|-----|------------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------|----|----|----|----|----|---|---|---|---|---|--------------|---|---|---|---|
| BITS |     | 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 |
|      |     |            |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                                                   |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |
| a    | R/W | CUR_OFFSET |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Cursor/icon address offset in terms of 64 bit words |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |

|      |     |               | CUR_HORZ_VERT_POSN |    |    |    |    |    |    |    |    |    |    |                            |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Offset: 0_1B |   |   |   |   |  |  |  |  |
|------|-----|---------------|--------------------|----|----|----|----|----|----|----|----|----|----|----------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------------|---|---|---|---|--|--|--|--|
| BITS |     | 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 |  |  |  |  |
|      |     |               |                    |    |    |    |    |    |    |    |    |    |    | b                          |    |    |    |    |    |    |    |    |    |   |   | a |   |   |              |   |   |   |   |  |  |  |  |
| a    | R/W | CUR_HORZ_POSN |                    |    |    |    |    |    |    |    |    |    |    | Cursor horizontal position |    |    |    |    |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |  |  |  |  |
| b    | R/W | CUR_VERT_POSN |                    |    |    |    |    |    |    |    |    |    |    | Cursor vertical position   |    |    |    |    |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |  |  |  |  |

|      |     |              | CUR_HORZ_VERT_OFF |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Offset: 0_1C |   |   |   |   |  |  |  |  |
|------|-----|--------------|-------------------|----|----|----|----|----|----|----|----|----|----|--------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------------|---|---|---|---|--|--|--|--|
| BITS |     | 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 |  |  |  |  |
|      |     |              |                   |    |    |    |    |    |    |    |    |    |    | b                        |    |    |    |    |    |    |    |    |    |   |   | a |   |   |              |   |   |   |   |  |  |  |  |
| a    | R/W | CUR_HORZ_OFF |                   |    |    |    |    |    |    |    |    |    |    | Cursor horizontal offset |    |    |    |    |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |  |  |  |  |
| b    | R/W | CUR_VERT_OFF |                   |    |    |    |    |    |    |    |    |    |    | Cursor vertical offset   |    |    |    |    |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |  |  |  |  |

|      |     |            | CUR_CLR0 |    |    |    |    |    |    |    |    |    |    |                                                                  |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Offset: 0_18 |   |   |   |   |  |  |  |  |   |
|------|-----|------------|----------|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------------|---|---|---|---|--|--|--|--|---|
| XL   |     | d          |          |    |    |    |    |    |    |    |    |    |    | c                                                                |    |    |    |    |    |    |    |    |    |   |   | b |   |   |              |   |   |   |   |  |  |  |  | a |
| BITS |     | 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 |  |  |  |  |   |
| a    | R/W | CUR_CLR0_8 |          |    |    |    |    |    |    |    |    |    |    | Cursor color 0 INDEX, output on feature connector in 4 and 8 bpp |    |    |    |    |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |  |  |  |  |   |
| b    | R/W | CUR_CLR0_B |          |    |    |    |    |    |    |    |    |    |    | Blue cursor color 0, to internal DAC                             |    |    |    |    |    |    |    |    |    |   |   |   |   |   |              |   |   |   |   |  |  |  |  |   |

| Cont'd | CUR_CLR0 |            |    |    |    |    |    |    |    |                                       |    |    |    |    |    |    | Offset: 0_18 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|----------|------------|----|----|----|----|----|----|----|---------------------------------------|----|----|----|----|----|----|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS   | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XL     | d        |            |    |    |    |    |    |    | c  |                                       |    |    |    |    |    |    | b            |    |    |    |    |    |   |   | a |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c      | R/W      | CUR_CLR0_G |    |    |    |    |    |    |    | Green cursor color 0, to internal DAC |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d      | R/W      | CUR_CLR0_R |    |    |    |    |    |    |    | Red cursor color 0, to internal DAC   |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Cont'd | CUR_CLR1 |            |    |    |    |    |    |    |    |                                                                |    |    |    |    |    |    | Offset: 0_19 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|----------|------------|----|----|----|----|----|----|----|----------------------------------------------------------------|----|----|----|----|----|----|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS   | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XL     | d        |            |    |    |    |    |    |    | c  |                                                                |    |    |    |    |    |    | b            |    |    |    |    |    |   |   | a |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a      | R/W      | CUR_CLR1_8 |    |    |    |    |    |    |    | Cursor color 1 INDEX, output on feature connector in 4 & 8 bpp |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b      | R/W      | CUR_CLR1_B |    |    |    |    |    |    |    | Blue cursor color 1, to internal DAC                           |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c      | R/W      | CUR_CLR1_G |    |    |    |    |    |    |    | Green cursor color 1, to internal DAC                          |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d      | R/W      | CUR_CLR1_R |    |    |    |    |    |    |    | Red cursor color 1, to internal DAC                            |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

*The following CUR2\_\* registers are NOT supported in RAGE XL.*

(NOT supported in RAGE XL)

| Cont'd | CUR2_CLR0 |             |    |    |    |    |    |    |    |                                                                  |    |    |    |    |    |    | Offset: 0_18 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|-----------|-------------|----|----|----|----|----|----|----|------------------------------------------------------------------|----|----|----|----|----|----|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS   | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XL     | d         |             |    |    |    |    |    |    | c  |                                                                  |    |    |    |    |    |    | b            |    |    |    |    |    |   |   | a |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a      | R/W       | CUR2_CLR0_8 |    |    |    |    |    |    |    | Cursor color 0 INDEX, output on feature connector in 4 and 8 bpp |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b      | R/W       | CUR2_CLR0_B |    |    |    |    |    |    |    | Blue cursor color 0, to internal DAC                             |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c      | R/W       | CUR2_CLR0_G |    |    |    |    |    |    |    | Green cursor color 0, to internal DAC                            |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d      | R/W       | CUR2_CLR0_R |    |    |    |    |    |    |    | Red cursor color 0, to internal DAC                              |    |    |    |    |    |    |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| CUR2_CLR1 |     |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                |    |    |    |    |    |   |   |   |   |   |   |   |   | Offset: 0_19 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-----------|-----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|--------------|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS      |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XL        |     | d           |    |    |    |    |    |    |    | c  |    |    |    |    |    |    |    | b                                                              |    |    |    |    |    |   |   | a |   |   |   |   |   |              |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a         | R/W | CUR2_CLR1_8 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Cursor color 1 INDEX, output on feature connector in 4 & 8 bpp |    |    |    |    |    |   |   |   |   |   |   |   |   |              |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b         | R/W | CUR2_CLR1_B |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Blue cursor color 1, to internal DAC                           |    |    |    |    |    |   |   |   |   |   |   |   |   |              |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c         | R/W | CUR2_CLR1_G |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Green cursor color 1, to internal DAC                          |    |    |    |    |    |   |   |   |   |   |   |   |   |              |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d         | R/W | CUR2_CLR1_R |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Red cursor color 1, to internal DAC                            |    |    |    |    |    |   |   |   |   |   |   |   |   |              |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| CUR2_OFFSET |     |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                |    |    |    |    |    |   |   |   |   |   |   |   |   | Offset: 0_1A |   |
|-------------|-----|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|--------------|---|
| BITS        |     | 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 |
| XL          |     | XXXXXXXXXXXXXXXXXXXX |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                                              |    |    |    |    |    |   |   |   |   |   |   |   |   |              |   |
| a           | R/W | CUR2_OFFSET          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Cursor address offset in terms of 64 bit words |    |    |    |    |    |   |   |   |   |   |   |   |   |              |   |

| CUR2_HORZ_VERT_POSN |     |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                            |    |    |    |    |    |   |   |   |   |   |   |   | Offset: 0_1B |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------|-----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------|----|----|----|----|----|---|---|---|---|---|---|---|--------------|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS                |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XL                  |     | XXXXXXXX       |    |    |    |    |    |    |    | b  |    |    |    |    |    |    |    | XXXXXXXX                   |    |    |    |    |    |   |   | a |   |   |   |   |              |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a                   | R/W | CUR2_HORZ_POSN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Cursor horizontal position |    |    |    |    |    |   |   |   |   |   |   |   |              |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b                   | R/W | CUR2_VERT_POSN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Cursor vertical position   |    |    |    |    |    |   |   |   |   |   |   |   |              |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| CUR2_HORZ_VERT_OFF |     |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                      |   |   |   |   | Offset: 0_1C |   |   |   |  |  |  |  |  |  |  |
|--------------------|-----|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|----|----|----|----|----|---|---|----------------------|---|---|---|---|--------------|---|---|---|--|--|--|--|--|--|--|
| BITS               |     | 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 |   |  |  |  |  |  |  |  |
| XL                 |     | XXXXXXXXXXXXXXXXXXXX |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | b                        |    |    |    |    |    |   |   | XXXXXXXXXXXXXXXXXXXX |   |   |   |   |              |   |   | a |  |  |  |  |  |  |  |
| a                  | R/W | CUR2_HORZ_OFF        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Cursor horizontal offset |    |    |    |    |    |   |   |                      |   |   |   |   |              |   |   |   |  |  |  |  |  |  |  |
| b                  | R/W | CUR2_VERT_OFF        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Cursor vertical offset   |    |    |    |    |    |   |   |                      |   |   |   |   |              |   |   |   |  |  |  |  |  |  |  |

#### 4.2.5 GenLocking (CRT-Sync to Video) Registers

The GenLocking registers are used to indicate the *snapshot* values of the CRTC horizontal/vertical count, video frame and CRT frame count, captured automatically or manually. These values are used for calculating the frame rate drift between CRTC and Video frames, which in turn is used to reprogram PLL M and N (CLKBLK) to synchronize the frame rates.

|      |   | SNAPSHOT_VH_COUNTS |    |    |    |    |    |    |    |    |    |    |    |                                         |    |    |    |    |    |    |    |    |    |   |   | Offset: 1_1C |   |   |   |   |   |   |   |
|------|---|--------------------|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------|----|----|----|----|----|----|----|----|----|---|---|--------------|---|---|---|---|---|---|---|
| BITS |   | 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 |
|      |   | b                  |    |    |    |    |    |    |    |    |    |    |    | a                                       |    |    |    |    |    |    |    |    |    |   |   |              |   |   |   |   |   |   |   |
| a    | R | SNAPSHOT_VCOUNT    |    |    |    |    |    |    |    |    |    |    |    | Snapshot of CRTC horizontal count value |    |    |    |    |    |    |    |    |    |   |   |              |   |   |   |   |   |   |   |
| b    | R | SNAPSHOT_HCOUNT    |    |    |    |    |    |    |    |    |    |    |    | Snapshot of CRTC vertical count value   |    |    |    |    |    |    |    |    |    |   |   |              |   |   |   |   |   |   |   |

|      |   | SNAPSHOT_F_COUNT |    |    |    |    |    |    |    |    |    |    |    |                                     |    |    |    |    |    |    |    |    |    |   |   |   | Offset: 1_1D |   |   |   |   |   |   |  |
|------|---|------------------|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|--------------|---|---|---|---|---|---|--|
| BITS |   | 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 |  |
|      |   | b                |    |    |    |    |    |    |    |    |    |    |    | a                                   |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |  |
| a    | R | SNAPSHOT_F_COUNT |    |    |    |    |    |    |    |    |    |    |    | Snapshot of CRTC frame count value. |    |    |    |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |  |

*The following two SNAPSHOT2\_\* registers are NOT supported in RAGE XL*

|      |   | SNAPSHOT2_VH_COUNTS |    |    |    |    |    |    |    |    |    |    |    |                                                |    |    |    |    |    |    |    |    |    |   |   | MM: 1_2C |   |   |   |   |   |   |   |
|------|---|---------------------|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|
| BITS |   | 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 |
|      |   | b                   |    |    |    |    |    |    |    |    |    |    |    | a                                              |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |
| a    | R | SNAPSHOT2_VCOUNT    |    |    |    |    |    |    |    |    |    |    |    | Snapshot of second CRTC horizontal count value |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |
| b    | R | SNAPSHOT2_HCOUNT    |    |    |    |    |    |    |    |    |    |    |    | Snapshot of second CRTC vertical count value   |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |

|             |     |                          | <b>SNAPSHOT2_F_COUNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                            | <b>MM: 1_2D</b> |   |   |   |   |   |   |  |
|-------------|-----|--------------------------|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|--------------------------------------------|-----------------|---|---|---|---|---|---|--|
| <b>BITS</b> |     | 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 |  |
|             |     |                          |                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                            | a               |   |   |   |   |   |   |  |
| a           | R/W | <b>SNAPSHOT2_F_COUNT</b> |                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Snapshot of second CRTC frame count value. |                 |   |   |   |   |   |   |  |

|             |     |                        | <b>N_VIF_COUNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                                                                                                                                                                   | <b>Offset: 1_1E</b> |   |   |   |   |   |   |  |
|-------------|-----|------------------------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---|---|---|---|---|---|--|
| <b>BITS</b> |     | 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 |  |
|             |     |                        |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                                                                                                                                                                   | a                   |   |   |   |   |   |   |  |
| a           | R/W | <b>N_VIF_COUNT_VAL</b> |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Programmable N-Video-in-Field count value used to generate a snapshot interrupt when this N-count value is equal to the count value of the lower 10 bit SNAPSHOT_VIF_COUNT. Refer to CRTC_INT_CNTL [8:7] for the snapshot interrupt specification |                     |   |   |   |   |   |   |  |

### Usage

This register is pre-programmed to non-zero 'N' of the Video-in-Field to capture count values automatically. When this non-zero N value is expired, an interrupt is triggered to indicate an auto-snapshot has been taken.

(NOT supported in RAGE XL)

|             |     |                         | <b>N_VIF2_COUNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                                                                                                                                                                            | <b>MM: 1_2E</b> |   |   |   |   |   |   |  |
|-------------|-----|-------------------------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---|---|---|---|---|---|--|
| <b>BITS</b> |     | 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 |  |
|             |     |                         |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                                                                                                                                                                            | a               |   |   |   |   |   |   |  |
| a           | R/W | <b>N_VIF2_COUNT_VAL</b> |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Programmable N-video-in-field count value which is used to generate a snapshot interrupt when this N-count value is equal to the count value of the lower 10-bit SNAPSHOT_VIF_COUNT. Refer to CRTC_INT_CNTL [8:7] for the snapshot interrupt specification |                 |   |   |   |   |   |   |  |

### See also:

CRTC\_INT\_CNTL register ([page 4-50](#)), bits [8:7] - 0\_06 for the snapshot interrupt specification.

|      |     | SNAPSHOT_VIF_COUNT  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 1_1F                                                                                                                                                                                     |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| BITS |     | 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 |  |  |  |  |
|      |     | d c                 |    |    |    |    |    |    |    | b  |    |    |    |    |    |    |    | a  |    |    |    |                                                                                                                                                                                                  |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| a    | R   | LSNAPSHOT_VIF_COUNT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Lower snapshot of Video_in_Field count value.<br>(Lower 10 bits [9:0] indicate the current number of frames accumulated.)                                                                        |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| b    | R   | USNAPSHOT_VIF_COUNT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Upper snapshot of Video_in_Field count value.<br>(Upper 11 bits [20:10] indicate the current number of N-frames.)                                                                                |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| c    | R/W | AUTO_SNAPSHOT_TAKEN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = writing '0' enables both auto and manual snapshot taking and clears internal SNAPSHOT_F_COUNT and SNAPSHOT_VIF_COUNT counters (W).<br>1 = indicates that a snapshot has been taken (R)       |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| d    | W   | MANUAL_SNAPSHOT_NOW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1 = snapshot taken immediately<br>(writing '1' to this bit prevents all auto-snapshot taking until a write of '0' to the AUTO_SNAPSHOT_TAKEN bit which will re-enable the auto-snapshot taking.) |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

### Usage

Use this register to calculate the total number of Video-in-Field frames. Use the following equation:

$$\text{Total VIF frame count} = (\text{N_VIF_COUNT_VAL} * \text{USNAPSHOT_VIF_COUNT}) + \text{LSNAPSHOT_VIF_COUNT}$$

(NOT supported in RAGE XL)

|      |     | SNAPSHOT2_VIF_COUNT  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 1_2F                                                                                                                                                                                                                                                                       |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|------|-----|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| BITS |     | 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 |  |  |  |  |
|      |     | c b                  |    |    |    |    |    |    |    | a  |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                                |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| a    | R   | SNAPSHOT2_VIF_COUNT  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Snapshot of Video-in-field count value:<br>Lower 10-bit [[9:0] indicates the current number of frames accumulated.<br>Upper 11-bit [20:10] indicates the number of N-frames.<br>Total frame count = (N_VIF2_COUNT_VAL x Upper SNAPSHOT2_VIF_COUNT) + Lower SNAPSHOT2_VIF_COUNT |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| b    | R/W | AUTO_SNAPSHOT2_TAKEN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = writing '0' enables both auto and manual snapshot taking, and clears SNAPSHOT2_F_COUNT and SNAPSHOT2_VIF_COUNT counters (W).<br>1 = indicates that a snapshot for second CRT has been taken (R)                                                                            |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

| Cont'd |   | SNAPSHOT2_VIF_COUNT  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 1_2F                                                                                                                                                                                          |    |   |   |   |   |   |   |   |   |   |   |
|--------|---|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |   | 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 |
|        |   |                      |    |    |    | c  | b  |    |    |    |    | a  |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                   |    |   |   |   |   |   |   |   |   |   |   |
| c      | W | MANUAL_SNAPSHOT2_NOW |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1 = Snapshot taken immediately<br>(writing '1' to this bit prevents all auto-snapshot taking until a writing of '0' to the AUTO_SNAPSHOT2_TAKEN bit that will re-enable the auto-snapshot taking) |    |   |   |   |   |   |   |   |   |   |   |

#### 4.2.6 Clock Control Registers

|      |     | CLOCK_CNTL  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | Offset: 0_24 |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|--------------|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     |             |    |    |    |    |    |    |    |    |    |    |    | e  |    |    | d  |    |    | c  |    |    | b  |   |   |   |   | a |   |              |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | CLOCK_SEL   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | PLL_WR_EN   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | PLL_ADDR    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d    | R/W | PLL_ADDR(5) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| e    | R/W | PLL_DATA    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### Description

This register selects a pixel clock in non-VGA modes. It is also used for programming the internal clock synthesizer (or PLL registers which are described next). The internal clock synthesizer has only 4 programmable pixel clock settings; therefore, only bits 0 and 1 of CLOCK\_SEL are used.

#### Usage

This register should be touched only by the adapter BIOS when switching video modes.

#### See Also

*mach64* Programmer's Guide:

- Advanced Topics: Manual Mode Switching and Custom CRT Modes

- *Appendix C: CRTC Parameters*
- *Appendix D: Clock Chip Reference*

#### **4.2.7 PLL Control Registers**

The PLL registers are accessed indirectly through the CLOCK\_CNTL register described above. Example reads and writes of the PLL registers are given below. The address CLOCK\_CNTL0 represents bits 7:0, CLOCK\_CNTL1 bits 15:8, and CLOCK\_CNTL2 bits 23:16.

##### **PLL Register Read**

```
iow8 CLOCK_CNTL1 PLL_ADDR ; PLL address to read (PLL_WR_EN = 0)
```

```
ior8 CLOCK_CNTL2 PLL_DATA ; data is put into variable PLL_DATA
```

##### **PLL Register Write**

```
iow8 CLOCK_CNTL1 PLL_ADDR | PLL_WR_EN; PLL address to write and  
PLL_WR_EN = 1
```

```
iow8 CLOCK_CNTL2 PLL_DATA; PLL data to write
```

##### **32 bit I/O write:**

```
iow32 CLOCK_CNTL CLOCK_SEL | PLL_ADDR | PLL_WR_EN | PLL_DATA
```

##### **Notes:**

- PLL registers 0 and 1 control gain and duty cycle of analog PLLs. Gain bits affect lock and jitter of PLLs. These registers should only be adjusted by the BIOS.
- Oscillator is always turned on regardless of whether 14.3 or 29.5 MHz crystal is being used.
- All clock sources can be programmed to exceed the frequency limitations of the hardware. Do not attempt to program the PLL registers without a good understanding of the frequency limitations of all clock nets.
- PLL\_TEST\_CTRL and PLL\_TEST\_COUNT are used only during manufacturing tests of analog PLLs.

The table below is a listing of the PLL registers with their default values.

**Table 4-6 PLL Register Default Values**

| Address | Register Name                           | Default     | Default for Scan |
|---------|-----------------------------------------|-------------|------------------|
| 0       | MPLL_CNTL                               | ACh         | ACh              |
| 1       | VPLL_CNTL                               | ACh         | ACh              |
| 2       | PLL_REF_DIV                             | 24h         | 24h              |
| 3       | PLL_GEN_CNTL                            | DFh         | FFh              |
| 4       | MCLK_FB_DIV                             | F6h         | F6h              |
| 5       | PLL_VCLK_CNTL                           | 04h         | 05h              |
| 6       | VCLK_POST_DIV                           | 00h         | 00h              |
| 7       | VCLK0_FB_DIV                            | FDh         | FDh              |
| 8       | VCLK1_FB_DIV                            | 8Eh         | 8Eh              |
| 9       | VCLK2_FB_DIV                            | 9Eh         | 9Eh              |
| 10      | VCLK3_FB_DIV                            | 65h         | 65h              |
| 11      | PLL_EXT_CNTL                            | 05h         | 05h              |
| 12      | DLL1_CNTL                               | 00h         | 00h              |
| 13      | VFC_CNTL                                | 00h         | 00h              |
| 14      | PLL_TEST_CNTL                           | 00h         | 00h              |
| 15      | PLL_TEST_COUNT                          | 00h         | 00h              |
| 16      | LVDSPLL_CNTL0<br><b>(NOT supported)</b> | 06h         | 06h              |
| 17      | LVDSPLL_CNTL1<br><b>(NOT supported)</b> | CFh         | CFh              |
| 18      | AGP1_CNTL                               | 80h         | 80h              |
| 19      | AGP2_CNTL                               | 00h         | 00h              |
| 20      | DLL2_CNTL                               | 10h         | 10h              |
| 21      | SCLK_FB_DIV                             | F6h         | F6h              |
| 22      | SPLL_CNTL1                              | ACh         | ACh              |
| 23      | SPLL_CNTL2 <b>(NOT supported)</b>       | 53h         | 53h              |
| 24      | APLL_STRAPS                             | -- (straps) | -- (straps)      |

**Table 4-6 PLL Register Default Values**

| Address | Register Name                                 | Default | Default for Scan |
|---------|-----------------------------------------------|---------|------------------|
| 25      | EXT_VPLL_CNTL                                 | 80h     | 80h              |
| 26      | EXT_VPLL_REF_DIV                              | 24h     | 24h              |
| 27      | EXT_VPLL_FB_DIV                               | FDh     | FDh              |
| 28      | EXT_VPLL_MSB                                  | 00h     | 00h              |
| 29      | HTOTAL_CNTL                                   | 00h     | 00h              |
| 30      | BYTE_CLK_CNTL                                 | 00h     | 00h              |
| 31      | TV_PLL_CNTL1 ( <b>NOT supported</b> )         | 02h     | 02h              |
| 32      | TV_PLL_CNTL2 ( <b>NOT supported</b> )         | 06h     | 06h              |
| 33      | TV_PLL_CNTL ( <b>NOT supported</b> )          | ACh     | ACh              |
| 34      | EXT_TV_PLL ( <b>NOT supported</b> )           | 06h     | 2Eh              |
| 35      | V2PLL_CNTL ( <b>NOT supported</b> )           | ACh     | ACh              |
| 36      | PLL_V2CLK_CNTL<br>( <b>NOT supported</b> )    | 14h     | 15h              |
| 37      | EXT_V2PLL_REF_DIV<br>( <b>NOT supported</b> ) | 24h     | 24h              |
| 38      | EXT_V2PLL_FB_DIV<br>( <b>NOT supported</b> )  | FDh     | FDh              |
| 39      | EXT_V2PLL_MSB<br>( <b>NOT supported</b> )     | 00h     | 00h              |
| 40      | HTOTAL2_CNTL ( <b>NOT supported</b> )         | 00h     | 00h              |
| 41      | PLL_YCLK_CNTL                                 | 05h     | 05h              |
| 42      | PM_DYN_CLK_CNTL                               | 55h     | 55h              |

|      |     | MPLL_CNTL    |   |   |                               |   |   |   |   | Addr: 0 |  |  |  |  |  |
|------|-----|--------------|---|---|-------------------------------|---|---|---|---|---------|--|--|--|--|--|
| BITS |     | 7            | 6 | 5 |                               | 4 | 3 | 2 | 1 | 0       |  |  |  |  |  |
|      |     | d            | c |   |                               | b |   | a |   |         |  |  |  |  |  |
| a    | R/W | MPLL_PC_GAIN |   |   | MPLL Charge-pump gain setting |   |   |   |   |         |  |  |  |  |  |
| b    | R/W | MPLL_VC_GAIN |   |   | MPLL VCGEN gain setting       |   |   |   |   |         |  |  |  |  |  |
| c    | R/W | MPLL_D_CYC   |   |   | Duty cycle control for MPLL   |   |   |   |   |         |  |  |  |  |  |

| MPLL_CNTL |     |            |   |   |                    |   |   | Addr: 0 |
|-----------|-----|------------|---|---|--------------------|---|---|---------|
| BITS      | 7   | 6          | 5 | 4 | 3                  | 2 | 1 | 0       |
| d         | c   |            |   | b |                    |   | a |         |
| d         | R/W | MPLL_RANGE |   |   | MPLL range control |   |   |         |

**Description**

This register sets the controls for the MPLL analog macro.

**Usage**

Do not change the default set by BIOS.

| VPLL_CNTL |     |              |   |   |                               |   |   | Addr: 1 |  |  |
|-----------|-----|--------------|---|---|-------------------------------|---|---|---------|--|--|
| BITS      | 7   | 6            | 5 | 4 | 3                             | 2 | 1 | 0       |  |  |
| d         | c   |              |   | b |                               |   | a |         |  |  |
| a         | R/W | VPLL_PC_GAIN |   |   | VPLL Charge-pump gain setting |   |   |         |  |  |
| b         | R/W | VPLL_VC_GAIN |   |   | VPLL VCGEN gain setting       |   |   |         |  |  |
| c         | R/W | VPLL_D_CYC   |   |   | Duty cycle control for VPLL   |   |   |         |  |  |
| d         | R/W | VPLL_RANGE   |   |   | VPLL range control            |   |   |         |  |  |

**Description**

This register sets the controls for the VPLL analog macro.

**Usage**

Do not change the default set by BIOS.

| PLL_REF_DIV |     |             |   |   |                                                            |   |   | Addr: 2 |
|-------------|-----|-------------|---|---|------------------------------------------------------------|---|---|---------|
| BITS        | 7   | 6           | 5 | 4 | 3                                                          | 2 | 1 | 0       |
| a           |     |             |   |   |                                                            |   |   |         |
| a           | R/W | PLL_REV_DIV |   |   | Common reference setting for MPLL and VPLL (default = 24h) |   |   |         |

| PLL_GEN_CNTL |     |              |   |   |   |                                                                                                                                                                                                                                                                                                                                       |   | Addr: 3 |   |  |
|--------------|-----|--------------|---|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|---|--|
| BITS         |     | 7            | 6 | 5 | 4 | 3                                                                                                                                                                                                                                                                                                                                     | 2 | 1       | 0 |  |
| a            | R/W | PLL_SLEEP    |   | f | e | d                                                                                                                                                                                                                                                                                                                                     | c | b       | a |  |
| b            | R/W | PLL_MRESET   |   |   |   | 1 = Reset PLL                                                                                                                                                                                                                                                                                                                         |   |         |   |  |
| c            | R/W | OSC_EN       |   |   |   | 1 = Enable oscillator                                                                                                                                                                                                                                                                                                                 |   |         |   |  |
| d            | R/W | EXT_CLK_EN   |   |   |   | 1 = Force DCLK pin output to tri-state                                                                                                                                                                                                                                                                                                |   |         |   |  |
| e            | R/W | MCLK_SRC_SEL |   |   |   | Select MCLK (MCLK is GUI and 3D Engine clock)<br>000 = MCLK set to PLLMCLK (MPPLL primary output)<br>001 = MCLK set to PLLMCLK/2<br>010 = MCLK set to PLLMCLK/4<br>011 = MCLK set to PLLMCLK/8<br>100 = MCLK set to PLLMCLK/3<br>101 = MCLK set to CPUCLK<br>110 = MCLK set to SCLK HCLK (direct, no DLL)<br>111 = MCLK set to XTALIN |   |         |   |  |
| f            | R/W | DLL_PWDN     |   |   |   | 0 = Enable DLL<br>1 = Power down DLL (for full powerdown, set DLL_GAIN = 10)                                                                                                                                                                                                                                                          |   |         |   |  |

**Description**

This register sets up the PLL and DLL general controls, and MCLK source, and/or post divider selection (default = CFh).

| MCLK_FB_DIV |     |             |   |   |   |                                               |   | Addr: 4 |   |
|-------------|-----|-------------|---|---|---|-----------------------------------------------|---|---------|---|
| BITS        |     | 7           | 6 | 5 | 4 | 3                                             | 2 | 1       | 0 |
|             |     |             |   |   |   | a                                             |   |         |   |
| a           | R/W | MCLK_FB_DIV |   |   |   | MPLL feedback divider (default = F6h, 50 MHz) |   |         |   |

**Description**

This register sets up the MPPLL feedback divider.

**Usage**

MPPLL output (PLLMCLK) will run at:

$$\text{PLLMCLK} = (\text{XTALIN} * x * \text{MCLK_FB_DIV}) / (\text{PLL_REF_DIV})$$

where  $x$  is either 2 or 4 as set by MFB\_TIMES\_4\_2b@PLL\_EXT\_CNTL

| PLL_VCLK_CNTL |     |              |   |   |                                                                                                                                                                                                                           |   |   | Addr: 5 |   |  |  |
|---------------|-----|--------------|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---------|---|--|--|
| BITS          |     | 7            | 6 | 5 | 4                                                                                                                                                                                                                         | 3 | 2 | 1       | 0 |  |  |
|               |     | e            |   | d |                                                                                                                                                                                                                           | c | b | a       |   |  |  |
| a             | R/W | VCLK_SRC_SEL |   |   | Select VLCK_SRC (VLC is the pixel clock)<br>00 = VCLK_SRC set to CPUCLK<br>01 = VCLK_SRC set to DCLK<br>10 = VCLK_SRC set to GIO(1)<br>11 = VCLK_SRC set to PLLVCLK (VPLL primary output)<br>VCLK = VCLK_SRC / VCLKx_POST |   |   |         |   |  |  |
| b             | R/W | PLL_PRESET   |   |   | 1 = Reset VCLK PLL                                                                                                                                                                                                        |   |   |         |   |  |  |
| c             | R/W | VCLK_INVERT  |   |   | 1 = Invert VCLK to get opposite duty cycle                                                                                                                                                                                |   |   |         |   |  |  |
| d             | R/W | ECP_DIV      |   |   | Set ECP (ECP is the Scaler/Ovelay clock)<br>00 = ECP set to VCLK<br>01 = ECP set to VCLK/2<br>10 = ECP set to VCLK/4<br>11 = Reserved                                                                                     |   |   |         |   |  |  |
| e             |     | (scratch)    |   |   | Reserved for future use                                                                                                                                                                                                   |   |   |         |   |  |  |

### Description

This register sets up the pixel clock control (default = 04h).

### Usage

Display will stop and the system will hang if anything is done to stop VLCK. Switch VCLK\_SRC\_SEL to another source before resetting or stopping PLLVCLK or XTALIN.

| VCLK_POST_DIV |     |            |   |   |                                      |   |   | Addr: 6 |   |  |  |  |  |
|---------------|-----|------------|---|---|--------------------------------------|---|---|---------|---|--|--|--|--|
| BITS          |     | 7          | 6 | 5 | 4                                    | 3 | 2 | 1       | 0 |  |  |  |  |
|               |     | d          |   | c |                                      | b |   | a       |   |  |  |  |  |
| a             | R/W | VLCK0_POST |   |   | Lower bits of post divider for VCLK0 |   |   |         |   |  |  |  |  |
| b             | R/W | VLCK1_POST |   |   | Lower bits of post divider for VCLK1 |   |   |         |   |  |  |  |  |
| c             | R/W | VLCK2_POST |   |   | Lower bits of post divider for VCLK2 |   |   |         |   |  |  |  |  |

| VCLK_POST_DIV |     |            |   |   |                                      |   |   | Addr: 6 |
|---------------|-----|------------|---|---|--------------------------------------|---|---|---------|
| BITS          | 7   | 6          | 5 | 4 | 3                                    | 2 | 1 | 0       |
| d             | d   |            | c |   |                                      | b |   | a       |
| a             | R/W | VLCK3_POST |   |   | Lower bits of post divider for VCLK3 |   |   |         |

**Description**

This register sets up the lower bits of post dividers for VCLK 0-3 (default = 00h).

**Usage**

Post divider selection made by VGA\_CKSEL@GENM0 in VGA mode (see page [7-23](#)) or by CLOCK\_SEL@CLOCK\_CNTL (see page [4-67](#)) in extended display modes.

| VCLK0_FB_DIV |     |              |   |   |                                            |   |   | Addr: 7 |
|--------------|-----|--------------|---|---|--------------------------------------------|---|---|---------|
| BITS         | 7   | 6            | 5 | 4 | 3                                          | 2 | 1 | 0       |
| a            | a   |              |   |   |                                            |   |   |         |
| a            | R/W | VCLK0_FB_DIV |   |   | Feedback divider for VCLK0 (default = FDh) |   |   |         |

| VCLK1_FB_DIV |     |              |   |   |                                            |   |   | Addr: 8 |
|--------------|-----|--------------|---|---|--------------------------------------------|---|---|---------|
| BITS         | 7   | 6            | 5 | 4 | 3                                          | 2 | 1 | 0       |
| a            | a   |              |   |   |                                            |   |   |         |
| a            | R/W | VCLK1_FB_DIV |   |   | Feedback divider for VCLK1 (default = 8Eh) |   |   |         |

| VCLK2_FB_DIV |     |              |   |   |                                            |   |   | Addr: 9 |
|--------------|-----|--------------|---|---|--------------------------------------------|---|---|---------|
| BITS         | 7   | 6            | 5 | 4 | 3                                          | 2 | 1 | 0       |
| a            | a   |              |   |   |                                            |   |   |         |
| a            | R/W | VCLK2_FB_DIV |   |   | Feedback divider for VCLK2 (default = 9Eh) |   |   |         |

| VCLK3_FBDIV |     |             |   |   |                                           |   |   | Addr: 10 |   |  |
|-------------|-----|-------------|---|---|-------------------------------------------|---|---|----------|---|--|
| BITS        |     | 7           | 6 | 5 | 4                                         | 3 | 2 | 1        | 0 |  |
|             |     | a           |   |   |                                           |   |   |          |   |  |
| a           | R/W | VCLK3_FBDIV |   |   | Feedback divider for VCLK3 (default =65h) |   |   |          |   |  |

### Description

This register sets up the VPLL feedback divider. Selection made by VGA\_CKSEL@GENM0 in VGA mode (see page [7-23](#)) or by CLOCK\_SEL@CLOCK\_CNTL (see page [4-67](#)) in extended display modes.

### Usage

VPLL output (PLLVCLK) will run at:

$$\text{PLLVCLK} = \text{XTALIN} * 2 * \text{VCLKx\_FB\_DIV}) / \text{PLL\_REF\_DIV}$$

where VCLKx can be VCLK1, VCLK2 or VCLK3.

| PLL_EXT_CNTL |     |                |   |   |                                                                                                                                                                                                                                                                                                                                      |   |   | Addr: 11 |   |  |  |  |
|--------------|-----|----------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|---|--|--|--|
| BITS         |     | 7              | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                    | 3 | 2 | 1        | 0 |  |  |  |
|              |     | f              | e | d |                                                                                                                                                                                                                                                                                                                                      | c | b | a        |   |  |  |  |
| a            | R/W | XCLK_SRC_SEL   |   |   | Select XCLK (XCLK is the memory interface clock)<br>000 = XCLK set to PLLMCLK (MPPLL primary output)<br>001 = XCLK set to PLLMCLK/2<br>010 = XCLK set to PLLMCLK/4<br>011 = XCLK set to PLLMCLK/8<br>100 = XCLK set to PLLMCLK/3<br>101 = XCLK set to CPUCLK<br>110 = XCLK set to HCLK (direct, no DLL)<br>111 = XCLK set to DLL_CLK |   |   |          |   |  |  |  |
| b            | R/W | MFB_TIMES_4_2b |   |   | Select ratio of MCLK_FB_DIV to effective feedback value<br>0 = PLLMCLK feedback set to 2 * MCLK_FB_DIV<br>1 = PLLMCLK feedback set to 4 * MCLK_FB_DIV                                                                                                                                                                                |   |   |          |   |  |  |  |
| c            | R/W | ALT_VCLK0_POST |   |   | Select alternate post dividers for VCLK0                                                                                                                                                                                                                                                                                             |   |   |          |   |  |  |  |
| d            | R/W | ALT_VCLK1_POST |   |   | Select alternate post dividers for VCLK1                                                                                                                                                                                                                                                                                             |   |   |          |   |  |  |  |
| e            | R/W | ALT_VCLK2_POST |   |   | Select alternate post dividers for VCLK2                                                                                                                                                                                                                                                                                             |   |   |          |   |  |  |  |
| f            | R/W | ALT_VCLK3_POST |   |   | Select alternate post dividers for VCLK3                                                                                                                                                                                                                                                                                             |   |   |          |   |  |  |  |

**Description**

This register sets up the extended control of XCLK & VCLK (default = 05h).

| DLL_CNTL |     |             |   |   |                                                                                                                                                                     |   |   | Addr: 12 |   |  |  |
|----------|-----|-------------|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|---|--|--|
| BITS     |     | 7           | 6 | 5 | 4                                                                                                                                                                   | 3 | 2 | 1        | 0 |  |  |
|          |     | d           | c |   |                                                                                                                                                                     |   | b | a        |   |  |  |
| a        | R/W | DLL_REF_SRC |   |   | Select source for DLL_REF_CLK<br>00 = DLL_REF_CLK set to XCLK<br>01 = DLL_REF_CLK set to HCLK input<br>10 = DLL_REF_CLK set to not YCLK<br>11 = Reserved            |   |   |          |   |  |  |
| b        | R/W | DLL_FB_SEL  |   |   | Selection of source for DLL_FB_CLK<br>00 = DLL_FB_CLK set to HCLK input<br>01 = DLL_FB_CLK set to XCLK<br>10 = DLL_FB_CLK set to internal feedback<br>11 = Reserved |   |   |          |   |  |  |
| c        | R/W | DLL_RESET   |   |   | DLL reset control. DLL resets on rising edge of this signal if<br>DLL_REF_CLK is running                                                                            |   |   |          |   |  |  |
| d        | R/W | HCLK_OUT_EN |   |   | 0 = HCLK forced to tri-state<br>1 = HCLK output enabled                                                                                                             |   |   |          |   |  |  |

**Description**

This register sets up the controls for XCLK DLL (default = 40h).

**Usage**

When using SDRAM/SGRAM, the DLL phase locks the external version of the memory clock to the internal XCLK.

| VFC_CNTL |     |              |   |   |                                                                                                   |   |   | Addr: 13 |   |
|----------|-----|--------------|---|---|---------------------------------------------------------------------------------------------------|---|---|----------|---|
| BITS     |     | 7            | 6 | 5 | 4                                                                                                 | 3 | 2 | 1        | 0 |
|          |     | f            |   |   | e                                                                                                 |   |   | d        | c |
| a        | R/W | DCLK_INVERTb |   |   | 0 = PIXEL data and BLANKB off DCLK falling edge<br>1 = PIXEL data and BLANKB off DCLK rising edge |   |   |          |   |

|      |     | VFC_CNTL         |   |   |  |   |                                                                                                                                                                                                                                                                                                  |   |   | Addr: 13 |  |  |
|------|-----|------------------|---|---|--|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|--|--|
| BITS |     | 7                | 6 | 5 |  | 4 | 3                                                                                                                                                                                                                                                                                                | 2 | 1 | 0        |  |  |
|      |     | f                |   | e |  | d | c                                                                                                                                                                                                                                                                                                | b | a |          |  |  |
| b    | R/W | DCLKBY2_EN       |   |   |  |   | Select DCLK for VGA Modes: 0,1,4,5,D,13<br>(no affect in other display modes)<br>0 = DCLK set to 2 x VGA default<br>1 = DCLK set to VGA default                                                                                                                                                  |   |   |          |  |  |
| c    | R/W | VFC_MULT_EN      |   |   |  |   | Select true-color mode (no affect in VGA, 4bpp or 8bpp)<br>0 = Single clock VFC (DCLK set to VCLK)<br>1 = Multi-clock VFC (DCLK set by pixel depth and VCLK post divider)                                                                                                                        |   |   |          |  |  |
| d    | R/W | VFC_DELAY        |   |   |  |   | Adjustment for PIXEL and BLANKB hold<br>00 = Least delay<br>11 = Most delay                                                                                                                                                                                                                      |   |   |          |  |  |
| e    | R/W | DCLKBY2_SHIFT    |   |   |  |   | Shift DCLK by 1/4 period in VGA modes 0,1,4,5,D,13 and DCLKBY2_EN active. Depends on setting of DCLK_INVERTb and DCLKBY2_SHIFT:<br>PIXEL and BLANKB timing<br>00 = Off DCLK falling edge<br>01 = 20 ns after DCLK rising edge<br>10 = Off DCLK rising edge<br>11 = 20 ns after DCLK falling edge |   |   |          |  |  |
| f    | R/W | TST_SRC_SEL_BIT5 |   |   |  |   | Bit 5 of select source of PLL test clock. See VT/GT-B CLKBLK test plan for details. Bits from (4:0) are in PLL_TEST_CTRL register                                                                                                                                                                |   |   |          |  |  |

### Description

This register sets up the controls for the VESA Feature Connector (default = 00h).

|      |     | PLL_TEST_CTRL  |   |   |  |   |                                                                             |   |   | Addr: 14 |  |  |
|------|-----|----------------|---|---|--|---|-----------------------------------------------------------------------------|---|---|----------|--|--|
| BITS |     | 7              | 6 | 5 |  | 4 | 3                                                                           | 2 | 1 | 0        |  |  |
|      |     | d              | c | b |  | a |                                                                             |   |   |          |  |  |
| a    | R/W | TST_SRC_SEL    |   |   |  |   | Selects source of PLL test clock. See VT/GT-B CLKBLK test plan for details. |   |   |          |  |  |
| b    | R/W | TST_DIVIDERS   |   |   |  |   | 1 = Open reference and feedback dividers for test                           |   |   |          |  |  |
| c    | R/W | PLL_MASK_READb |   |   |  |   | 0 = Mask PLL_TEST_COUNT(2:0) and disable test output pin                    |   |   |          |  |  |

| Cont'd |     | PLL_TEST_CTRL |   |   |                                                                       |   |   |   |   | Addr: 14 |
|--------|-----|---------------|---|---|-----------------------------------------------------------------------|---|---|---|---|----------|
| BITS   |     | 7             | 6 | 5 | 4                                                                     | 3 | 2 | 1 | 0 |          |
|        |     | d             | c | b | a                                                                     |   |   |   |   |          |
| d      | R/W | ANALOG_MON_EN |   |   | Control PLL and Bandgap analog test mode<br>0 = Disable<br>1 = Enable |   |   |   |   |          |

**Description**

This register sets up the PLL test mode control (used for ASIC production testing).

|      |     | PLL_TEST_COUNT |   |   |                                                                                    |   |   |   |   | Addr: 15 |
|------|-----|----------------|---|---|------------------------------------------------------------------------------------|---|---|---|---|----------|
| BITS |     | 7              | 6 | 5 | 4                                                                                  | 3 | 2 | 1 | 0 |          |
|      |     | a              |   |   |                                                                                    |   |   |   |   |          |
| a    | R/W | PLL_TEST_COUNT |   |   | PLL test mode counter (read only, no default). Writing any value will reset to 00h |   |   |   |   |          |

**Description**

This register is used for ASIC production testing only. Do not use this register.

(NOT supported in RAGE XL)

|      |     | LVDSPLL_CNTL0  |   |   |                                                                                          |   |   |   |   | Addr: 16 |  |  |  |  |
|------|-----|----------------|---|---|------------------------------------------------------------------------------------------|---|---|---|---|----------|--|--|--|--|
| BITS |     | 7              | 6 | 5 | 4                                                                                        | 3 | 2 | 1 | 0 |          |  |  |  |  |
|      |     | c              |   |   |                                                                                          | b |   |   |   | a        |  |  |  |  |
| a    | R/W | FPDI_NS_TIMING |   |   | 0: Timing compatible National (DS90CR562/582)<br>1: Timing compatible with FPDI proposal |   |   |   |   |          |  |  |  |  |
| b    | R/W | CURR_LEVEL     |   |   | Output current level control (default = 011)                                             |   |   |   |   |          |  |  |  |  |
| c    | R/W | LVDS_TEST_MODE |   |   | Define testmode for LVDS                                                                 |   |   |   |   |          |  |  |  |  |

(NOT supported in RAGE XL)

| LVDSPLL_CNTL1 |     |              |   |   |                                              |   |   |   | Addr: 17 |   |  |  |  |
|---------------|-----|--------------|---|---|----------------------------------------------|---|---|---|----------|---|--|--|--|
| BITS          |     | 7            | 6 | 5 | 4                                            | 3 | 2 | 1 | 0        |   |  |  |  |
|               |     | d            |   |   |                                              | c |   | b |          | a |  |  |  |
| a             | R/W | LPLL_RANGE   |   |   | Range control for LPLL                       |   |   |   |          |   |  |  |  |
| b             | R/W | LPLL_DUTY    |   |   | Duty cycle control for LPLL                  |   |   |   |          |   |  |  |  |
| c             | R/W | LPLL_VC_GAIN |   |   | VCGEN gain control for LPLL (default = 001)  |   |   |   |          |   |  |  |  |
| d             | R/W | LPLL_CP_GAIN |   |   | CP gain control for LVDS PLL (default = 101) |   |   |   |          |   |  |  |  |

| AGP1_CNTL |     |               |   |   |                                                 |   |   |   | Addr: 18 |  |  |
|-----------|-----|---------------|---|---|-------------------------------------------------|---|---|---|----------|--|--|
| BITS      |     | 7             | 6 | 5 | 4                                               | 3 | 2 | 1 | 0        |  |  |
|           |     | c             | b |   | b                                               |   |   |   | a        |  |  |
| a         | R/W | X1_CLOCK_SKEW |   |   | Adjustment for AGP X1 phase (default = 000)     |   |   |   |          |  |  |
| b         | R/W | X2_CLOCK_SKEW |   |   | Adjustment for AGP X2 phase (default = 000)     |   |   |   |          |  |  |
| c         | R/W | PUMP_GAIN     |   |   | AGP PLL charge-pump gain setting (default = 01) |   |   |   |          |  |  |

**Description**

Use X1 and X2\_CLOCK\_SKEW to phase shift X1 clock (to roughly 0.5 ns step) with respect to X2 clock, and vice-versa.

**Usage**

This register should not be changed from the BIOS settings. X1 and X2 come from AGP PLL.

| AGP2_CNTL |     |           |   |   |                                                                      |   |   |   | Addr: 19 |
|-----------|-----|-----------|---|---|----------------------------------------------------------------------|---|---|---|----------|
| BITS      |     | 7         | 6 | 5 | 4                                                                    | 3 | 2 | 1 | 0        |
|           |     | e         |   |   | d                                                                    | c | b |   | a        |
| a         | R/W | AP_TST_EN |   |   | Enable AGP PLL test mode: (default = 0)<br>0 = Disable<br>0 = Enable |   |   |   |          |

| Cont'd |     | AGP2_CNTL  |   |   |                                                                                                                                                 |   |   |   |   | Addr: 19 |  |  |  |  |
|--------|-----|------------|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|----------|--|--|--|--|
| BITS   |     | 7          | 6 | 5 | 4                                                                                                                                               | 3 | 2 | 1 | 0 |          |  |  |  |  |
|        |     | e          |   |   |                                                                                                                                                 | d | c | b |   | a        |  |  |  |  |
| b      | R/W | AP_X_SEL   |   |   | 00 = PCI reference clock is selected<br>01 = x1 clock is selected<br>10 = x2 clock is selected<br>This field is only used for AGP PLL test mode |   |   |   |   |          |  |  |  |  |
| c      | R/W | AP_SLEEP   |   |   | Only for AGP PLL test (default = 0, not sleep)                                                                                                  |   |   |   |   |          |  |  |  |  |
| d      | R/W | AP_RESET   |   |   | Only for AGP PLL test (default = 0, not reset)                                                                                                  |   |   |   |   |          |  |  |  |  |
| e      | R/W | ANALOG_MON |   |   | Controls select mux for PLL and Bandgap analog test                                                                                             |   |   |   |   |          |  |  |  |  |

**Description**

This register is used to test AGP PLL in ASIC production. Do not use this register.

|      |     | DLL2_CNTL   |   |   |                                                              |   |   |   |   | Addr: 20 |  |  |  |  |  |  |
|------|-----|-------------|---|---|--------------------------------------------------------------|---|---|---|---|----------|--|--|--|--|--|--|
| BITS |     | 7           | 6 | 5 | 4                                                            | 3 | 2 | 1 | 0 |          |  |  |  |  |  |  |
|      |     | c           |   |   |                                                              | b | a |   |   |          |  |  |  |  |  |  |
| a    | R/W | DLL_SKEW    |   |   | DLL reference skew control (default = 111 for minimum skew)  |   |   |   |   |          |  |  |  |  |  |  |
| b    | R/W | DLL_RANGE   |   |   | DLL range control<br>10 = 80 - 110 MHz<br>11 = 110 - 150 MHz |   |   |   |   |          |  |  |  |  |  |  |
| c    | R/W | DLL_FB_SKEW |   |   | DLL feedback skew control (default = 111 for minimum skew)   |   |   |   |   |          |  |  |  |  |  |  |

**Description**

This register sets up the extended control for XCLK DLL.

|      |     | SCLK_FB_DIV |   |   |                                              |   |   |   |   | Addr: 21 |  |  |
|------|-----|-------------|---|---|----------------------------------------------|---|---|---|---|----------|--|--|
| BITS |     | 7           | 6 | 5 | 4                                            | 3 | 2 | 1 | 0 |          |  |  |
|      |     | a           |   |   |                                              |   |   |   |   |          |  |  |
| a    | R/W | SCLK_FB_DIV |   |   | Feedback divider value for the secondary PLL |   |   |   |   |          |  |  |

| <b>SPLL_CNTL1</b> |     |              |   |   |                               |   |   |   | <b>Addr: 22</b> |  |  |  |  |
|-------------------|-----|--------------|---|---|-------------------------------|---|---|---|-----------------|--|--|--|--|
| BITS              |     | 7            | 6 | 5 | 4                             | 3 | 2 | 1 | 0               |  |  |  |  |
|                   |     | d            | c |   |                               | b |   | a |                 |  |  |  |  |
| a                 | R/W | SPLL_PC_GAIN |   |   | SPLL Charge-pump gain setting |   |   |   |                 |  |  |  |  |
| b                 | R/W | SPLL_VC_GAIN |   |   | SPLL VCGEN gain setting       |   |   |   |                 |  |  |  |  |
| c                 | R/W | SPLL_D_CYC   |   |   | Duty cycle control for SPLL   |   |   |   |                 |  |  |  |  |
| d                 | R/W | SPLL_RANGE   |   |   | SPLL range control            |   |   |   |                 |  |  |  |  |

### Description

This register sets up the control lines for the Secondary PLL.

| <b>SPLL_CNTL2</b> |     |              |   |   |                                                                                                                                                                                                                               |   |   |   | <b>Addr: 23</b> |
|-------------------|-----|--------------|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|-----------------|
| BITS              |     | 7            | 6 | 5 | 4                                                                                                                                                                                                                             | 3 | 2 | 1 | 0               |
|                   |     |              |   |   |                                                                                                                                                                                                                               |   |   | b | a               |
| a                 | R/W | S_SLEEP      |   |   | Secondary PLL sleep                                                                                                                                                                                                           |   |   |   |                 |
| b                 | R/W | S_RESET      |   |   | Secondary PLL reset                                                                                                                                                                                                           |   |   |   |                 |
| c                 | R/W | SCLK_SRC_SEL |   |   | Select clock for different divide downs of SCLK from secondary PLL<br>000 = SCLK set to PLLSCLK<br>001 = SCLK set to PLLSCLK/2<br>010 = SCLK set to PLLSCLK/4<br>011 = SCLK set to PLLSCLK/8<br>100 -111 = SCLK set to CPUCLK |   |   |   |                 |

### Description

Secondary PLL serves as another clock source for the GUI Engine, in addition to MPPLL. Using this PLL allows the GUI clock to run at any frequency (within the operating range) regardless of what frequency the memory clock (XCLK) is running at (default = 53h).

| APLL_STRAPS   |                              |            |   |   |   |                                                                                                                                                      |   | Addr: 24                                                                                                                                                                                                                                                                                                                                   |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
|---------------|------------------------------|------------|---|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------|------------------------------|-----------|----|-----|--------|----|-----|------|----|-----|--------|----|-----|------|
| BITS          |                              | 7          | 6 | 5 | 4 | 3                                                                                                                                                    | 2 | 1                                                                                                                                                                                                                                                                                                                                          | 0 |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
|               |                              | b          |   |   |   | a                                                                                                                                                    |   |                                                                                                                                                                                                                                                                                                                                            |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
| a             | R                            | APLL_SKEWS |   |   |   | [1:0] AGP skew control, provide a means to compensate the input at the Reference Clock. Strap from MA(2:1)                                           |   |                                                                                                                                                                                                                                                                                                                                            |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
|               |                              |            |   |   |   |                                                                                                                                                      |   | <table> <thead> <tr> <th>STRAP setting</th><th>Internal Setting (mapped to)</th><th>SKEW (ns)</th></tr> </thead> <tbody> <tr> <td>00</td><td>011</td><td>-0.221</td></tr> <tr> <td>01</td><td>100</td><td>0.14</td></tr> <tr> <td>10</td><td>010</td><td>-0.596</td></tr> <tr> <td>11</td><td>101</td><td>0.51</td></tr> </tbody> </table> |   | STRAP setting | Internal Setting (mapped to) | SKEW (ns) | 00 | 011 | -0.221 | 01 | 100 | 0.14 | 10 | 010 | -0.596 | 11 | 101 | 0.51 |
| STRAP setting | Internal Setting (mapped to) | SKEW (ns)  |   |   |   |                                                                                                                                                      |   |                                                                                                                                                                                                                                                                                                                                            |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
| 00            | 011                          | -0.221     |   |   |   |                                                                                                                                                      |   |                                                                                                                                                                                                                                                                                                                                            |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
| 01            | 100                          | 0.14       |   |   |   |                                                                                                                                                      |   |                                                                                                                                                                                                                                                                                                                                            |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
| 10            | 010                          | -0.596     |   |   |   |                                                                                                                                                      |   |                                                                                                                                                                                                                                                                                                                                            |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
| 11            | 101                          | 0.51       |   |   |   |                                                                                                                                                      |   |                                                                                                                                                                                                                                                                                                                                            |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
|               |                              |            |   |   |   |                                                                                                                                                      |   | [3:2] Inter-clock skew control, provide a means to compensate the delay between the AGP X1 and AGP X2 Mode clock. Strap from MA(4:3)                                                                                                                                                                                                       |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
|               |                              |            |   |   |   |                                                                                                                                                      |   | <table> <thead> <tr> <th>STRAP setting</th><th>Internal Setting (mapped to)</th><th>SKEW (ns)</th></tr> </thead> <tbody> <tr> <td>00</td><td>111</td><td>0</td></tr> <tr> <td>01</td><td>110</td><td>0.33</td></tr> <tr> <td>10</td><td>101</td><td>0.66</td></tr> <tr> <td>11</td><td>100</td><td>0.99</td></tr> </tbody> </table>        |   | STRAP setting | Internal Setting (mapped to) | SKEW (ns) | 00 | 111 | 0      | 01 | 110 | 0.33 | 10 | 101 | 0.66   | 11 | 100 | 0.99 |
| STRAP setting | Internal Setting (mapped to) | SKEW (ns)  |   |   |   |                                                                                                                                                      |   |                                                                                                                                                                                                                                                                                                                                            |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
| 00            | 111                          | 0          |   |   |   |                                                                                                                                                      |   |                                                                                                                                                                                                                                                                                                                                            |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
| 01            | 110                          | 0.33       |   |   |   |                                                                                                                                                      |   |                                                                                                                                                                                                                                                                                                                                            |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
| 10            | 101                          | 0.66       |   |   |   |                                                                                                                                                      |   |                                                                                                                                                                                                                                                                                                                                            |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
| 11            | 100                          | 0.99       |   |   |   |                                                                                                                                                      |   |                                                                                                                                                                                                                                                                                                                                            |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |
| b             | R                            | FILL_GAIN  |   |   |   | VCO filter gain control, straps from MA[11:10]<br>00 = 01 to VCO gain (default)<br>01 = 00 to VCO gain<br>10 = 11 to VCO gain<br>11 = 10 to VCO gain |   |                                                                                                                                                                                                                                                                                                                                            |   |               |                              |           |    |     |        |    |     |      |    |     |        |    |     |      |

**Description**

This register sets up the read-only straps to control APLL at reset to ensure proper PCI operation at first cycle.

| EXT_VPLL_CNTL |     |                  |   |   |                                                                                                                  |   |   | Addr: 25 |   |
|---------------|-----|------------------|---|---|------------------------------------------------------------------------------------------------------------------|---|---|----------|---|
| BITS          |     | 7                | 6 | 5 | 4                                                                                                                | 3 | 2 | 1        | 0 |
|               |     | e                | d |   |                                                                                                                  | c | b | a        |   |
| a             | R/W | EXT_VPLL_REF_SRC |   |   | 00 = VPLL_REF set to XTALIN<br>01 = VPLL_REF set to PLLMCLK/2<br>10 = VPLL_REF set to PLLSCLK/2<br>11 = Reserved |   |   |          |   |

| Cont'd |     | EXT_VPLL_CNTL   |   |   |                                                                                                                                                                                                                                                                                                                    |   |   |   | Addr: 25 |
|--------|-----|-----------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|----------|
| BITS   |     | 7               | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                  | 3 | 2 | 1 | 0        |
|        |     | e               |   |   |                                                                                                                                                                                                                                                                                                                    | d | c | b | a        |
| b      | R/W | EXT_VPLL_EN     |   |   | Control of VPLL reference and feedback<br>0 = Use feedback divider settings in VCLKx_FB_DIV, reference divider setting in PLL_REF_DIV and XTALIN reference clock<br>1 = Use EXT_VPLL_FB_DIV, EXT_VPLL_REF_DIV and EXT_VPLL_REF_SRC settings for extended display modes.<br>Use for VGA only if EXT_VPLL_VGA_EN = 1 |   |   |   |          |
| c      | R/W | EXT_VPLL_VGA_EN |   |   | 0 = Do not use any EXT_VPLL settings in VGA modes<br>1 = Use EXT_VPLL settings in VGA modes                                                                                                                                                                                                                        |   |   |   |          |
| d      | R/W | EXT_VPLL_INSYNC |   |   | Controls when EXT_VPLL_UPDATE action occurs<br>0 = Do atomic update ASAP<br>1 = Wait for vertical sync before atomic update                                                                                                                                                                                        |   |   |   |          |
| e      | R/W | EXT_V2PLL_EN    |   |   | Select reference divider value: (default = 1)<br>0 = Use reference divider value programmed in PLL_REF_DIV<br>1 = Use reference divider value programmed in EXT_VPLL_REF_DIV                                                                                                                                       |   |   |   |          |

### Description

This register controls the extended precision reference and feedback for VCLK (default = 00h).

|      |     | EXT_VPLL_REF_DIV |   |   |                                                                                                                                                            |   |   |   | Addr: 26 |
|------|-----|------------------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|----------|
| BITS |     | 7                | 6 | 5 | 4                                                                                                                                                          | 3 | 2 | 1 | 0        |
|      |     | a                |   |   |                                                                                                                                                            |   |   |   |          |
| a    | R/W | EXT_VPLL_REF_DIV |   |   | Lower 8 bits of 10 bit extended VPLL reference divider. New value not used until EXT_VPLL_UPDATE is written. Readback is of pending value. (default = 00h) |   |   |   |          |

| EXT_VPLL_FB_DIV |     |                 |   |   |                                                                                                                                                                                                                                                                                 |   |   | Addr: 27 |   |  |
|-----------------|-----|-----------------|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|---|--|
| BITS            |     | 7               | 6 | 5 | 4                                                                                                                                                                                                                                                                               | 3 | 2 | 1        | 0 |  |
|                 |     | a               |   |   |                                                                                                                                                                                                                                                                                 |   |   |          |   |  |
| a               | R/W | EXT_VPLL_FB_DIV |   |   | Lower 8 bits of 11 bit extended VPLL feedback divider. Effective feedback divider is the same as register setting, not twice register setting as for VCLKx_FB_DIV registers. New value not used until EXT_VPLL_UPDATE is written. Readback is of pending value. (default = 00h) |   |   |          |   |  |

| EXT_VPLL_MSB |     |                  |   |   |                                                                                                                                                                                                                                                                                                                                        |   |   | Addr: 28 |   |  |  |  |
|--------------|-----|------------------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|---|--|--|--|
| BITS         |     | 7                | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                      | 3 | 2 | 1        | 0 |  |  |  |
|              |     |                  |   | c |                                                                                                                                                                                                                                                                                                                                        |   |   | b        |   |  |  |  |
| a            | R/W | EXT_VPLL_REF_DIV |   |   | EXT_VPLL_REF_DIV bits [9:8]                                                                                                                                                                                                                                                                                                            |   |   |          |   |  |  |  |
| b            | R/W | EXT_VPLL_UPDATE  |   |   | Controls transfer of EXT_VPLL_REF_DIV and EXT_VPLL_FB_DIV from registers to functional units<br>Write:<br>0 = No update<br>1 = Atomically update reference and feedback divider<br><br>Read:<br>0 = Atomic update complete, ready for next writes<br>1 = Atomic update still pending, do not write EXT_VPLL_REF_DIV or EXT_VPLL_FB_DIV |   |   |          |   |  |  |  |
| c            | R/W | EXT_VPLL_FB_DIV  |   |   | EXT_VPLL_FB_DIV bits [10:8]                                                                                                                                                                                                                                                                                                            |   |   |          |   |  |  |  |

### Description

This register sets up the most significant bits (msb) of EXT\_VPLL\_REF\_DIV and EXT\_VPLL\_FB\_DIV (default = 00h).

| HTOTAL_CNTL |     |                    |   |   |                                                                                                                                                                                                                             |   |   |   | Addr: 29 |  |  |
|-------------|-----|--------------------|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|----------|--|--|
| BITS        |     | 7                  | 6 | 5 | 4                                                                                                                                                                                                                           | 3 | 2 | 1 | 0        |  |  |
|             |     | c                  | b |   |                                                                                                                                                                                                                             |   |   | a |          |  |  |
| a           | R/W | PLLVCLK_SLIP       |   |   | <b>Reserved, not yet implemented</b><br>Number of 1/5th of PLLVCLK periods to extend HTOTAL by. Valid range is 0 to 4, for 5 or more increment VCLK_POST_SLIP.                                                              |   |   |   |          |  |  |
| b           | R/W | VCLK_POST_SLIP     |   |   | <b>Reserved, not yet implemented</b><br>Number of periods of PLLVCLK to extend each HTOTAL by stopping VCLK post divider. For corrections equal to or greater than the current post divider use the TVO_H_TOT_PIX register. |   |   |   |          |  |  |
| c           | R/W | HTOTAL_CNTL_VGA_EN |   |   | <b>Reserved, not yet implemented</b><br>0 = No HTOTAL control through this register in VGA modes.<br>1 = Enable HTOTAL control through this register in VGA modes.                                                          |   |   |   |          |  |  |

### Description

This register controls sub-pixel adjustment of HTOTAL timing. TVO\_CNTL register controls active edge of HSYNC and HTOTAL adjustment down to pixel level. Update of this register does not take effect until opposite edge of HSYNC than specified in TVO\_H\_TOT\_EDGE register to ensure atomic change of each slip field outside active area (default = 00h).

| BYTE_CLK_CNTL |     |                   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |   |   | Addr: 30 |  |  |
|---------------|-----|-------------------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|----------|--|--|
| BITS          |     | 7                 | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 3 | 2 | 1 | 0        |  |  |
|               |     | c                 |   |   | b                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |   | a |          |  |  |
| a             | R/W | BYTE_CLK_SKEW     |   |   | Selects BYTE_CLK phase in 1/2 PLLVCLK increments. Valid range depends on BYTE_CLK_POST_DIV, and may not exceed (2 * byte clock post divider)-1. e.g. for byte clock post divider of 3 (BYTE_CLK_POST_DIV = 10), then (2*3) - 1 = 5, so BYTE_CLK_SKEW has range 0 to 5                                                                                                                                                                                      |   |   |   |          |  |  |
| b             | R/W | BYTE_CLK_POST_DIV |   |   | TV out byte clock post divider. If VCLK for TV out clock sourced in ImpacTV then set to 00, otherwise VCLK for TV out sourced from internal PLL and post dividers are changed as indicated<br>00 = BYTE_CLK set to GPIO(11) input, no change in VCLK_POST_DIV<br>01 = BYTE_CLK set to PLLVCLK/2, multiply VCLK_POST_DIV by 2<br>10 = BYTE_CLK set to PLLVCLK/3, multiply VCLK_POST_DIV by 3<br>11 = BYTE_CLK set to PLLVCLK/4, multiply VCLK_POST_DIV by 4 |   |   |   |          |  |  |

| BYTE_CLK_CNTL |     |          |   |   |                                                                                                               |   |   | Addr: 30 |   |
|---------------|-----|----------|---|---|---------------------------------------------------------------------------------------------------------------|---|---|----------|---|
| BITS          |     | 7        | 6 | 5 | 4                                                                                                             | 3 | 2 | 1        | 0 |
|               |     |          |   | c | b                                                                                                             |   | a |          |   |
| c             | R/W | BYTE_CLK |   |   | 0 = BYTE_CLK from ImpacTV to graphics controller<br>1 = Forces BYTE_CLK to be muxed out BYTCLK pin to ImpacTV |   |   |          |   |

**Description**

This register controls the byte clock sent to (or received from) ImpacTV and extra VCLK post divider. VCLK\_SRC\_SEL must be set to 10 for BYTE\_CLK generation (default = 00h).

(NOT supported in RAGE XL)

| TV_PLL_CNTL1 |     |      |   |   |                                                       |   |   | Addr: 31 |   |
|--------------|-----|------|---|---|-------------------------------------------------------|---|---|----------|---|
| BITS         |     | 7    | 6 | 5 | 4                                                     | 3 | 2 | 1        | 0 |
|              |     | a    |   |   |                                                       |   |   |          |   |
| a            | R/W | TV_M |   |   | Reference Divider setting for TV clock (default = 2h) |   |   |          |   |

(NOT supported in RAGE XL)

| TV_PLL_CNTL2 |     |      |   |   |                                                      |   |   | Addr: 32 |   |
|--------------|-----|------|---|---|------------------------------------------------------|---|---|----------|---|
| BITS         |     | 7    | 6 | 5 | 4                                                    | 3 | 2 | 1        | 0 |
|              |     | a    |   |   |                                                      |   |   |          |   |
| a            | R/W | TV_N |   |   | Feedback Divider setting for TV clock (default = 6h) |   |   |          |   |

(NOT supported in RAGE XL)

| TVPLL_CNTL |     |               |   |   |                                |   |   | Addr: 33 |   |  |  |  |  |  |
|------------|-----|---------------|---|---|--------------------------------|---|---|----------|---|--|--|--|--|--|
| BITS       |     | 7             | 6 | 5 | 4                              | 3 | 2 | 1        | 0 |  |  |  |  |  |
|            |     | d             | c |   | b                              |   | a |          |   |  |  |  |  |  |
| a          | R/W | TVPLL_PC_GAIN |   |   | TVPLL Charge-pump gain setting |   |   |          |   |  |  |  |  |  |
| b          | R/W | TVPLL_VC_GAIN |   |   | TVPLL VCGEN gain setting       |   |   |          |   |  |  |  |  |  |
| c          | R/W | TVPLL_D_CYC   |   |   | Duty cycle control for TVPLL   |   |   |          |   |  |  |  |  |  |
| d          | R/W | TVPLL_RANGE   |   |   | TVPLL range control            |   |   |          |   |  |  |  |  |  |

**Description:**

This register sets up the controls for the TVPLL analog macro (default = ADh).

(NOT supported in RAGE XL)

|      |     | EXT_TV_PLL     |   |   |                                                                                                                                         |   |   |   |   | Addr: 34 |  |  |  |  |
|------|-----|----------------|---|---|-----------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|----------|--|--|--|--|
| BITS |     | 7              | 6 | 5 |                                                                                                                                         | 4 | 3 | 2 | 1 | 0        |  |  |  |  |
|      |     | e              |   |   |                                                                                                                                         | d |   | c | b | a        |  |  |  |  |
| a    | R/W | TV_N_BIT9      |   |   | Bit 9 of TV PLL feedback divider TV_N                                                                                                   |   |   |   |   |          |  |  |  |  |
| b    | R/W | TV_PLL_RST     |   |   | 1 = TV_PLL reset                                                                                                                        |   |   |   |   |          |  |  |  |  |
| c    | R/W | TV_PLL_SLEEP   |   |   | 1 = TV_PLL power down                                                                                                                   |   |   |   |   |          |  |  |  |  |
| d    | R/W | TVCLK_SRC_SEL  |   |   | 00 = CPUCLK<br>01 = XTALIN<br>10 = reserved<br>11 = TVPLLCLK                                                                            |   |   |   |   |          |  |  |  |  |
| e    | R/W | VCLKTV_SRC_SEL |   |   | 000 = CPUCLK (inverted)<br>001 = DCLK<br>010 = VCLK<br>011 = VCLK2<br>100 = VCLK/2<br>101 = V2CLK/2<br>110 = Reserved<br>111 = Reserved |   |   |   |   |          |  |  |  |  |

**Description:**

This register sets up the additional controls to TVPLL macro (default = 06h).

|      |     | HW_DEBUG_EXT                 |   |   |                                                                                                                                            |   |   |   |   | Addr: 35 |   |  |  |  |
|------|-----|------------------------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|----------|---|--|--|--|
| BITS |     | 7                            | 6 | 5 |                                                                                                                                            | 4 | 3 | 2 | 1 | 0        |   |  |  |  |
|      |     |                              |   |   |                                                                                                                                            | d | c |   |   | b        | a |  |  |  |
| a    | R/W | IGNORE_BADCCIR656_CMD_E<br>N |   |   | Ignore non-compliant CCIR656 video capture stream commands<br>0 = does not ignore bad CCIR656 commands<br>1 = ignores bad CCIR656 commands |   |   |   |   |          |   |  |  |  |
| b    | R/W | INVERT_FIELD                 |   |   | Invert FIELD information in the video capture block<br>0 = normal<br>1 = invert                                                            |   |   |   |   |          |   |  |  |  |

| HW_DEBUG_EXT |     |                          |   |   |                                                                                                                                                                                                                                         |   |   | Addr: 35 |   |
|--------------|-----|--------------------------|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|---|
| BITS         |     | 7                        | 6 | 5 | 4                                                                                                                                                                                                                                       | 3 | 2 | 1        | 0 |
|              |     |                          |   |   |                                                                                                                                                                                                                                         | d | c | b        | a |
| c            | R/W | FLIP_HREF                |   |   | 0 = normal<br>1 = flip (default)                                                                                                                                                                                                        |   |   |          |   |
| d            | R/W | SOFT_RESET_SUBSYS_ID_DIS |   |   | Disables resetting of SUBSYS_VEN_ID, SUBSYS_DEV_ID during power management reset.<br>0 = do not reset SUBSYS_ID registers during a Power Management reset (D3 -> D0) (default) (see note below)<br>1 = always reset SUBSYS_ID registers |   |   |          |   |

**Note:**

This register was formerly called V2PLL\_CNTL.

In this register, bits 4:7 operate differently from bits 0:3. Bits 4:7 can only be written after a hard reset, however after a Power Management reset (D3 -> D0), these bits become read-only.

(NOT supported in RAGE XL)

| PLL_V2CLK_CNTL |     |                |   |   |                                                                                                                                                                                          |   |   | Addr: 36 |   |  |  |
|----------------|-----|----------------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|---|--|--|
| BITS           |     | 7              | 6 | 5 | 4                                                                                                                                                                                        | 3 | 2 | 1        | 0 |  |  |
|                |     | e              |   |   | d                                                                                                                                                                                        | c | b | a        |   |  |  |
| a              | R/W | V2CLK_SRC_SEL  |   |   | 00 = V2CLK_SRC set to CPUCLK<br>01 = V2CLK_SRC set to DCLK<br>10 = V2CLK_SRC set to GIO(1)<br>11 = V2CLK_SRC set to PLLV2CLK<br>V2CLK = V2CLK_SRC/V2CLK_POST_DIV                         |   |   |          |   |  |  |
| b              | R/W | PLL_PRESET2    |   |   | 1 = Reset V2PLL                                                                                                                                                                          |   |   |          |   |  |  |
| c              | R/W | VCLK2_INVERT   |   |   | 1 = Invert V2CLK to get opposite duty cycle                                                                                                                                              |   |   |          |   |  |  |
| d              | R/W | V2PLL_SLEEP    |   |   | 1 = Power down V2PLL                                                                                                                                                                     |   |   |          |   |  |  |
| e              | R/W | V2CLK_POST_DIV |   |   | Select V2CLK post divider<br>000 = PLLV2CLK<br>001 = PLLV2CLK/2<br>010 = PLLV2CLK/4<br>011 = PLLV2CLK/8<br>100 = PLLV2CLK/3<br>101 = PLLV2CLK/5<br>110 = PLLV2CLK/6<br>111 = PLLV2CLK/12 |   |   |          |   |  |  |

**Description:**

This register sets up the second pixel clock control (default = 14h).

**(Not connected)**

| EXT_V2PLL_REF_DIV |     |                   |   |   |                                                                                                                                                             |   |   | Addr: 37 |   |  |
|-------------------|-----|-------------------|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|---|--|
| BITS              |     | 7                 | 6 | 5 | 4                                                                                                                                                           | 3 | 2 | 1        | 0 |  |
|                   |     | a                 |   |   |                                                                                                                                                             |   |   |          |   |  |
| a                 | R/W | EXT_V2PLL_REF_DIV |   |   | Lower 8 bits of 10 bit extended V2PLL reference divider. New value not used until EXT_V2PLL_UPDATE is written. Readback is of pending value (default = 24h) |   |   |          |   |  |

**(NOT supported in RAGE XL)**

| EXT_V2PLL_FB_DIV |     |                  |   |   |                                                                                                                                                            |   |   | Addr: 38 |   |  |
|------------------|-----|------------------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|---|--|
| BITS             |     | 7                | 6 | 5 | 4                                                                                                                                                          | 3 | 2 | 1        | 0 |  |
|                  |     | a                |   |   |                                                                                                                                                            |   |   |          |   |  |
| a                | R/W | EXT_V2PLL_FB_DIV |   |   | Lower 8 bits of 11 bit extended V2PLL feedback divider. New value not used until EXT_V2PLL_UPDATE is written. Readback is of pending value (default = FDh) |   |   |          |   |  |

**(NOT supported in RAGE XL)**

| EXT_V2PLL_MSB |     |                   |   |   |                                                                                                                                                                                                                                                                                                                                            |   |   | Addr: 39 |   |  |  |  |
|---------------|-----|-------------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|---|--|--|--|
| BITS          |     | 7                 | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                          | 3 | 2 | 1        | 0 |  |  |  |
|               |     |                   |   |   |                                                                                                                                                                                                                                                                                                                                            |   |   | a        |   |  |  |  |
| a             | R/W | EXT_V2PLL_REF_DIV |   |   | EXT_V2PLL_REF_DIV bits 9:8                                                                                                                                                                                                                                                                                                                 |   |   |          |   |  |  |  |
| b             | R/W | EXT_V2PLL_UPDATE  |   |   | Controls transfer of EXT_V2PLL_REF_DIV and EXT_V2PLL_FB_DIV from registers to functional units<br>Write:<br>0 = No update<br>1 = Atomically update reference and feedback divider<br><br>Read:<br>0 = Atomic update complete, ready for next writes<br>1 = Atomic update still pending, do not write EXT_V2PLL_REF_DIV or EXT_V2PLL_FB_DIV |   |   |          |   |  |  |  |
| c             | R/W | EXT_V2PLL_FB_DIV  |   |   | EXT_V2PLL_FB_DIV bits 10:8                                                                                                                                                                                                                                                                                                                 |   |   |          |   |  |  |  |

**Description:**

This register sets up the most significant bits (msb) of EXT\_V2PLL\_REF\_DIV and EXT\_V2PLL\_FB\_DIV (default = 00h).

(NOT supported in RAGE XL)

| HTOTAL2_CNTL |     |                  |   |   |   |                                                                                                                                                                                                 |   |   | Addr: 40 |  |  |  |
|--------------|-----|------------------|---|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|--|--|--|
| BITS         |     | 7                | 6 | 5 | 4 | 3                                                                                                                                                                                               | 2 | 1 | 0        |  |  |  |
|              |     | c                | b |   |   |                                                                                                                                                                                                 | a |   |          |  |  |  |
| a            | R/W | PLLV2CLK_SLIP    |   |   |   | Number of 1/5th of PLLV2CLK periods to extend HTOTAL by.<br>Valid range is 0 to 4, for 5 or more increment<br>V2CLK_POST_SLIP                                                                   |   |   |          |  |  |  |
| b            | R/W | V2CLK_POST_SLIP  |   |   |   | Number of periods of PLLV2CLK to extend each HTOTAL by<br>stopping V2CLK post divider. For corrections equal to or<br>greater than the current post divider, use the<br>TVO_H_TOT2_PIX register |   |   |          |  |  |  |
| c            | R/W | EXT_V2PLL_INSYNC |   |   |   | Controls when EXT_V2PLL_UPDATE action occurs:<br>0 = Do atomic update ASAP<br>1 = Wait for vertical sync before atomic update                                                                   |   |   |          |  |  |  |

**Description:**

This register controls the sub-pixel adjustment of HTOTAL timing for second display. TVO\_CNTL register controls active edge of HSYNC and HTOTAL adjustment down to pixel level. Update of this register does not take effect until opposite edge of HSYNC than specified in TVO\_H\_TOT2\_EDGE register to ensure atomic change of each slip field outside active area (default = 00h).

| PLL_YCLK_CNTL |     |              |   |   |   |                                                                                                                                                                                                                                                                                                                  |   |   | Addr: 41 |  |
|---------------|-----|--------------|---|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|--|
| BITS          |     | 7            | 6 | 5 | 4 | 3                                                                                                                                                                                                                                                                                                                | 2 | 1 | 0        |  |
| XL            |     | c            | b |   | b |                                                                                                                                                                                                                                                                                                                  |   |   | a        |  |
| a             | R/W | YCLK_SRC_SEL |   |   |   | YCLK is the memory interface clock when running 2:1 mode<br>000 = YCLK set to PLLMCLK<br>001 = YCLK set to PLLMCLK/2<br>010 = YCLK set to PLLMCLK/4<br>011 = YCLK set to PLLMCLK/8<br>100 = YCLK set to SSIN<br>101 = YCLK set to CPUCLK<br>110 = YCLK set to HCLK (direct, no DLL)<br>111 = YCLK set to DLL_CLK |   |   |          |  |

| Cont'd |     | PLL_YCLK_CNTL |    |   |                                                                                                                                                                                                                                                                   |   |   |   |   | Addr: 41 |  |  |  |  |
|--------|-----|---------------|----|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|----------|--|--|--|--|
| BITS   |     | 7             | 6  | 5 | 4                                                                                                                                                                                                                                                                 | 3 | 2 | 1 | 0 |          |  |  |  |  |
| XL     |     | c             | XL |   | b                                                                                                                                                                                                                                                                 |   |   |   | a |          |  |  |  |  |
| b      | R/W | HCLK_SEL      |    |   | Select function for HCLK pin (default = 4)<br>000 = HCLK set to XCLK<br>001 = HCLK set to not XCLK<br>010 = HCLK set to not YCLK<br>011 = HCLK set to YCLK<br>100 = HCLK set to DLL_CLK (default)<br>101 = Reserved<br>110 = Reserved<br>111 = HCLK set to YCLK/2 |   |   |   |   |          |  |  |  |  |
| c      | R/W | HCLK_REC      |    |   | HCLK receiver selection<br>0 = Hysteresis receiver<br>1 = Differential receiver                                                                                                                                                                                   |   |   |   |   |          |  |  |  |  |

|      |     | PM_DYN_CLK_CNTL |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   | Addr: 42 |  |  |  |  |
|------|-----|-----------------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|----------|--|--|--|--|
| BITS |     | 7               | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3 | 2 | 1 | 0 |          |  |  |  |  |
| XL   |     | d               | c |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | b | a |   |   |          |  |  |  |  |
| a    | R/W | PM_XCLK_SRC_SEL |   |   | PM_XCLK is the slower memory interface clock in the dynamic clock speed power management mode<br>000 = PM_XCLK set to PLLMCLK (MPLL primary output)<br>001 = PM_XCLK set to PLLMCLK/2<br>010 = PM_XCLK set to PLLMCLK/4<br>011 = PM_XCLK set to PLLMCLK/8<br>100 = PM_XCLK set to PLLMCLK/3<br>101 = PM_XCLK set to CPUCLK<br>110 = PM_XCLK set to HCLK (direct, no DLL)<br>111 = PM_XCLK set to DLL_CLK<br><br>Note: This is not a separate mux. The select for XCLK_SRC will be dynamically chosen as XCLK_SRC_SEL or PM_XCLK_SRC_SEL depending on the memory requester activity and the programming of POWER_MANAGEMENT_2 registers |   |   |   |   |          |  |  |  |  |
| b    | R/W | PWRMAN_CLK_SEL  |   |   | Set power management clock: (default = 0)<br>0 = BCLK_PM = BCLK<br>1 = BCLK_PM = XTALIN (if XTALIN_ALWAYS_ONb = 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   |   |   |          |  |  |  |  |

| Cont'd |     | PM_DYN_CLK_CNTL |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |   |   |   | Addr: 42 |
|--------|-----|-----------------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|----------|
| BITS   |     | 7               | 6 | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 4 | 3 | 2 | 1 | 0        |
| XL     |     | d               | c |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   | b | a |   |          |
| c      | R/W | PM_YCLK_SRC_SEL |   | PM_YCLK is the slower memory interface clock when running 2:1 mode in the dynamic clock speed power management mode<br>000 = PM_YCLK set to PLLMCLK<br>001 = PM_YCLK set to PLLMCLK/2<br>010 = PM_YCLK set to PLLMCLK/4<br>011 = PM_YCLK set to PLLMCLK/8<br>100 = PM_YCLK set to SSIN<br>101 = PM_YCLK set to CPUCLK<br>110 = PM_YCLK set to HCLK (direct, no DLL)<br>111 = PM_YCLK set to DLL_CLK<br><br>Note: This is not a separate mux; the select for YCLK_SRC will be dynamically chosen as YCLK_SRC_SEL or PM_YCLK_SRC_SEL depending on the memory requester activity and the programming of POWER_MANAGEMENT_2 registers |   |   |   |   |          |
| d      | R/W | SS_EN           |   | Enable spread spectrum clocking<br>Allows to broadband the VCLK source frequency for reducing measured EMI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |          |

**Description:**

This register sets up the control of PM\_XCLK and PM\_YCLK for dynamic memory clock speed power management (default 55h).

## 4.2.8 DAC Control Registers

The DAC\_REGS are also addressed at VGA I/O addresses 3C6h to 3C9h (not in the order below), i.e., the same palette data and DAC\_MASK are used either in VGA or in extended modes.

|      |     | DAC_REGS    |    |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | Offset: 0_30 |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
|------|-----|-------------|----|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|--------------|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |  |
|      |     | d           |    |    |    | c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |    |    | b  |    |    |    | a  |    |    |    |    |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | DAC_W_INDEX |    |    |    | DAC write index register *<br>Indexes the 256x24 entry palette RAM for write operations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | DAC_DATA    |    |    |    | DAC data register *<br>If DAC is in 6-bit mode then two MSB are ignored on write, zero on read. If DAC is in 8-bit mode, then two LSB are ignored on write, zero on read.<br><br>DAC WRITE: First 8 bit write is red data, next two writes are green and blue, respectively. After blue write the 24 bit palette is updated and DAC_W_INDEX auto-increments to next index.<br>DAC READ: After DAC_R_INDEX is written, three reads from DAC_DATA will give red, green and blue color components, respectively. After every third read the next index in the palette is read automatically and the read index is auto-incremented. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | DAC_MASK    |    |    |    | DAC mask register *<br>This 8 bit mask value is ANDed with the incoming 8 bit pseudocolor pixel data. The resultant value is used for looking up the true color in the LUT.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| d    | W   | DAC_R_INDEX |    |    |    | DAC read index register *<br>Indexes the 256x24 entry palette RAM for read operations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |              |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |

### Description

This register is actually a group of four 8-bit registers (not a single 32-bit register) aliased to the VGA DAC registers DAC\_MASK (3C6), DAC\_R\_INDEX (3C7), DAC\_W\_INDEX (3C8) and DAC\_DATA (3C9). See the *mach64 VGA Register Guide* for more details.

Byte accesses are recommended over word or Dword accesses. These registers may also be accessed in accelerator mode through the VGA I/O addresses if DAC\_VGA\_ADR\_EN@DAC\_CNTL is set.

### Usage

Use these registers to reprogram the DAC look up table (LUT).

**See Also**DAC\_CNTL on [page 4-95](#)

Chapter 8, VGA-Compatible Registers

mach64 Programmer's Guide:

- *Advanced Topics: CRT Synchronization and Animation: Double Buffering (Palette)*

|      |     | DAC_CNTL                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                                                                                                                           |   |   |   | Offset: 0_31 |   |   |  |  |  |  |  |
|------|-----|------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---------------------------------------------------------------------------------------------------------------------------|---|---|---|--------------|---|---|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |
|      |     |                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                                                                                                                           |   |   |   |              |   |   |  |  |  |  |  |
|      |     |                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                                                                                                                           |   |   |   |              |   |   |  |  |  |  |  |
| a    | R/W | DAC_RANGE_CNTL                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | DAC output standard                                                                                                       |   |   |   |              |   |   |  |  |  |  |  |
|      |     | 00 = PAL                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 01 = NTSC                                                                                                                 |   |   |   |              |   |   |  |  |  |  |  |
|      |     | 10 = PS2                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 11 = RS343                                                                                                                |   |   |   |              |   |   |  |  |  |  |  |
| b    | R/W | DAC_BLANKING                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 0 = 0 IRE blanking pedestal                                                                                               |   |   |   |              |   |   |  |  |  |  |  |
|      |     | 1 = Enable 7.5 IRE blanking pedestal                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                                                                                                                           |   |   |   |              |   |   |  |  |  |  |  |
| c    | R/W | DAC_CMP_DISABLE                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Disable DAC comparators: (default = 0)                                                                                    |   |   |   |              |   |   |  |  |  |  |  |
|      |     | 0 = Enable                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 1 = Disable (power down DAC comparators)                                                                                  |   |   |   |              |   |   |  |  |  |  |  |
| d    | R/W | DAC1_CLK_SEL                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Select data source for DAC1 (default = 0)                                                                                 |   |   |   |              |   |   |  |  |  |  |  |
|      |     | 0 = CRTC1 (primary display)                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 1 = CRTC2 (secondary display)                                                                                             |   |   |   |              |   |   |  |  |  |  |  |
| e    | R/W | PALETTE_ACCESS_CNTL                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Selects access to primary or secondary palette (MUST be set to 0)                                                         |   |   |   |              |   |   |  |  |  |  |  |
|      |     | 0 = Access primary palette through DAC_REGS register |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 1 = Access secondary palette through DAC_REGS register<br><b>(NOT supported)</b>                                          |   |   |   |              |   |   |  |  |  |  |  |
| f    | R/W | PALETTE2_SNOOP_EN                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Enable snooping of primary palette writes (MUST be set to 0)                                                              |   |   |   |              |   |   |  |  |  |  |  |
|      |     | 0 = Disabled (default)                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 1 = Enable (everything written to primary palette will be written to secondary palette as well)<br><b>(NOT supported)</b> |   |   |   |              |   |   |  |  |  |  |  |
| g    | R   | DAC_CMP_OUTPUT                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | DAC comparator output                                                                                                     |   |   |   |              |   |   |  |  |  |  |  |
|      |     | 0 = At least one comparator > 0.42 V                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 1 = All three comparators < 0.28 V                                                                                        |   |   |   |              |   |   |  |  |  |  |  |
| h    | R/W | DAC_8BIT_EN                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Select 6- or 8-bit DAC operation                                                                                          |   |   |   |              |   |   |  |  |  |  |  |
|      |     | 0 = 6-bit                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | 1 = 8-bit                                                                                                                 |   |   |   |              |   |   |  |  |  |  |  |

| Cont'd |     | DAC_CNTL         |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_31                                                                                                                                               |    |    |    |   |   |   |   |   |   |   |   |
|--------|-----|------------------|--|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|---|---|---|---|---|---|---|---|
|        |     | BITS             |  | 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 |
|        |     |                  |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                            |    |    |    |   |   |   |   |   |   |   |   |
| i      | R   | CRT_SENSE        |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | This bit is read only<br>0 = CRT is not connected<br>1 = CRT is connected                                                                                  |    |    |    |   |   |   |   |   |   |   |   |
| j      | R/W | CRT_DETECTION_ON |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | This bit is to enable hardware monitor detection circuitry                                                                                                 |    |    |    |   |   |   |   |   |   |   |   |
| k      | R/W | DAC_VGA_ADR_EN   |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable addressing of the DAC at the VGA IO DAC address when CRTC_EXT_DISP_EN is a '1'                                                                      |    |    |    |   |   |   |   |   |   |   |   |
| l      | R/W | DAC_FEA_CON_EN   |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable feature connector signal outputs                                                                                                                    |    |    |    |   |   |   |   |   |   |   |   |
| m      | R/W | DAC_PDWN         |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Power down internal DAC (DAC macro only)                                                                                                                   |    |    |    |   |   |   |   |   |   |   |   |
| n      | R   | DAC_TYPE         |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Select DAC type<br>000 = Internal DAC, 18-bit palette, no gamma correction<br>001 = Internal DAC, 24-bit palette, gamma correction<br>010 - 111 = Reserved |    |    |    |   |   |   |   |   |   |   |   |

### Description

This register configures the on-chip DAC interface unit. If the DAC has extended address bits to access extended DAC registers, then those upper address bits will be specified in DAC\_EXT\_SEL. DAC\_8BIT\_EN selects between 8-bit or 6-bit modes, and is used only if both modes are supported.

To enable CRT monitor auto-detection through hardware, set CRT\_DETECTION\_ON = 1.

For manual detection of the CRT monitor through software, set MONITOR\_DET\_EN@LCD\_MISC\_CNTL = 1.

To properly use the bits for selecting either manual- or auto-detection of the CRT monitor, set the following bits to their proper values:

FORCE\_DAC\_DATA\_SEL@LCD\_MISC\_CNTL

FORCE\_DAC\_DATA@LCD\_MISC\_CNTL

### Usage

This register is used only for mode switching. Only the adapter BIOS touches this register.

### See Also

*mach64* Programmer's Guide:

- Advanced Topics: DAC Programming

# Chapter 5

## GUI Draw Engine

### 5.1 Draw Engine Trajectory Registers

This chapter describes the GUI engine registers. Operations are initiated implicitly by writing to DST\_WIDTH or DST\_BRES\_LNTH. X and Y coordinates are in the range -8192 to +8191 and -16384 to +16383 respectively. All drawing operations are orthogonal with respect to pixel size. Packed 24 bpp is partially supported by setting DST\_PIX\_WIDTH to 8 bpp and adjusting the x coordinates and scissor values. The DST\_24\_ROT\_EN and DST\_24\_ROT control bits allow for a full 24 bpp foreground color, background color, and write mask, which will be rotated properly by the GUI engine. In addition, the 8x8x1 monochrome pattern source will be expanded and rotated properly. Note that Bresenham line drawing operations are not generally supported in the partial 24 bpp mode.

Note: Draw Engine registers are visible only in the memory space, not in sparse or block I/O.

#### 5.1.1 Destination Trajectory Registers

This register has two names—DST\_BRES\_DEC or LEAD\_BRES\_DEC

| DST_BRES_DEC (LEAD_BRES_DEC) |     |              | MM: 0_4B |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                         |   |   |   |   |   |   |   |   |   |   |
|------------------------------|-----|--------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|
| BITS                         | 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 |
|                              |     |              |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                         |   |   |   |   |   |   |   |   |   |   |
| a                            | R/W | DST_BRES_DEC |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bresenham decrement for line and trapezoid leading edge |   |   |   |   |   |   |   |   |   |   |

#### Description

This register is a signed 18-bit register that stores the Bresenham line decrement term. The number loaded into this register must be negative. This term is added to the DST\_BRES\_ERR term whenever the Bresenham error is positive.

#### Usage

Use this register for line draw or trapezoid draw operations. It is aliased as LEAD\_BRES\_DEC.

### See Also

DST\_BRES\_ERR on [page 5-2](#)

DST\_BRES\_INC on [page 5-3](#)

DST\_BRES\_LNTH on [page 5-3](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Destination Trajectory 2, Line*
- *Engine Operations: Draw Operations: Color Source: Drawing Lines*

| DST_BRES_ERR |     |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | MM: 0_49                                                 |   |   |
|--------------|-----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----------------------------------------------------------|---|---|
| BITS         | 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 |
| a            | a   |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |                                                          |   |   |
| a            | R/W | DST_BRES_ERR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | Bresenham error term for line and trapezoid leading edge |   |   |

### Description

This register is a signed, 18-bit register that stores the Bresenham line error term. If the error term is negative, an axial step is taken and DST\_BRES\_INC is added to this register; otherwise, a diagonal step is taken in the direction of the major axis, and DST\_BRES\_DEC is added.

### Usage

Use this register for line draw or trapezoid draw operations. It is aliased as LEAD\_BRES\_ERR.

### See Also

DST\_BRES\_DEC on [page 5-1](#)

DST\_BRES\_INC on [page 5-3](#)

DST\_BRES\_LNTH on [page 5-3](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Destination Trajectory 2, Line*
- *Engine Operations: Draw Operations: Color Source: Drawing Lines*

This register has two names—DST\_BRES\_INC or LEAD\_BRES\_INC

| DST_BRES_INC (LEAD_BRES_INC) |     |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_4A |    |                                                         |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------------------------|-----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|---------------------------------------------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS                         |     | 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 |
|                              |     |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    | a                                                       |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a                            | R/W | DST_BRES_INC |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    | Bresenham increment for line and trapezoid leading edge |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register is a signed 18-bit register which stores the Bresenham line increment term. The number loaded into this register must be positive. This term is added to the DST\_BRES\_ERR term whenever the Bresenham error is negative.

### Usage

Use this register for line draw or trapezoid draw operations, and is aliased as LEAD\_BRES\_INC.

### See Also

DST\_BRES\_DEC on [page 5-1](#)

DST\_BRES\_ERR on [page 5-2](#)

DST\_BRES\_LNTH on [page 5-3](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Destination Trajectory 2, Line*
- *Engine Operations: Draw Operations: Color Source: Drawing Lines*

The register below has two names—DST\_BRES\_LNTH or LEAD\_BRES\_LNTH

| DST_BRES_LNTH (LEAD_BRES_LNTH) |     |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_48 and MM: 0_51 |    |                                                                                                                                                                                                                                                                      |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
|--------------------------------|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|
| BITS                           |     | 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 |  |  |  |  |  |  |  |  |  |  |  |
|                                |     | d             | c  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | b                     | a  |                                                                                                                                                                                                                                                                      |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| a                              | R/W | DST_BRES_LNTH |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    | Bresenham line and trapezoid leading edge length<br>This field is aliased to DST_WIDTH[14:0]                                                                                                                                                                         |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| b                              | R/W | DRAW_TRAP     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    | To initiate a trapezoid, set to '1'<br>This field is aliased to DST_WIDTH[15]                                                                                                                                                                                        |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| c                              | R/W | TRAIL_X       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    | Location of trapezoid trailing edge<br>Note: This field is not written if bit 15 is a '1' and bit 31 is a '0'.<br>This field is aliased to DST_HEIGHT[14:0].<br>If SUB_PIX_ON@DST_CNTL is set, this field is interpreted as a S.12.2, otherwise a S.14.0 bit integer |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |

| Cont'd |   | <b>DST_BRES_LNTH (LEAD_BRES_LNTH) MM: 0_48 and MM: 0_51</b> |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|---|-------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |   | 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 |
|        |   | d                                                           | c  |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | b  | a  |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| d      | W | DST_BRES_LNTH_LINE_DIS                                      |    |    |    |    |    |    |    |    |    |    | Disables initiation of Bresenham line draw operations:<br>Bit 31      Bit 15<br>0            0      Bresenham line draw operation initiated.<br>TRAIL_X and DST_BRES_LNTH are loaded<br>0            1      Trapezoid draw operation. TRAIL_X is not updated, but DST_BRES_LNTH is loaded<br>1            0      TRAIL_X and DST_BRES_LNTH are loaded. No line or trapezoid operations are done<br>1            1      Trapezoid draw operation. TRAIL_X and DST_BRES_LNTH are loaded |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

Writing the value of line length to this register will initiate a line draw. The number written to this register is the number of pixels that will be drawn when DST\_LAST\_PEL@DST\_CNTL is set.

Writing to this register also overwrites the contents of DST\_WIDTH.

$$\text{DST_BRES_LNTH} = \max(|dx|, |dy|) + 1$$

### Usage

Use this register for line draw or trapezoid draw operations.

### See Also

DST\_BRES\_DEC on [page 5-1](#)

DST\_BRES\_ERR on [page 5-2](#)

DST\_BRES\_INC on [page 5-3](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Destination Trajectory 2, Line*
- *Engine Operations: Draw Operations: Color Source: Drawing Lines*

|      |     | DST_CNTL               |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |   |   | MM: 0_4C |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|------|-----|------------------------|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |
|      |     | q                      | p  | o  |    | n  | m  | l  | k  | j  |    | i  |    | h                                                                                                                                                                                                                                                                                                                       | g  | f  | e  | d  | c  | b  | a  |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| a    | R/W | DST_X_DIR              |    |    |    |    |    |    |    |    |    |    |    | Destination X direction<br>0 = Right to left<br>1 = Left to right                                                                                                                                                                                                                                                       |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| b    | R/W | DST_Y_DIR              |    |    |    |    |    |    |    |    |    |    |    | Destination Y direction<br>0 = Bottom to top<br>1 = Top to bottom                                                                                                                                                                                                                                                       |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| c    | R/W | DST_Y_MAJOR            |    |    |    |    |    |    |    |    |    |    |    | Destination Y major axis flag for bresenham lines<br>0 = X major line<br>1 = Y major line                                                                                                                                                                                                                               |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| d    | R/W | DST_X_TILE             |    |    |    |    |    |    |    |    |    |    |    | Enables rectangular tiling in the X direction                                                                                                                                                                                                                                                                           |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| e    | R/W | DST_Y_TILE             |    |    |    |    |    |    |    |    |    |    |    | Enables rectangular tiling in the Y direction                                                                                                                                                                                                                                                                           |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| f    | R/W | DST_LAST_PEL           |    |    |    |    |    |    |    |    |    |    |    | Destination last pel enable                                                                                                                                                                                                                                                                                             |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| g    | R/W | DST_POLYGON_EN         |    |    |    |    |    |    |    |    |    |    |    | Destination polygon outline and polygon fill enable                                                                                                                                                                                                                                                                     |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| h    | R/W | DST_24_ROT_EN          |    |    |    |    |    |    |    |    |    |    |    | Enables 24 bpp rotation<br>DSTPIXWIDTH MUST be set to 8 bpp                                                                                                                                                                                                                                                             |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| i    | R/W | DST_24_ROT             |    |    |    |    |    |    |    |    |    |    |    | Initial foreground color, background color, write mask, and monochrome pattern rotation when drawing packed 24 bpp<br>The initial DST_24_ROT value is defined as follows:<br>If DST_X_DIR = '0', then<br>DST_24_ROT = (Trunc(((DST_X * 3) + 2)/4)) Mod 6<br>Else<br>DST_24_ROT = (Trunc((DST_X * 3)/4)) Mod 6<br>End If |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| j    | R/W | DST_BRES_SIGN          |    |    |    |    |    |    |    |    |    |    |    | Sign of DST_BRES_ERR when DST_BRES_ERR = 0<br>0 = DEST_BRES_ERR = 0 is positive number<br>1 = DEST_BRES_ERR = 0 is negative number                                                                                                                                                                                      |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| k    | R/W | DST_POLYGON_RTEDGE_DIS |    |    |    |    |    |    |    |    |    |    |    | Disables drawing of the right edge pixel of a polygon fill operation<br>0 = Drawing of right edge pixel is enabled<br>1 = Drawing of right edge pixel is disabled                                                                                                                                                       |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| l    | R/W | TRAIL_X_DIR            |    |    |    |    |    |    |    |    |    |    |    | Trapezoid trailing edge direction<br>0 = Right to left<br>1 = Left to right                                                                                                                                                                                                                                             |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| m    | R/W | TRAP_FILL_DIR          |    |    |    |    |    |    |    |    |    |    |    | Trapezoid fill direction<br>0 = Right to left (trailing edge is to the left of the leading edge)<br>1 = Left to right (trailing edge is to the right of the leading edge)                                                                                                                                               |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| n    | R/W | TRAIL_BRES_SIGN        |    |    |    |    |    |    |    |    |    |    |    | Bresenham sign for trailing edge of trapezoids<br>0 = Zero error term is positive number<br>1 = Zero error term is negative number                                                                                                                                                                                      |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

| Cont'd |     | DST_CNTL          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_4C                                                                                                                                                                                                                                                                                                                                                                    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|        |     | BITS              | 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 |
|        |     |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | q                                                                                                                                                                                                                                                                                                                                                                           | p  | o  | n  | m  | l  | k  | j | i | h | g | f | e | d | c | b | a |
| o      | R/W | BRES_SIGN_AUTO    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bresenham sign<br>0 = Zero error term is defined by DST_BRES_SIGN and TRAIL_BRES_SIGN bit<br>1 = Overrides DST_BRES_SIGN and TRAIL_BRES_SIGN bit.<br>Zero error term is positive for X Major lines whose Y_DIR is 0 or for Y Major Lines whose X_DIR is 0. For Trapezoids with sub-pixel addressing, this bit is changed to include pixels on the top/left of the triangle  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| p      | R/W | ALPHA_OVERLAP_ENB |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Allow a pipeline optimization to fetch data for the current triangle before the previous triangle has been written to memory. If the triangles do in fact overlap in the frame buffer, this runs the risk of blending with the wrong data.<br>0 = Disallow optimization (guarantees correct blend)<br>1 = Allow optimization (risks incorrect data during triangle overlap) |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| q      | R/W | SUB_PIX_ON        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | This forces the interpretation of BRES_LNTH, DST_X, DST_Y and TRAIL_X as having 2 bits of sub-pixel precision<br>This bit is valid only for Trapezoid trajectories<br>It also changes the interpretation of BRES_SIGN_AUTO                                                                                                                                                  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register describes the miscellaneous control bits for the destination area:

If the destination trajectory is rectangular, DST\_X\_DIR and DST\_Y\_DIR will determine the trajectory quadrant that the destination area and the source area will take. Rectangular areas are always X-major.

If the destination trajectory is a line, DST\_X\_DIR, DST\_Y\_DIR, and DST\_Y\_MAJOR will determine the trajectory octant that the destination line will take and the source area direction is specified in SRC\_LINE\_X\_DIR@SRC\_CNTL. Source areas are always rectangular. Source areas do not advance in the Y direction when destination trajectory is a line.

DST\_X\_TILE and DST\_Y\_TILE affect only rectangular destinations. These bits determine the side effect of the DST\_X and DST\_Y registers after the draw operation is completed. If DST\_X\_TILE is set, then DST\_X will be assigned DST\_X+DST\_WIDTH upon draw completion for a left-to-right draw operation (DST\_X\_DST\_WIDTH for right-to-left); otherwise DST\_X is unchanged.

Similarly, if DST\_Y\_TILE is set, then DST\_Y will be assigned DST\_Y+DST\_HEIGHT upon draw completion (for a top-to-bottom draw operation (DST\_Y\_DST\_HEIGHT for bottom-to-top); otherwise DST\_Y is unchanged.

DST\_LAST\_PEL affects only destination line trajectories. When set, the last pixel in the line is drawn, otherwise it is not. This register does *not* affect DST\_X and DST\_Y trajectories.

DST\_POLYGON\_EN affects line and rectangle destinations differently. (1) For lines, with this bit set, only one pixel will be drawn per scan line (with the exception of horizontal lines, where no pixels will be drawn). Lines exceeding the left scissor boundary will be saturated to the left scissor. (2) For rectangles, with this bit set, an implicit polygon source (specified by the source trajectory registers) is used to conduct an alternate-fill polygon fill on the destination. Blit sources cannot be used in conjunction with polygon fills. DST\_X\_DIR must be set to left-to-right operation for correct polygon fill behavior.

DST\_24\_ROT\_EN and DST\_24\_ROT are used to set the initial rotation factor in packed 24 bpp mode.

DST\_BRES\_SIGN controls the behavior of the line draw engine when DST\_BRES\_ERR is zero. When set, a zero error term is considered negative, otherwise it is positive.

### Usage

This register must be set for all draw operations. DST\_Y\_MAJOR and DST\_LAST\_PEL are applicable only for line draw operations. DST\_X\_TILE and DST\_Y\_TILE are applicable only for rectangle fills.

### See Also

GUI\_TRAJ\_CNTL on [page 5-65](#)

SRC\_CNTL on [page 5-21](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Destination Trajectory 1, Rectangular*
- *Engine Operations: Background Information: Trajectories: Destination Trajectory 2, Line*
- *Engine Operations: Draw Operations: Color Source: Drawing Lines*
- *Engine Operations: Background Information: Trajectories: Trajectory Modifier 2, DST\_POLYGON\_EN*
- *Engine Operations: Background Information: Side Effects of Trajectories*
- *Advanced Topics: Polygons*
- *Engine Operations: Miscellaneous Operations: Drawing in Packed 24 Bit Per Pixel Mode*

| DST_HEIGHT |     |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------|-----|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS       |     | 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 |
|            |     |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                   |    |    |    |    |    |   |   | a |   |   |   |   |   |   |   |
| a          | R/W | DST_HEIGHT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Destination height<br>Bits14:0 aliased to TRAIL_X @ DST_BRES_LNTH |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register specifies the height in pixels of a rectangular destination area.

### Usage

Use this register for drawing a rectangular or trapezoidal destination area.

### See Also

DST\_WIDTH on [page 5-10](#)

DST\_HEIGHT\_WIDTH on [page 5-8](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Destination Trajectory 1, Rectangular*
- *Engine Operations: Draw Operations: Color Source: Drawing Rectangles*
- *Engine Operations: Draw Operations: Standard Bitblit Source*
- *Engine Operations: Draw Operations: Specialized Bitblit Source: Transparent BitBlts*
- *Advanced Topics: Polygons*

| DST_HEIGHT_WIDTH |   |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|------------------|---|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| BITS             |   | 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 |  |
|                  |   | b          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                              |    |    |    |    |    |   |   |   | a |   |   |   |   |   |   |  |
| a                | W | DST_HEIGHT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Destination height (see register DST_HEIGHT) |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| b                | W | DST_WIDTH  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Destination width (see register DST_WIDTH)   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

### Description

This register is a composite of registers DST\_HEIGHT and DST\_WIDTH. Writing to this register will initiate a rectangle fill operation.

**Usage**

Use these registers only for drawing rectangular destinations.

**See Also**

[DST\\_HEIGHT](#) on [page 5-8](#)

[DST\\_WIDTH](#) on [page 5-10](#)

[DST\\_WIDTH\\_HEIGHT](#) on [page 5-11](#)

|      |     | DST_OFF_PITCH |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                          |    |    |    |    |    |    |    |    |    |   |   | MM: 0_40 |   |   |   |   |   |   |   |
|------|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | b             |    |    |    |    |    |    |    |    |    |    |    | a                                                                                                                                                                                        |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |
| a    | R/W | DST_OFFSET    |    |    |    |    |    |    |    |    |    |    |    | Destination offset address in terms of 64 bit words<br>For SGRAM configuration, DST_OFFSET must be aligned on a 64 byte boundary                                                         |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |
| b    | R/W | DST_PITCH     |    |    |    |    |    |    |    |    |    |    |    | Destination pitch in pixels*8. Note that for monochrome modes the destination pitch must be a multiple of 64 pixels<br>For SGRAM configuration, DST_PITCH must be a multiple of 64 bytes |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |

**Description**

This register specifies the offset (in QWORDs) and pitch (in pixels) of the destination area. If the memory boundary is enabled, ensure that the offset points to an area above or equal to the boundary. If the destination is on-screen memory, any value of pitch smaller than the display area is not meaningful.

**Usage**

This register should be set for all draw operations.

**See Also**

[SRC\\_OFF\\_PITCH](#) on [page 5-26](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Destination Trajectory 1, Rectangular*
- *Engine Operations: Background Information: Trajectories: Destination Trajectory 2, Line*
- *Advanced Topics: CRT Synchronization and Animation: Double Buffering (Memory)*
- *Linear Aperture: VGA Interaction*

|             |     |                           | <b>DST_WIDTH</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                |    |    |    |    |    |    |   |   |   | <b>MM: 0_44</b> |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
|-------------|-----|---------------------------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|---|---|---|-----------------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|
| <b>BITS</b> |     | 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 |  |  |  |  |  |  |  |  |  |
|             |     | b                         |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                | a  |    |    |    |    |    |   |   |   |                 |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| a           | R/W | <b>DST_WIDTH</b>          |                  |    |    |    |    |    |    |    |    |    |    |    |    |    | Destination width<br>Only bits [13:0] are used for rectangle draws<br>Bit [15] is write ONLY and will always read back as '0'<br>Bits [15:14] are aliased to DST_BRES_LENGTH[15:14] and are used for trapezoid draw operations                 |    |    |    |    |    |    |   |   |   |                 |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| b           | W   | <b>DST_WIDTH_FILL_DIS</b> |                  |    |    |    |    |    |    |    |    |    |    |    |    |    | Disables initiation of rectangular fill operations<br>0 = Rectangular fill operation initiated<br>1 = No rectangular fill operation initiated<br>NOTE: This function is performed when the register is written. The bit is not stored, or read |    |    |    |    |    |    |   |   |   |                 |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |

### Description

This register specifies the width in pixels of a rectangular destination area and initiates a draw operation. DST\_WIDTH can be set without initiating a draw operation by setting the DST\_WID\_FILL\_DIS bit.

Writing to this register also overwrites the contents of DST\_BRES\_LNTH.

### Usage

Use this register only for drawing a rectangular destination area.

### See Also

[DST\\_HEIGHT](#) on [page 5-8](#)

[DST\\_HEIGHT\\_WIDTH](#) on [page 5-8](#)

[DST\\_X\\_WIDTH](#) on [page 5-12](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Destination Trajectory 1, Rectangular*
- *Engine Operations: Draw Operations: Color Source: Drawing Rectangles*
- *Engine Operations: Draw Operations: Standard Bitblit Source*
- *Engine Operations: Draw Operations: Specialized Bitblit Source: Transparent BitBlts*
- *Advanced Topics: Polygons*

| DST_WIDTH_HEIGHT |   |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------------|---|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS             |   | 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 |
|                  |   | b          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                                            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a                | W | DST_WIDTH  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Destination width (see register DST_WIDTH)   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b                | W | DST_HEIGHT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Destination height (see register DST_HEIGHT) |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register is a composite of registers DST\_WIDTH and DST\_HEIGHT (as is DST\_HEIGHT\_WIDTH, but in the inverse order). Writing to this register will initiate a rectangle fill operation.

### Usage

Use these registers only for drawing rectangular destinations.

### See Also

DST\_HEIGHT on [page 5-8](#)

DST\_WIDTH on [page 5-10](#)

DST\_HEIGHT\_WIDTH on [page 5-8](#)

| DST_X |     |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|-------|-----|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| BITS  |     | 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 |  |
|       |     |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | b                                                                                                                                                               | a  |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| a     | R/W | DST_X                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Destination X coordinate<br>If SUB_PIX_ON is set, this field is interpreted as a S.12.2 number;<br>otherwise, it is a S.13.0 bit integer with bit [14] reserved |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| b     | R/W | SCALE_Y_SECONDARY_LSB |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | The LSB of the Y index of the secondary source<br>This bit is used as a “hint” to give better performance (it is ignored<br>for non-scaling operations)         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

### Description

This register specifies the starting X coordinate of the destination trajectory. This is a signed 14 bit number.

### Usage

Use this register for all draw operations.

### See Also

DST\_X\_WIDTH on [page 5-12](#)

DST\_Y on [page 5-13](#)

DST\_Y\_X on [page 5-14](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Destination Trajectory 1, Rectangular*
- *Engine Operations: Background Information: Trajectories: Destination Trajectory 2, Line*

| DST_X_WIDTH |    |                       | MM: 0_47 |    |    |    |    |    |    |    |    |                                                                     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------|----|-----------------------|----------|----|----|----|----|----|----|----|----|---------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS        | 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 |
|             | c  |                       |          |    |    |    |    |    |    |    | b  | a                                                                   |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a           | W  | DST_X                 |          |    |    |    |    |    |    |    |    | Destination X coordinate                                            |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b           | W  | SCALE_Y_SECONDARY_LSB |          |    |    |    |    |    |    |    |    | The LSB of the Y index of the secondary source (see register DST_X) |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| c           | W  | DST_WIDTH             |          |    |    |    |    |    |    |    |    | Destination width                                                   |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register is a composite of registers DST\_X and DST\_WIDTH.

### Usage

Use this register as an alternative for initiating rectangle fill operations when drawing a rectangular destination area.

### See Also

DST\_X on [page 5-11](#)

DST\_WIDTH on [page 5-10](#)

|      |   | DST_X_Y               |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                     |    |    |    |    |    | MM: 0_BA |    |   |   |   |   |   |   |   |   |   |   |
|------|---|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------|----|----|----|----|----|----------|----|---|---|---|---|---|---|---|---|---|---|
| BITS |   | 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 |
|      |   | d                     | c  |    |    |    |    |    |    |    |    |    |    |    |    |                                                                     | b  | a  |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| a    | W | DST_X                 |    |    |    |    |    |    |    |    |    |    |    |    |    | Destination X coordinate                                            |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| b    | W | SCALE_Y_SECONDARY_LSB |    |    |    |    |    |    |    |    |    |    |    |    |    | The LSB of the Y index of the secondary source (see register DST_X) |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| c    | W | DST_Y                 |    |    |    |    |    |    |    |    |    |    |    |    |    | Destination Y coordinate                                            |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| d    | W | SCALE_Y_LSB           |    |    |    |    |    |    |    |    |    |    |    |    |    | The LSB of the Y index of the primary source (see register DST_Y)   |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register is a composite of registers DST\_X and DST\_Y. It provides destination coordinates in the inverse order to DST\_Y\_X.

### Usage

Use these registers for all draw operations.

### See Also

DST\_X on [page 5-11](#)

DST\_Y on [page 5-13](#)

DST\_Y\_X on [page 5-14](#)

|      |     | DST_Y       |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                  |    |    |    |    |    | MM: 0_42 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|------|-----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| BITS |     | 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 |  |  |  |
|      |     |             |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                  |    |    |    |    |    | b        | a  |   |   |   |   |   |   |   |   |   |   |  |  |  |
| a    | R/W | DST_Y       |    |    |    |    |    |    |    |    |    |    |    |    |    | Destination Y coordinate<br>If SUB_PIX_ON is set, this field is interpreted as a S.12.2 number<br>(otherwise it is a S.14.0 integer)             |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| b    | R/W | SCALE_Y_LSB |    |    |    |    |    |    |    |    |    |    |    |    |    | The LSB of the Y index of the secondary source<br>This bit is used as a “hint” to give better performance (it is ignored<br>for non-scaling ops) |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

### Description

This register specifies the starting Y coordinate of the destination trajectory. This is a signed 15 bit number.

### Usage

Use this register for all draw operations.

### See Also

DST\_X on [page 5-11](#)

DST\_Y\_X on [page 5-14](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Destination Trajectory 1, Rectangular*
- *Engine Operations: Background Information: Trajectories: Destination Trajectory 2, Line*

| DST_Y_X |   |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                     |    |    |    |    |    |    |    |   |   |   |   |   |   |   | MM: 0_43 and MM: 0_4D |   |   |  |  |  |  |  |
|---------|---|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----------------------|---|---|--|--|--|--|--|
| BITS    |   | 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 |  |  |  |  |  |
|         |   | d                     | c  |    |    |    |    |    |    |    |    |    |    |    |    |                                                                     | b  | a  |    |    |    |    |    |   |   |   |   |   |   |   |                       |   |   |  |  |  |  |  |
| a       | W | DST_Y                 |    |    |    |    |    |    |    |    |    |    |    |    |    | Destination Y coordinate                                            |    |    |    |    |    |    |    |   |   |   |   |   |   |   |                       |   |   |  |  |  |  |  |
| b       | W | SCALE_Y_LSB           |    |    |    |    |    |    |    |    |    |    |    |    |    | The LSB of the Y index of the primary source (see register DST_Y)   |    |    |    |    |    |    |    |   |   |   |   |   |   |   |                       |   |   |  |  |  |  |  |
| c       | W | DST_X                 |    |    |    |    |    |    |    |    |    |    |    |    |    | Destination X coordinate                                            |    |    |    |    |    |    |    |   |   |   |   |   |   |   |                       |   |   |  |  |  |  |  |
| d       | W | SCALE_Y_SECONDARY_LSB |    |    |    |    |    |    |    |    |    |    |    |    |    | The LSB of the Y index of the secondary source (see register DST_X) |    |    |    |    |    |    |    |   |   |   |   |   |   |   |                       |   |   |  |  |  |  |  |

### Description

This register is a composite of registers DST\_X and DST\_Y.

### Usage

Use these registers for all draw operations.

### See Also

DST\_X on [page 5-11](#)

DST\_Y on [page 5-13](#)

| TRAIL_BRES_ERR |     |                |    |    |    |    |    |    |    |    |    |                                                           |    |    |    |    |    | MM: 0_4E |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|-----|----------------|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS           |     | 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 |
|                |     |                |    |    |    |    |    |    |    |    |    |                                                           |    |    |    |    |    |          |    | a  |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a              | R/W | TRAIL_BRES_ERR |    |    |    |    |    |    |    |    |    | Bresenham error term for line and trapezoid trailing edge |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register is a signed 18-bit register that stores the Bresenham error term for line and trapezoid trailing edges.

| TRAIL_BRES_INC |     |                |    |    |    |    |    |    |    |    |    |                                                          |    |    |    |    |    | MM: 0_4F |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|-----|----------------|----|----|----|----|----|----|----|----|----|----------------------------------------------------------|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS           |     | 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 |
|                |     |                |    |    |    |    |    |    |    |    |    |                                                          |    |    |    |    |    |          |    | a  |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a              | R/W | TRAIL_BRES_INC |    |    |    |    |    |    |    |    |    | Bresenham increment for line and trapezoid trailing edge |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register is a signed 18-bit register which stores the Bresenham increment for line and trapezoid trailing edges. The number loaded into this register must be positive. This term is added to the DST\_BRES\_ERR term whenever the Bresenham error is negative.

| TRAIL_BRES_DEC |     |                |    |    |    |    |    |    |    |    |    |                                                          |    |    |    |    |    | MM: 0_50 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|-----|----------------|----|----|----|----|----|----|----|----|----|----------------------------------------------------------|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS           |     | 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 |
|                |     |                |    |    |    |    |    |    |    |    |    |                                                          |    |    |    |    |    |          |    | a  |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a              | R/W | TRAIL_BRES_DEC |    |    |    |    |    |    |    |    |    | Bresenham decrement for line and trapezoid trailing edge |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register is a signed 18-bit register which stores the Bresenham decrement for line and trapezoid trailing edges. The number loaded into this register must be negative. This term is added to the DST\_BRES\_ERR term whenever the Bresenham error is positive.

|      |     |          | <b>Z_OFF_PITCH</b> |    |    |    |    |    |    |    |    |    |    |                                           |    |    |    |    |    |    |    |    |    |   |   |   |   | <b>MM: 0_52</b> |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
|------|-----|----------|--------------------|----|----|----|----|----|----|----|----|----|----|-------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|-----------------|---|---|---|---|---|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |
|      |     | b        |                    |    |    |    |    |    |    |    |    |    |    | a                                         |    |    |    |    |    |    |    |    |    |   |   |   |   |                 |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| a    | R/W | Z_OFFSET |                    |    |    |    |    |    |    |    |    |    |    | Z offset address in terms of 64 bit words |    |    |    |    |    |    |    |    |    |   |   |   |   |                 |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| b    | R/W | Z_PITCH  |                    |    |    |    |    |    |    |    |    |    |    | Z pitch (*8)                              |    |    |    |    |    |    |    |    |    |   |   |   |   |                 |   |   |   |   |   |  |  |  |  |  |  |  |  |  |

### Description

This register is used to specify the offset (in QWORDs) and pitch (in pixels) of the Z-buffer area. The Z-buffer destination will always track the normal destination in X and Y, but with its own pitch and offset.

(\*8) means the unit value (in decimal) contained in the bits represents 8 pixels.

Example: to set the pitch of the Z-buffer area to 16 pixels, insert 02h (i.e., 2 decimal) into bits [19:0]; therefore,  $2^8 = 16$ .

### Usage

Use this register for all 3D draw operations.

All other Z functions directly track the DST registers.

### See Also

[Z\\_CNTL](#) on [page 5-16](#)

|      |     |       | <b>Z_CNTL</b> |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                           |    |    |    |    |    |    |    |    |    |   |   |   | <b>MM: 0_53</b> |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|------|-----|-------|---------------|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|-----------------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |
|      |     |       |               |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                           |    |    |    |    |    |    |    |    |    |   |   |   | d               | c | b | a |   |   |   |  |  |  |  |  |  |  |  |
| a    | R/W | Z_EN  |               |    |    |    |    |    |    |    |    |    |    | Enables use of Z functions<br>0 = Disable Z testing<br>1 = Enable Z testing                                                                                                                               |    |    |    |    |    |    |    |    |    |   |   |   |                 |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| b    | R/W | Z_SRC |               |    |    |    |    |    |    |    |    |    |    | Denotes that the 2D source, added to the Z interpolator should be used as the source for new Z values<br>0 = Z source (new Z) from Z interpolator<br>1 = Z source (new Z) from 2D source + Z interpolator |    |    |    |    |    |    |    |    |    |   |   |   |                 |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

| Cont'd |     | Z_CNTL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_53                                                                                                                                                                                                                                                                                                        |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | d                                                                                                                                                                                                                                                                                                               |    | c |   | b | a |   |   |   |   |   |   |
| c      | R/W | Z_TEST |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable specific Z test<br>000 = Z test never passes<br>001 = Z < current Z<br>010 = Z <= current Z<br>011 = Z == current Z<br>100 = Z >= current Z<br>101 = Z > current Z<br>110 = Z != current Z<br>111 = Z test always passes<br>A passing Z test will overwrite the existing value with the new source value |    |   |   |   |   |   |   |   |   |   |   |
| d      | R/W | Z_MASK |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable writing to the Z planes:<br>0 = Disable writing to the Z planes<br>1 = Enable writing to the Z planes                                                                                                                                                                                                    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register controls the new Z source FIFO which supports the hardware Z buffering.

### Usage

Z\_EN toggles Z ‘on’ or ‘off’. Z\_TEST specifies which Z test is to be done. Z\_MASK allows Z to apply to colors, even if Z itself is never written.

### See Also

Z\_OFF\_PITCH on [page 5-16](#)

|      |     | ALPHA_TST_CNTL    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |    |    |    |    |    |    |    |    |   |   | MM: 0_54 |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|-------------------|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | n                 | m  | l  | k  | j  | i  |    |    |    |    |    | h  | g                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | f  | e  | d  |    |    | c  | b  | a  |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | ALPHA_TST_EN      |    |    |    |    |    |    |    |    |    |    |    | Enable use of Alpha testing functions<br>0 = Disable Alpha testing<br>1 = Enable Alpha testing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | ALPHA_TEST        |    |    |    |    |    |    |    |    |    |    |    | Enable specific Alpha test<br>000 = Alpha test never passes<br>001 = Src_Alpha < RefDst Alpha<br>010 = Src_Alpha <= RefDst Alpha<br>011 = Src_Alpha == RefDst Alpha<br>100 = Src_Alpha >= RefDst Alpha<br>101 = Src_Alpha > Ref Dst Alpha<br>110 = Src_Alpha != RefDst Alpha<br>111 = Src_Alpha test always passes<br><br>Tst_Src_Alpha is either the expanded alpha from the texture map<br>OR the source alpha, depending on the setting of the<br>ALPHA_TST_SRC_SEL bit<br><br>A passing Alpha test will overwrite the entire destination pixel with<br>the new source pixel<br><br>Note: the Alpha used is the expanded alpha from the texture map.<br>If TEX_MAP_AEN in SCALE_3D_CNTL is OFF, the alpha<br>value is assumed to be 0xFF |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | ALPHA_MODE_MSB    |    |    |    |    |    |    |    |    |    |    |    | If this bit is set, and TEX_MAP_AEN is set, the TEXEL alpha is<br>used to modify the source alpha value used to blend with the<br>destination<br>0 = Use filtered texture alpha (if TEX_MAP_AEN is 1 and<br>ALPHA_DECAL lighting is off) or alpha interpolator<br>(otherwise) as the source alpha value<br>1 = Use the (alpha interpolator * filtered TEXEL alpha) as the<br>source alpha value<br><br>This bit does not imply that any “alpha masking” is being done and<br>in fact it is invalid to set both this bit and TEX_MASK_AEN                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d    | R/W | ALPHA_DST_SEL     |    |    |    |    |    |    |    |    |    |    |    | Alpha value written to the destination<br>000 = Destination alpha is 0x00<br>001 = Destination alpha is 0xff<br>010 = Reserved<br>011 = (reserved)<br>100 = Destination alpha is As<br>101 = Destination alpha is 1-As<br>110 = Destination alpha Ad<br>111 = Destination alpha is 1-Ad                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| e    | R/W | ALPHA_TST_SRC_SEL |    |    |    |    |    |    |    |    |    |    |    | Select the value that is compared to REF_ALPHA during alpha<br>testing<br>0 = Use Texel Alpha<br>1 = Use Source Alpha                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Cont'd

| Cont'd   |     | ALPHA_TST_CNTL                |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                  |    |    |    |    |    |    |    |    |    | MM: 0_54 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
|----------|-----|-------------------------------|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|
| BITS     |     | 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 |  |  |  |  |  |
|          |     | n                             | m  | l  | k  | j  | i  |    |    |    |    | h                                                                                                                                                                                                                                                                                                                                                                                                                                                | g  | f  | e  |    | d  | c  | b  |    |    | a        |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| <b>f</b> | R/W | FOG_TABLE_EN                  |    |    |    |    |    |    |    |    |    | Enable the fog table<br>If fog is enabled, this bit denotes that the fog table rather than the alpha/fog interpolator will be used for the fog 'density' value<br>0 = Use alpha/fog interpolator<br>1 = Use Z interpolator value to index into the 256x8 fog table. Use the low order bits of Z to interpolate between two adjacent entries.<br>Note: when this bit is set and fog is enabled, the Setup engine should set up the Z interpolator |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| <b>g</b> | R/W | TEX_CACHE_LINE_SIZE           |    |    |    |    |    |    |    |    |    | Allows fetches to use 2QW rather than 4 QW fetches (in some cases this may be a performance improvement)<br>0 = Fetch a full line (4 QW)<br>1 = Fetch half lines (2 QW)                                                                                                                                                                                                                                                                          |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| <b>h</b> | R/W | IDCT_EN                       |    |    |    |    |    |    |    |    |    | Indicates that the operation should take data from the IDCT engine, rather than the destination during alpha blending and add it to the generated pixel<br>For this bit to take effect, ALPHA_EN and SIGNED_DST_CLAMP_EN must be on<br>In this mode, the Alpha blending function will be overridden and assumed to be Src + Dst<br>0 = IDCT engine off<br>1 = IDCT engine on (Alpha Blending off)                                                |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| <b>i</b> | R/W | REF_ALPHA                     |    |    |    |    |    |    |    |    |    | Reference alpha used for Alpha testing                                                                                                                                                                                                                                                                                                                                                                                                           |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| <b>j</b> | R/W | COMPOSITE_CI4_RGB_INDEX       |    |    |    |    |    |    |    |    |    | These bits will be used as the upper 4 bits of the CI4 color value to select 1 of 16 different palettes for the secondary map                                                                                                                                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| <b>k</b> | R/W | COMPOSITE_CI4_RGB_LOW_NIBBLE  |    |    |    |    |    |    |    |    |    | Denotes that when in CI8 -> RGB texture lookup mode for the secondary map, the texture should be interpreted as 4 bits/pixel, aligned in bits 3-0 of the byte                                                                                                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| <b>l</b> | R/W | COMPOSITE_CI4_RGB_HIGH_NIBBLE |    |    |    |    |    |    |    |    |    | Denotes that when in CI8 -> RGB texture lookup mode for the secondary map, the texture should be interpreted as 4 bits/pixel, aligned in bits 7-4 of the byte                                                                                                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |

| Cont'd |     | ALPHA_TST_CNTL    |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_54                                                                                                                                                                                                                                                                                                          |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|-----|-------------------|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|
|        |     | BITS              |   | 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 |  |  |  |  |  |  |  |  |  |  |  |  |
|        |     | n                 | m | l  | k  | j  |    | i  |    |    |    |    |    |    |    | h  | g  | f  | e  | d  |    | c                                                                                                                                                                                                                                                                                                                 | b  | a  |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |
| m      | R/W | COMPOSITE_SHADOW  |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | If this bit is set and compositing is being carried out, with the COMPOSITE_COMBINE_FCN set to 10, the COMPOSITE_SHADOW_ID field is compared to the un-expanded composite texels<br>If they match, the SPECULAR color is substituted for the composite texel, otherwise, 0 is substituted for the composite texel |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |
| n      | R/W | SPECULAR_LIGHT_EN |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Denotes whether a specular value should be added to texture mapped pixels as part of the lighting function<br>This bit should NOT be set if COMPOSITE_SHADOW is ON<br>0 = Specular Lighting Off<br>1 = Specular Lighting On                                                                                       |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |

|      |     | COMPOSITE_SHADOW_ID |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_E6                                                                                                                                                             |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | a                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                      |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | COMPOSITE_SHADOW_ID |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | This field is a count of executed 3D primitives<br>It is used as part of the shadow ID algorithm, but may also be used as a general counter for performance purposes |    |   |   |   |   |   |   |   |   |   |   |

## 5.1.2 Source Trajectory Registers

|      |     | SRC_CNTL               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | MM: 0_6D |                                                                                                                                                                                                                                                                                                                  |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
|------|-----|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|--|
| BITS |     | 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 |   |   |   |   |   |   |   |  |
|      |     |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | n                                                                                                                                                                                                                                                                                                                | m | l | k | j | i | h | g | f | e | d | c | b | a |  |
| a    | R/W | SRC_PATT_EN            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Enable pattern source<br>SRC_Y_END is only used if this bit is enabled                                                                                                                                                                                                                                           |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
| b    | R/W | SRC_PATT_ROT_EN        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Enable pattern source rotation<br>SRC_X_START, SRC_Y_START is only used if this bit is enabled                                                                                                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
| c    | R/W | SRC_LINEAR_EN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Enables the source to be advanced linearly in memory<br>The source starts at SRC_OFFSET and advances in the left-to-right direction<br>Note: DST_X_DIR should also be set to the left-to-right to operate properly. All other source registers and control bits with the exception of SRC_BYTE_ALIGN are ignored |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
| d    | R/W | SRC_BYTE_ALIGN         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Allows the source to skip to the next data byte boundary when the destination advances in the Y direction<br>Note: SRC_LINEAR_EN MUST be set                                                                                                                                                                     |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
| e    | R/W | SRC_LINE_X_DIR         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Source X direction when drawing operation is a bresenham line                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
| f    | R/W | SRC_8x8x8_BRUSH        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Treats source as an 8x8x8 linear brush (SRC must be QWORD aligned)                                                                                                                                                                                                                                               |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
| g    | R/W | FAST_FILL_EN           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Fast filling for transparent DST<br>Not needed if auto-fast-fills are enabled (see HW_DEBUG)<br>Write as '0'                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
| h    | R/W | SRC_TRACK_DST          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Source will track the trajectory which the Dst FIFO is using                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
| i    | R/W | BUS_MASTER_EN          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Enable bus mastering for any subsequent GUI operations                                                                                                                                                                                                                                                           |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
| j    | R/W | BUS_MASTER_SYNC        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Synchronize GUI operations to bus master.<br>No operations permitted until both GUI and bus master are complete                                                                                                                                                                                                  |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
| k    | R/W | BUS_MASTER_OP          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | GUI operation performed by the bus master<br>0 = Frame buffer to system memory operation<br>1 = System memory to frame buffer operation<br>2 = Foreground register to system memory operation<br>3 = System memory to host data register operation                                                               |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
| l    | R/W | SRC_8x8x8_BRUSH_LOADED |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Holds current 8x8x8 brush for next brush operation<br>0 = Load new brush<br>1 = Hold 8x8x8 brush from previous operation<br>Note: SRC_8x8x8_BRUSH must be set to '1' for this bit to have effect                                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |  |

| Cont'd |     | SRC_CNTL           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_6D                                                                                                                          |    |   |   |   |   |   |   |   |   |   |   |   |   |
|--------|-----|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |   |   |
|        |     |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | n                                                                                                                                 | m  | l | k | j | i | h | g | f | e | d | c | b | a |
| m      | R/W | COLOR_REG_WRITE_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable color register blit for SGRAM<br>Not needed when auto-color register updates are enabled (see HW_DEBUG)<br>Write as 0      |    |   |   |   |   |   |   |   |   |   |   |   |   |
| n      | R/W | BLOCK_WRITE_EN     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable block write blit using SGRAM color register<br>Not needed if auto-block-writes are enabled (see HW_DEBUG).<br>Write as '0' |    |   |   |   |   |   |   |   |   |   |   |   |   |

### Description

This register contains various enable bits for blit source trajectory control.

SRC\_PATT\_EN, SRC\_PATT\_ROT\_EN, and SRC\_LINEAR\_EN are set as shown in the table below to select the source trajectories as follows:

**Table 5-1 Source Trajectories vs SRC\_CNTL Enable Bits**

| SRC_LINEAR_EN | SRC_PATT_ROT_EN | SRC_PATT_EN | Source Trajectory             |
|---------------|-----------------|-------------|-------------------------------|
| 1             | 0               | 0           | Strictly Linear               |
| 0             | 0               | 0           | Unbounded Y                   |
| 0             | 0               | 1           | General Pattern               |
| 0             | 1               | 1           | General Pattern with Rotation |

SRC\_BYTE\_ALIGN is applicable only when the destination is rectangular. In 1 bpp mode, if this field is set, the source pointer will advance to the nearest byte boundary when the destination advances in the Y direction.

SRC\_LINE\_X\_DIR is applicable only when the destination is a line. It is used to specify the source direction.

Source and destination trajectory directions are de-coupled for line draws. The source is always rectangular, but never advances in the Y direction for lines.

For SRC\_8x8x8\_BRUSH, the SRC\_LINEAR\_EN must be set as well. The source pixel depth should be set to 8Bpp and the source in DP\_SRC should be set the 'Blit Source' in order for the 8x8x8 brush to be used.

For BUS\_MASTER\_OP = 2 (Foreground register to system memory), all 32-bits of the foreground register are always transferred to system memory. Thus, prior to setting

the bus master to this mode, the desired color to be transferred must be replicated in all 32-bits of the foreground color register if the current GUI pixel depth is < 32Bpp.

For block write operations, the following apply:

- The color register must be written qword-aligned.
- There are no restrictions on the alignment of operations (i.e., DST\_X), except that DST\_OFF\_PITCH must be 64 byte aligned and DST\_PITCH must be a multiple of 64 bytes in pixel depth.
- Pixel depths of 8/16/32 bpp are fully supported (not 24 bpp).
- Fastfill bit must be set.

### Usage

Use this register only if a blit source is selected in the pixel data path.

### See Also

DST\_CNTL on [page 5-5](#)

GUI\_TRAJ\_CNTL on [page 5-65](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories*
- *Engine Operations: Background Information: Source and Destination Alignment*
- *Engine Operations: Draw Operations: Standard Bitblit Source*

|      |     |             | <b>SRC_HEIGHT1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | MM: 0_65 |   |   |   |   |   |   |
|------|-----|-------------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------|---|---|---|---|---|---|
| BITS |     |             | 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 |
|      |     |             |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | a        |   |   |   |   |   |   |
| a    | R/W | SRC_HEIGHT1 | Source height 1    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |   |   |   |   |   |   |

### Description

This register specifies the height of the source area for general-pattern sources or the vertical distance (in lines) from DST\_Y to the bottom of a pattern block for general-pattern-with-rotation sources.

### Usage

Set this register only if a general-pattern blit source or general-pattern-with-rotation blit source is selected in the pixel data path.

### *See Also*

SRC\_HEIGHT1\_WIDTH1 on *page 5-24*

SRC\_WIDTH1 on *page 5-27*

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Source Trajectory 3, General Pattern*
  - *Engine Operations: Background Information: Trajectories: Source Trajectory 4, General Pattern with Rotation*
  - *Engine Operations: Draw Operations: Standard Bitblit Source: General Pattern*
  - *Engine Operations: Draw Operations: Standard Bitblit Source: General Pattern with Rotation*

## *Description*

This register is a composite of SRC\_HEIGHT1 and SRC\_WIDTH1.

## *Usage*

Set this register only if a general-pattern blit source or general-pattern-with-rotation blit source is selected in the pixel data path.

#### *See Also*

SRC\_HEIGHT1 on *page 5-23*

SRC\_WIDTH1 on *page 5-27*

| SRC_HEIGHT2 |     |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|-------------|-----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| BITS        |     | 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 |  |
|             |     |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |   |   |   | a |   |   |   |   |   |   |  |
| a           | R/W | SRC_HEIGHT2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Source height 2 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

### Description

This register specifies the height of the general pattern for general-pattern-with-rotation sources.

### Usage

Set this register only if a general-pattern-with-rotation blit source is selected.

### See Also

[SRC\\_HEIGHT2\\_WIDTH2](#) on [page 5-25](#)

[SRC\\_WIDTH2](#) on [page 5-27](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Source Trajectory 4, General Pattern with Rotation*
- *Engine Operations: Draw Operations: Standard Bitblit Source: General Pattern with Rotation*

| SRC_HEIGHT2_WIDTH2 |   |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|--------------------|---|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| BITS               |   | 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 |  |
|                    |   |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |   |   |   | a |   |   |   |   |   |   |  |
| a                  | W | SRC_HEIGHT2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Source height 2 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| b                  | W | SRC_WIDTH2  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Source width 2  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

### Description

This register is a composite of SRC\_HEIGHT2 and SRC\_WIDTH2.

### Usage

Set these registers only if a general-pattern-with-rotation blit source is selected.

**See Also**SRC\_HEIGHT2 on [page 5-25](#)SRC\_WIDTH2 on [page 5-27](#)

|      |     |                                                                                                                                                     | <b>SRC_OFF_PITCH</b> |  |  |  |  |  |  |  |  |  |  |                                                                                                                                                                               |   |  |  |  | <b>MM: 0_60</b> |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--|--|--|--|--|--|--|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 | a                    |  |  |  |  |  |  |  |  |  |  |                                                                                                                                                                               | a |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | b                                                                                                                                                   |                      |  |  |  |  |  |  |  |  |  |  | a                                                                                                                                                                             |   |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | SRC_OFFSET                                                                                                                                          |                      |  |  |  |  |  |  |  |  |  |  | Source offset address in terms of 64 bit words                                                                                                                                |   |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | SRC_PITCH                                                                                                                                           |                      |  |  |  |  |  |  |  |  |  |  | Source pitch in pixels x 8<br>Note: In monochrome mode the source pitch must be a multiple of 64 pixels; also, in 4 bpp mode the source pitch must be a multiple of 16 pixels |   |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |

**Description**

This register specifies the offset (in QWORDs) and pitch (in pixels) of the blit source area.

**Usage**

This register should be set for any draw operations that select a blit source in the pixel data path.

**See Also**DST\_OFF\_PITCH on [page 5-9](#)

mach64 Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Source Trajectory 1, Strictly Linear*
- *Engine Operations: Background Information: Trajectories: Source Trajectory 2, Unbounded Y*
- *Engine Operations: Background Information: Trajectories: Source Trajectory 3, General Pattern*
- *Engine Operations: Background Information: Source Trajectory 4, General Pattern with Rotation*

| SRC_WIDTH1 |     |                                                                                       |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | MM: 0_64 |  |
|------------|-----|---------------------------------------------------------------------------------------|----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|
| BITS       |     | 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 |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
|            |     | a                                                                                     |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| a          | R/W | SRC_WIDTH1                                                                            | Source width 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |

### Description

This register specifies the width of the source area for general pattern sources or the horizontal distance (in pixels) from DST\_X to the right edge of a pattern block for general pattern sources with rotation.

### Usage

Set this register only if a general-pattern blit source, a general-pattern-with-rotation blit source, or an unbounded Y source is selected in the pixel data path.

### See Also

[SRC\\_HEIGHT1](#) on [page 5-23](#)

[SRC\\_HEIGHT1\\_WIDTH1](#) on [page 5-24](#)

*mach64* Programmer's Guide:

- [Engine Operations: Background Information: Trajectories: Source Trajectory 2, Unbounded Y](#)
- [Engine Operations: Background Information: Trajectories: Source Trajectory 3, General Pattern](#)
- [Engine Operations: Background Information: Trajectories: Source Trajectory 4, General Pattern with Rotation](#)
- [Engine Operations: Draw Operations: Standard Bitblit Source: General Pattern](#)
- [Engine Operations: Draw Operations: Standard Bitblit Source: General Pattern with Rotation](#)

| SRC_WIDTH2 |     |                                                                                       |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | MM: 0_6A |
|------------|-----|---------------------------------------------------------------------------------------|----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|
| BITS       |     | 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 |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |
|            |     | a                                                                                     |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |
| a          | R/W | SRC_WIDTH2                                                                            | Source width 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |

### Description

This register specifies the width of the pattern for general-pattern-with-rotation sources.

### Usage

Set this register only if a general-pattern-with-rotation blit source is selected.

### See Also

[SRC\\_HEIGHT2](#) on [page 5-25](#)

[SRC\\_HEIGHT2\\_WIDTH2](#) on [page 5-25](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Source Trajectory 4, General Pattern with Rotation*
- *Engine Operations: Draw Operations: Standard Bitblit Source: General Pattern with Rotation*

|      |     |       | <b>SRC_X</b> |    |    | <b>MM: 0_61</b> |    |    |    |    |    |    |    |    |    |    |    |                     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|------|-----|-------|--------------|----|----|-----------------|----|----|----|----|----|----|----|----|----|----|----|---------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| BITS |     | 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 |  |  |  |  |
|      |     | a     |              |    |    |                 |    |    |    |    |    |    |    |    |    |    |    |                     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| a    | R/W | SRC_X |              |    |    |                 |    |    |    |    |    |    |    |    |    |    |    | Source X coordinate |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

### Description

This register specifies the starting X coordinate of the blit source trajectory. This is a signed 14 bit number.

### Usage

Use this register for any draw operation which selects a blit source in the pixel data path.

### See Also

[SRC\\_Y](#) on [page 5-29](#)

[SRC\\_Y\\_X](#) on [page 5-31](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Source Trajectory 1, Strictly Linear*
- *Engine Operations: Background Information: Trajectories: Source Trajectory 2, Unbounded Y*

- *Engine Operations: Background Information: Trajectories: Source Trajectory 4, General Pattern*
- *Engine Operations: Background Information: Trajectories: Source Trajectory 4, General Pattern with Rotation*

|      |     |             | <b>SRC_X_START</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                | <b>MM: 0_67</b> |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|-------------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------------------------|-----------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
| a    | R/W | SRC_X_START |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Pattern source X start for pattern rotation in the X direction |                 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register specifies the starting horizontal edge of a general-pattern-with-rotation blit source. This is a signed 14 bit number.

### Usage

Set this register only if a draw operation selects a general-pattern-with-rotation in the pixel data path.

### See Also

[SRC\\_Y\\_START](#) on [page 5-30](#)

[SRC\\_Y\\_X\\_START](#) on [page 5-31](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Source Trajectory 4, General Pattern with Rotation*
- *Engine Operations: Draw Operations: Standard Bitblit Source: General Pattern with Rotation*

|      |     |       | <b>SRC_Y</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     | <b>MM: 0_62</b> |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|-------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|-----------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
| a    | R/W | SRC_Y |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Source Y coordinate |                 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### *Description*

This register specifies the starting Y coordinate of the blot source trajectory. This is a signed 15 bit number.

## *Usage*

Use this register for any draw operation that selects a blit source in the pixel data path.

### *See Also*

SRC\_X on *page 5-28*

SRC\_Y\_X on *page 5-31*

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Source Trajectory 1, Strictly Linear*
  - *Engine Operations: Background Information: Trajectories: Source Trajectory 2, Unbounded Y*
  - *Engine Operations: Background Information: Trajectories: Source Trajectory 4, General Pattern*
  - *Engine Operations: Background Information: Trajectories: Source Trajectory 4, General Pattern with Rotation*

### *Description*

This register specifies the starting vertical edge of a general-pattern-with-rotation blit source. This is a signed 15 bit number.

## *Usage*

Set this register only if a draw operation selects a general-pattern-with-rotation in the pixel data path.

#### *See Also*

SRC\_X\_START on *page* 5-29

SRC\_Y\_X\_START on *page 5-31*

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Trajectories: Source Trajectory 4, General Pattern with Rotation*
- *Engine Operations: Draw Operations: Standard Bitblit Source: General Pattern with Rotation*

| SRC_Y_X |   |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |    |    |    |    |    |   |   |   |   |   |   |   | MM: 0_63 |   |   |
|---------|---|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|----|----|----|----|----|---|---|---|---|---|---|---|----------|---|---|
| BITS    |   | 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 |
|         |   | b     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                   |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |
| a       | W | SRC_Y |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Source Y coordinate |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |
| b       | W | SRC_X |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Source X coordinate |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |

### Description

This register is a composite of SRC\_Y and SRC\_X.

### Usage

Set these registers only if a blit source is selected in the pixel data path.

### See Also

SRC\_Y on [page 5-29](#)

SRC\_X on [page 5-28](#)

| SRC_Y_X_START |   |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                |    |    |    |    |    |   |   |   |   |   |   |   | MM: 0_69 |   |   |
|---------------|---|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|----------|---|---|
| BITS          |   | 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 |
|               |   | b           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                                                              |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |
| a             | W | SRC_Y_START |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Pattern source Y start for pattern rotation in the Y direction |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |
| b             | W | SRC_X_START |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Pattern source X start for pattern rotation in the X direction |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |

### Description

This register is a composite of SRC\_X\_START and SRC\_Y\_START.

### Usage

Set these registers only if a general pattern with rotation blit source is selected in the pixel data path.

**See Also**SRC\_X\_START on [page 5-29](#)SRC\_Y\_START on [page 5-30](#)

## 5.2 Draw Engine Control Registers

### 5.2.1 Host Data Registers

The host data registers provide pixel data that are used in the current drawing operation. The pixel data may be used as a monochrome or color pixel source. For rectangular drawing operations, the pixel data may be either packed from one horizontal line to the next or unpacked. All registers are treated identically and data is fed to the engine in the order in which it is written to any of the host data registers. Up to sixteen host data registers are provided to allow block data moves of variable length up to the depth of the parameter FIFO.

|      |   |              | HOST_DATA[15:0]                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_80 – 0_8F |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|------|---|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| BITS |   |              | 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 |  |
| a    |   |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   | a |  |
| a    | W | HOST_DATA[i] | Host data register – pixel data taken from the least significant bit, nibble, byte, or word for left-to-right rectangular drawing operations; and taken from the most significant bit, nibble, byte, or word for right-to-left rectangular drawing operations. Data for line drawing operations are always taken from the least significant bit, nibble, byte, or word<br>See DP_BYTPIX_ORDER@DP_PIX_WIDTH for more details on monochrome mode. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

**Description**

This register is actually a single register mapped to 16 consecutive addresses, thus the notation HOST\_DATA[15:0]. This scheme enables applications to conduct high speed host transfers using REP MOVSD. The register corresponds directly to the host data source in the pixel data path.

If a draw operation expects host data and any other draw engine register is written, the draw operation will *panic* and complete the draw operation with a garbage color. This condition is interruptible through BUS\_CNTL.

If HOST\_DATA is written and host data is not expected, the data is discarded.

Full FIFO discipline must be applied to this register; that is, check the FIFO before doing a REP MOVSD.

### Usage

Data is fed to the draw engine through a host source by repeatedly writing pixel data to this register. Under certain conditions, it may be more desirable to write directly to the big linear aperture instead of using the host data port.

When using HOST\_DATA for 3D operations (either shading or texture mapping), the data is not allowed to be packed. That is, only a single pixel at a time is sent to the host data register. The pixel will be assumed to be aligned to bit 0. The DP\_SCALE\_PIX\_WIDTH rather than the DP\_HOST\_PIX\_WIDTH field will determine the size of the data.

### See Also

[BUS\\_CNTL](#) on [page 4-5](#)

[HOST\\_CNTL](#) on [page 5-33](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Logical Pixel Data Path: Host Data Consumption*
- *Advanced Topics: Performance Issues*

|      |     | HOST_CNTL          |    | MM: 0_90 |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                                                                  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|--------------------|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     |                    |    | b        | a  |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                                                                  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | HOST_BYTE_ALIGN    |    |          |    |    |    |    |    |    |    |    |    |    |    |    | Enables byte aligning the host data                                                                                                                                                                                                                                                                              |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b    | R/W | HOST_BIG_ENDIAN_EN |    |          |    |    |    |    |    |    |    |    |    |    |    |    | Enables big endian data translation for 15 bpp, 16 bpp, and 32 bpp pixel width. In 15 bpp and 16 bpp modes the bytes within each word are swapped. In 32 bpp mode the order of the four bytes within each dword is reversed<br>0 = Disable big endian data translation<br>1 = Enable big endian data translation |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

HOST\_BYTE\_ALIGN controls the host data consumption for 1 bpp data. When T\_BYTE\_ALIGN is enabled and the destination trajectory advances in the Y direction,

pixels are consumed from the host data port until the nearest byte boundary is reached. When host data byte align is not enabled, pixel data is packed.

### Usage

HOST\_BIT\_ENDIAN\_EN controls the endians of the HOST\_DATA register. This register is used only if a data path source is set to host data, and host data pixel width is 1 bpp.

### See Also

[GUI\\_TRAJ\\_CNTL](#) on [page 5-65](#)

[HOST\\_DATA](#) on [page 5-32](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Logical Pixel Data Path: Host Data Consumption*
- *Engine Operations: Draw Operations: Color Source: Drawing Rectangles*

## 5.2.2 Pattern Registers

Two pattern registers (PAT\_REG0 and PAT\_REG1) support three fixed destination aligned pattern modes: monochrome 8x8, 8bpp color 4x2, and 8bpp color 8x1. For the VT/GT-B, 8x8x8 patterns or brushes can be using a linear source in conjunction with the SRC\_8x8x8\_BRUSH@SRC\_CNTL. For all patterns, the alignment of register data to the least significant bits of DST\_X and DST\_Y is as follows:

**Table 5-2 Data Alignment (Monochrome 8x8x1, DP\_BYTE\_PIX\_ORDER = 0)**

|       |        | DST_X  |        |        |        |        |        |        |  |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|--|
| DST_Y | 0      | 1      | 2      | 3      | 4      | 5      | 6      | 7      |  |
| 0     | P0(7)  | P0(6)  | P0(5)  | P0(4)  | P0(3)  | P0(2)  | P0(1)  | P0(0)  |  |
| 1     | P0(15) | P0(14) | P0(13) | P0(12) | P0(11) | P0(10) | P0(9)  | P0(8)  |  |
| 2     | P0(23) | P0(22) | P0(21) | P0(20) | P0(19) | P0(18) | P0(17) | P0(16) |  |
| 3     | P0(31) | P0(30) | P0(29) | P0(28) | P0(27) | P0(26) | P0(25) | P0(24) |  |
| 4     | P1(7)  | P1(6)  | P1(5)  | P1(4)  | P1(3)  | P1(2)  | P1(1)  | P1(0)  |  |
| 5     | P1(15) | P1(14) | P1(13) | P1(12) | P1(11) | P1(10) | P1(9)  | P1(8)  |  |

**Table 5-2 Data Alignment (Monochrome 8x8x1, DP\_BYTEx\_PIX\_ORDER = 0) Cont'd**

| DST_Y | DST_X  |        |        |        |        |        |        |        |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|       | 0      | 1      | 2      | 3      | 4      | 5      | 6      | 7      |
| 6     | P1(23) | P1(22) | P1(21) | P1(20) | P1(19) | P1(18) | P1(17) | P1(16) |
| 7     | P1(31) | P1(30) | P1(29) | P1(28) | P1(27) | P1(26) | P1(25) | P1(24) |

**Table 5-3 Data Alignment (Monochrome 8x8x1, DP\_BYTEx\_PIX\_ORDER = 1)**

| DST_Y | DST_X  |        |        |        |        |        |        |        |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|       | 0      | 1      | 2      | 3      | 4      | 5      | 6      | 7      |
| 0     | P0(0)  | P0(1)  | P0(2)  | P0(3)  | P0(4)  | P0(5)  | P0(6)  | P0(7)  |
| 1     | P0(8)  | P0(9)  | P0(10) | P0(11) | P0(12) | P0(13) | P0(14) | P0(15) |
| 2     | P0(16) | P0(17) | P0(18) | P0(19) | P0(20) | P0(21) | P0(22) | P0(23) |
| 3     | P0(24) | P0(25) | P0(26) | P0(27) | P0(28) | P0(29) | P0(30) | P0(31) |
| 4     | P1(0)  | P1(1)  | P1(2)  | P1(3)  | P1(4)  | P1(5)  | P1(6)  | P1(7)  |
| 5     | P1(8)  | P1(9)  | P1(10) | P1(11) | P1(12) | P1(13) | P1(14) | P1(15) |
| 6     | P1(16) | P1(17) | P1(18) | P1(19) | P1(20) | P1(21) | P1(22) | P1(23) |
| 7     | P1(24) | P1(25) | P1(26) | P1(27) | P1(28) | P1(29) | P1(30) | P1(31) |

**Table 5-4 Data Alignment (Color 4x2x8)**

| DST_Y | DST_X   |          |           |           |
|-------|---------|----------|-----------|-----------|
|       | 0       | 1        | 2         | 3         |
| 0     | P0(7:0) | P0(15:8) | P0(23:16) | P0(31:24) |
| 1     | P1(7:0) | P1(15:8) | P1(23:16) | P1(31:24) |

**Table 5-5 Data Alignment (Color 8x1x8)**

| DST_X   |          |           |           |         |          |           |           |
|---------|----------|-----------|-----------|---------|----------|-----------|-----------|
| 0       | 1        | 2         | 3         | 4       | 5        | 6         | 7         |
| P0(7:0) | P0(15:8) | P0(23:16) | P0(31:17) | P1(7:0) | P1(15:8) | P1(23:16) | P1(31:24) |

| PAT_REG0 MM: 0_A0 |     |          |    |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------|-----|----------|----|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS              |     | 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 |
| a                 |     | a        |    |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a                 | R/W | PAT_REG0 |    | Pattern register 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register defines one half of a fixed pattern. PAT\_REG1 defines the other half.

### Usage

Set this register only when a fixed monochrome or fixed color pattern is selected as a data path source.

### See Also

PAT\_CNTL on [page 5-37](#)

PAT\_REG1 on [page 5-37](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Logical Pixel Data Path*
- *Engine Operations: Background Information: Logical Pixel Data Path: Pattern Consumption*
- *Engine Operations: Draw Operations: Pattern Source: Fixed Patterns*

| PAT_REG1 |     |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|-----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS     |     | 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 |
|          |     | a        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a        | R/W | PAT_REG1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Pattern register 1 |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register defines one half of a fixed pattern. PAT\_REG0 defines the other half.

### Usage

Set this register only when a fixed monochrome or fixed color pattern is selected as a data path source.

### See Also

PAT\_CNTL on [page 5-37](#)

PAT\_REG0 on [page 5-36](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Logical Pixel Data Path*
- *Engine Operations: Background Information: Logical Pixel Data Path: Pattern Consumption*
- *Engine Operations: Draw Operations: Pattern Source: Fixed Patterns*

| PAT_CNTL |     |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|-----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS     |     | 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 |
|          |     | c b a          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a        | R/W | PAT_MONO_EN    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Monochrome 8x8 pattern enable |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b        | R/W | PAT_CLR_4x2_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Color 4x2 pattern enable      |    |    |    |   |   |   |   |   |   |   |   |   |   |
| c        | R/W | PAT_CLR_8x1_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Color 8x1 pattern enable      |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register is used for fixed pattern control. All enable bits are mutually exclusive; do not set more than one for any draw operation.

### **Usage**

Only use this register when the monochrome source is set for fixed mono patterns or when either of the two color sources is set for fixed color patterns. When a fixed pattern is selected, one and only one pattern type can be selected (i.e., set one, and only one bit in this register).

Only 8 bpp color pattern source is supported. Use generalized source pattern for 16 bpp and 32 bpp color patterns.

### **See Also**

[GUI\\_TRAJ\\_CNTL](#) on [page 5-65](#)

[PAT\\_REG0](#) on [page 5-36](#)

[PAT\\_REG1](#) on [page 5-37](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Logical Pixel Data Path*
- *Engine Operations: Background Information: Logical Pixel Data Path: Pattern Consumption*
- *Engine Operations: Draw Operations: Pattern Source: Fixed Patterns*

### **5.2.3 Scissors**

The scissor registers define the rectangular region within which data is drawn. Left and right scissor registers are within the range -8192 to +8191. Top and bottom scissor registers are within the range -16384 to +16383. Polylines which follow a trajectory to the left of the left scissor register will result in a line drawn along the left scissor coordinate.

|      |     | SC_LEFT |    |    |    |    |    |    |    |    |    |              |    |    |    |    |    | MM: 0_A8 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|---------|----|----|----|----|----|----|----|----|----|--------------|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     |         |    |    |    |    |    |    |    |    |    |              |    |    |    |    |    | a        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | SC_LEFT |    |    |    |    |    |    |    |    |    | Left scissor |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### **Description**

This register defines the left edge of a scissor rectangle. Drawing is inhibited for any pixel that is outside this scissor rectangle. Scissors are inclusive. This is a signed, 14-bit number.

### **Usage**

This register must be set for all draw operations.

**See Also**SC\_TOP on [page 5-40](#)SC\_BOTTOM on [page 5-41](#)SC\_RIGHT on [page 5-39](#)SC\_LEFT\_RIGHT on [page 5-40](#)*mach64* Programmer's Guide:

- *Engine Operations: Miscellaneous Operations: Scissoring and Masking*

|      |     |          | SC_RIGHT |    |    |    |    |    |    |    |    |    |    |               |    |    | MM: 0_A9 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|----------|----------|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     |          |          |    |    |    |    |    |    |    |    |    |    |               |    |    |          |    |    |    |    |    |    |   |   |   | a |   |   |   |   |   |   |
| a    | R/W | SC_RIGHT |          |    |    |    |    |    |    |    |    |    |    | Right scissor |    |    |          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Description**

This register defines the right edge of a scissor rectangle. Drawing is inhibited for any pixel which is outside of this scissor rectangle. Scissors are inclusive. This is a signed 14-bit number.

**Usage**

This register must be set for all draw operations.

**See Also**SC\_TOP on [page 5-40](#)SC\_LEFT on [page 5-38](#)SC\_LEFT\_RIGHT on [page 5-40](#)SC\_BOTTOM on [page 5-41](#)*mach64* Programmer's Guide:

- *Engine Operations: Miscellaneous Operations: Scissoring and Masking*

| SC_LEFT_RIGHT |   |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|---|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS          |   | 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 |
|               |   | b        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a             | W | SC_LEFT  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Left scissor  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b             | W | SC_RIGHT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Right scissor |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register is a composite of registers SC\_LEFT and SC\_RIGHT.

### Usage

This register must be set for all draw operations.

### See Also

[SC\\_LEFT on page 5-38](#)

[SC\\_RIGHT on page 5-39](#)

| SC_TOP |     |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a      | R/W | SC_TOP |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Top scissor |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register defines the top edge of a scissor rectangle. Drawing is inhibited for any pixel which is outside of this scissor rectangle. Scissors are inclusive. This is a signed 15-bit number.

### Usage

This register must be set for all draw operations.

### See Also

[SC\\_BOTTOM on page 5-41](#)

[SC\\_LEFT on page 5-38](#)

[SC\\_RIGHT on page 5-39](#)

[SC\\_TOP\\_BOTTOM on page 5-41](#)

*mach64* Programmer's Guide:

- *Engine Operations: Miscellaneous Operations: Scissoring and Masking*

|      |     |           | SC_BOTTOM |    |    |    |    |    |    |    |    |    |    |    |    |    |                | MM: 0_AC |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|-----------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     |           |           |    |    |    |    |    |    |    |    |    |    |    |    |    | a              |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | SC_BOTTOM |           |    |    |    |    |    |    |    |    |    |    |    |    |    | Bottom scissor |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register defines the bottom edge of a scissor rectangle. Drawing is inhibited for any pixel which is outside of this scissor rectangle. Scissors are inclusive. This is a signed 15-bit number.

### Usage

This register must be set for all draw operations.

### See Also

[SC\\_TOP](#) on [page 5-40](#)

[SC\\_TOP\\_BOTTOM](#) on [page 5-41](#)

[SC\\_LEFT](#) on [page 5-38](#)

[SC\\_RIGHT](#) on [page 5-39](#)

*mach64* Programmer's Guide:

- *Engine Operations: Miscellaneous Operations: Scissoring and Masking*

|      |   |           | SC_TOP_BOTTOM |    |    |    |    |    |    |    |    |    |    |    |    |    |                | MM: 0_AD |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|---|-----------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS |   | 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 |
|      |   | b         |               |    |    |    |    |    |    |    |    |    |    |    |    |    | a              |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a    | W | SC_TOP    |               |    |    |    |    |    |    |    |    |    |    |    |    |    | Top scissor    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b    | W | SC_BOTTOM |               |    |    |    |    |    |    |    |    |    |    |    |    |    | Bottom scissor |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register is a composite of registers SC\_TOP and SC\_BOTTOM.

**Usage**

This register must be set for all draw operations.

**See Also**

SC\_TOP on [page 5-40](#)

SC\_BOTTOM on [page 5-41](#)

## 5.2.4 Data Path Registers

|      |     |             | DP_BKGD_CLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                  | MM: 0_B0 |   |   |   |   |   |  |  |
|------|-----|-------------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------------------|----------|---|---|---|---|---|--|--|
| BITS | 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 |  |  |
|      | a   |             |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                  |          |   |   |   |   |   |  |  |
| a    | R/W | DP_BKGD_CLR |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Background color |          |   |   |   |   |   |  |  |

**Description**

This register is used to hold a solid color source. The number of bits used varies depending on graphics modes, as follows:

**Table 5-6 Video Modes vs Bits Used**

| Video Mode    | Bits Used                     |
|---------------|-------------------------------|
| 1 bpp         | The least significant bit     |
| 8 bpp         | The least significant 8 bits  |
| 15 bpp/16 bpp | The least significant 16 bits |
| packed 24 bpp | The least significant 24 bits |
| 32 bpp        | All 32 bits                   |

**Usage**

Generally, use this register for the background source in a color expansion of monochrome data.

**See Also**

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Logical Pixel Data Path*

| DP_FRGD_CLR (ALSO DP_FOG_CLR) |     |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------------|-----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS                          |     | 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 |
|                               |     | a           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a                             | R/W | DP_FRGD_CLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Foreground color |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register holds a solid color source. The number of bits used varies depending on graphics modes, as follows:

**Table 5-7 Video Modes vs Bits Used**

| Video Mode    | Bits Used                     |
|---------------|-------------------------------|
| 1 bpp         | The least significant bit     |
| 8 bpp         | The least significant 8 bits  |
| 15 bpp/16 bpp | The least significant 16 bits |
| packed 24 bpp | The least significant 24 bits |
| 32 bpp        | All 32 bits                   |

### Usage

Generally, use this register for solid color fill or for the foreground source in a color expansion of monochrome data.

The register (DP\_FOG\_CLR) is used to source the solid **Fog** color.

### See Also

*mach64 Programmer's Guide:*

- *Engine Operations: Background Information: Logical Pixel Data Path*

| DP_FRGD_BKGD_CLR |   |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------------|---|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS             |   | 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 |
|                  |   | b           |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a                | W | DP_FRGD_CLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Foreground color [0..15] |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b                | W | DP_BKGD_CLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Background color [0..15] |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register sets the pixel depth.

### Usage

Set this register for 16 bpp pixel depths and below.

### See Also

*mach64 Programmer's Guide:*

- *Engine Operations: Background Information: Logical Pixel Data Path*

|      |   | DP_FRGD_CLR_MIX |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    | MM: 0_B7 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|------|---|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|----|----|----|----------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| BITS |   | 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 |  |  |  |  |
|      |   | c               |    |    |    |    |    |    |    | b  |    |    |    |    |    |    |    | a                        |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| a    | W | DP_FRGD_CLR     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Foreground color [0..15] |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| b    | W | DP_FRGD_MIX     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Foreground mix           |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| c    | W | DP_FRGD_MIX     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Background mix           |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

### See Also

*mach64 Programmer's Guide:*

- *Engine Operations: Background Information: Logical Pixel Data Path*

|      |     | DP_WRITE_MSK |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|------|-----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| BITS |     | 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 |  |  |
|      |     | a            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| a    | R/W | DP_WRITE_MSK |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Write mask |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

### Description

This register inhibits the destination writing of selected bits within a pixel. Each occurrence of a zero in the mask will preserve the content of the destination pixel at that bit position in the pixel. The bits used vary according to the video mode used as shown in [Table 5-7 on page 43](#)

**Usage**

All draw operations require this register to be set.

When Alpha Blending is enabled, the Destination Read FIFO is unavailable to the 2D engine. This register **must** be set to 0xFFFFFFFFh.

**See Also**

*mach64 Programmer's Guide:*

- *Engine Operations: Miscellaneous Operations: Scissoring and Masking*

|      |     |                  | DP_PIX_WIDTH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | MM: 0_B4 |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|------|-----|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| BITS |     |                  | 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    | k  | j  | i  | h  |    | g  |    | f  |    |    | e  | d  |    | c  |    | b  |    | a  |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| a    | R/W | DP_DST_PIX_WIDTH | Destination datapath pixel width<br>0000 = Monochrome<br>0001 = Reserved<br>0010 = 8 bpp pseudocolor<br>0011 = 16 bpp aRGB 1555<br>0100 = 16 bpp RGB 565<br>0101 = 24 bpp. Valid only when SCALE_3D_FCN is set to SCALING. No ALPHA blending is allowed in this mode<br>0110 = 32 bpp aRGB 8888<br>0111 = 8 bpp RGB 332<br>1000 = Y8 greyscale<br>1001 = RGB8 greyscale (8 bit intensity, duplicated for all 3 channels. Green channel is used on writes)<br>1010 = Reserved<br>1011 = YUV 422 packed (VYUY)<br>1100 = YUV 422 packed (YYVY)<br>1101 = Reserved<br>1110 = aYUV 444 (8:8:8:8)<br>1111 = aRGB4444 (intermediate format only, not understood by the Display Controller) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

| Cont'd |     | DP_PIX_WIDTH        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | MM: 0_B4 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |   |   |   |   |   |  |  |  |  |
|--------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|--|--|--|--|
| BITS   |     | 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                   | k  | j  | i  | h  | g  |    |    | f  | e  | d  | c  | b  | a  |    |    |    |    |    |    |    |    |   |   |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |   |   |   |   |   |  |  |  |  |
| b      | R/W | COMPOSITE_PIX_WIDTH |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Datapath pixel width for secondary texture. Note that if the primary texture and the secondary texture are required to be the same width (in terms of bpp), but they may vary in format within that restriction                                                                                                                                                                                                                                                                    |   |   |   |   |   |   |  |  |  |  |
|        |     |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | 0000 = Reserved<br>0001 = Reserved<br>0010 = 8 bpp pseudocolor<br>0011 = 16 bpp aRGB 1555<br>0100 = 16 bpp RGB 565<br>0101 = Reserved<br>0110 = 32 bpp aRGB 8888<br>0111 = 8 bpp RGB 332<br>1000 = Y8 greyscale<br>1001 = RGB8 greyscale (8 bit intensity, duplicated for all 3 channels. Green channel is used on writes)<br>1010 = Reserved<br>1011 = YUV 422 packed (VYUY)<br>1100 = YUV 422 packed (YYVU)<br>1101 = (reserved)<br>1110 = aYUV 444 (8:8:8:8)<br>1111 = aRGB4444 |   |   |   |   |   |   |  |  |  |  |
| c      | R/W | DP_SRC_PIX_WIDTH    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Source datapath pixel width<br>0000 = Monochrome<br>0001 = Reserved<br>0010 = 8 bpp pseudocolor<br>0011 = 16 bpp aRGB 1555<br>0100 = 16 bpp RGB 565<br>0101 = Reserved<br>0110 = 32 bpp aRGB 8888<br>0111 = 8 bpp RGB332<br>1000 = Y8 greyscale<br>1001 = Reserved<br>1010 = Reserved<br>1011 = YUV 422 packed (VYUY)<br>1100 = YUV 422 packed (YYVU)<br>1101 = Reserved<br>1110 = aYUV 444 (8:8:8:8)<br>1111 = aRGB4444                                                           |   |   |   |   |   |   |  |  |  |  |
| d      | R/W | DP_HOST_TRIPLE_EN   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | 0 = Disable host data triplication<br>1 = Enable host data triplication                                                                                                                                                                                                                                                                                                                                                                                                            |   |   |   |   |   |   |  |  |  |  |
| e      | R/W | DP_PALETTE_TYPE     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | If set to 1, this indicates that the Texture Palette contains 32 bit ARGB entries<br>This bit is assumed to be 0 unless SCALE_3D_FCN is set to SCALING and SCALE_PIX_REP is 1                                                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |  |  |  |  |

| Cont'd |     | DP_PIX_WIDTH           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_B4                                                                                                                                                                                                                                                                                                                                                                                                                          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|-----|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS   |     | 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                      |    | k  | j  | i  | h  | g  |    |    | f  |    |    |    | e  | d  |    | c  |    | b  |    | a                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| f      | R/W | DP_HOST_PIX_WIDTH      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Host datapath pixel width<br>0000 = Monochrome<br>0001 = Reserved<br>0010 = 8 bpp pseudocolor<br>0011 = 16 bpp aRGB 1555<br>0100 = 16 bpp RGB 565<br>0101 = (reserved)<br>0110 = 32 bpp aRGB 8888<br>0111 = 8 bpp RGB8 332<br>1000 = Y8 greyscale<br>1001 = RGB8 greyscale<br>1010 = (reserved)<br>1011 = YUV 422 packed (VYUY)<br>1100 = YUV 422 packed (YVYU)<br>1101 = (reserved)<br>1110 = aYUV444 (8:8:8:<br>1111 = aRGB4444 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| g      | R/W | DP_CI4_RGB_INDEX       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | These bits will be used as the upper 4 bits of the CI4 color value to select 1 of 16 different palettes                                                                                                                                                                                                                                                                                                                           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| h      | R/W | DP_BYTE_PIX_ORDER      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Reverses the pixel order within each byte in monochrome modes<br>0 = Pixel order from MSBit to LSBit<br>1 =Pixel order from LSBit to MSBit                                                                                                                                                                                                                                                                                        |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| i      | R/W | DP_CONVERSION_TEMP     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | YUV to RGB conversion temperature<br>0 = Red@6500 K, GB@9300 K<br>1 = RGB@9300K                                                                                                                                                                                                                                                                                                                                                   |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| j      | R/W | DP_CI4_RGB_LOW_NIBBLE  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Denotes that when in CI8 -> RGB texture lookup mode, the texture should be interpreted as 4 bits/pixel, aligned in bits [3:0] of the byte                                                                                                                                                                                                                                                                                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| k      | R/W | DP_CI4_RGB_HIGH_NIBBLE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Denotes that when in CI8 -> RGB texture lookup mode, the texture should be interpreted as 4 bits/pixel, aligned in bits [7:4] of the byte                                                                                                                                                                                                                                                                                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Cont'd |     | DP_PIX_WIDTH       |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_B4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |
|--------|-----|--------------------|--|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|
|        |     | BITS               |  | 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                  |  | k  | j  | i  | h  | g  |    |    |    | f  |    |    |    | e  | d  | c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |    |    | b  |    |    |    | a |   |   |   |   |   |   |   |
| 1      | R/W | DP_SCALE_PIX_WIDTH |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Scaler source and 3D (texture and shading) datapath pixel width<br>0000 = Reserved<br>0001 = Reserved<br>0010 = 8 bpp pseudocolor<br>0011 = 15 bpp aRGB 1555<br>0100 = 16 bpp RGB 565<br>0101 = (reserved)<br>0110 = 32 bpp aRGB 8888<br>0111 = 8 bpp RGB8 332<br>1000 = Y8 greyscale<br>1001 = RGB8 greyscale (8 bit intensity, duplicated for all three channels, Green channel is used on writes)<br>1010 = Reserved<br>1011 = YUV 422 packed (VYUY)<br>1100 = YUV 422 packed (YYVU)<br>1101 = (reserved)<br>1110 = aYUV444 (8:8:8:8)<br>1111 = 16 bpp aRGB 4444 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |

### Description

This register specifies the pixel format of the destination area, blit source area, and host data register. Although each may be specified independently, the only pixel format conversions supported are 1 bpp to any pixel size when doing color expansion of monochrome data.

DP\_BYTE\_PIX\_ORDER affects pixel ordering within a byte of data for 1 bpp mode. This bit affects the pixel order when writing to destination memory or reading from blit source memory. It also affects the interpretation of the HOST\_DATA register.

If the display mode is 4 bpp, this field should be set to the same value as CRTC\_BYTE\_PIX\_ORDER@CRTC\_GEN\_CNTL. These bits should be set only once upon mode initialization.

### Usage

Use this register for setting draw engine pixel width and pixel ordering within a byte. The source, host, and destination pixel widths may be specified separately, although only the following combinations are supported for simple color sources:

**Table 5-8 Host Destination Pixel Width Combinations**

| Supported Pixel Widths     |                         |
|----------------------------|-------------------------|
| Host or Source Pixel Width | Destination Pixel Width |
| 1                          | 1                       |
| 1                          | 8                       |
| 1                          | 15                      |
| 1                          | 16                      |
| 1                          | 32                      |
| 8                          | 8                       |
| 15                         | 15                      |
| 16                         | 16                      |
| 32                         | 32                      |

Note that 8 bpp pseudo-color, Y8, and 8 bpp RGB332 are treated as raw 8 bpp data by the standard draw engine, and are differentiated from one another by the Scaler/3D block, which needs to pack expanded 24 bpp pixels into their respective destination pixel formats.

Also, YUV422 is treated as raw 32 bpp data by the standard draw engine, and is differentiated by the Scaler/3D block.

When using the Scaler/3D pipeline, the following combination of scaler source and destination pixel formats may be selected:

**Table 5-9 Scalar Pipe Pixel Conversions**

| Scaler Source Pixel Width | Destination Pixel Widths             |
|---------------------------|--------------------------------------|
| Pseudo 8                  | Pseudo 8                             |
| Y8                        | RGB8, 15, 16, 32, Y8, YUV422, YUV444 |
| Pseudo 8 or Y8            | RGB 8, 15, 32*                       |
| RGB 8                     | RGB 8, 15, 16, 32                    |
| RGB 12                    | RGB 8, 15, 16, 32                    |
| RGB 15                    | RGB 8, 15, 16, 32                    |
| RGB 16                    | RGB 8, 15, 16, 32                    |
| RGB 32                    | RGB 8, 15, 16, 32                    |
| YUV422                    | RGB8, 15, 16, 32, Y8, YUV422, YUV444 |
| YUV444                    | RGB8, 15, 16, 32, Y8, YUV422, YUV444 |

\* This combination is only available during Texture Mapping or Scaling. The Pseudocolor-to-RGB conversion is done via a read of the texture palette.

### See Also

mach64 Programmer's Guide:

- *Engine Operations: Draw Operations: Specialized BitBlt Source: Monochrome Expansion*

|      |     | DP_MIX      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_B5                         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | DP_BKGD_MIX |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Background mix (see table below) |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b    | R/W | DP_FRGD_MIX |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Foreground mix (see table below) |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register specifies the ALU mix function for both foreground and background expansions. If the result of the monochrome pixel consumption is zero, then the ALU uses DP\_BKGD\_MIX for that pixel; otherwise, DP\_FRGD\_MIX is used.

**Table 5-10 Mix Function Descriptions**

| Mix Function | Description             |
|--------------|-------------------------|
| 0h           | (not DST)               |
| 1h           | “0”                     |
| 2h           | “1”                     |
| 3h           | DST                     |
| 4h           | (not SRC)               |
| 5h           | DST xor SRC             |
| 6h           | (not DST) xor SRC       |
| 7h           | SRC                     |
| 8h           | (not DST) or (not SRC)  |
| 9h           | DST or (not SRC)        |
| Ah           | (not DST) or SRC        |
| Bh           | DST or SRC              |
| Ch           | DST and SRC             |
| Dh           | (not DST) and SRC       |
| Eh           | DST and (not SRC)       |
| Fh           | (not DST) and (not SRC) |
| 10h-1Fh      | Reserved                |

**Usage**

Always set this register. DP\_BKGD\_MIX is ‘*don’t\_care*’ for non-trivial color expansion of monochrome data. A non-trivial monochrome source is anything but *Always\_1*.

Note that when Alpha Blending or Anti-Aliasing is enabled, the Destination Read FIFO is unavailable to the 2D engine. In this case, DP\_MIX **must not** use the Destination.

**See Also**

DP\_MONO\_SRC@DP\_SRC on [page 5-58](#)

*mach64 Programmer's Guide:*

- *Engine Operations: Background Information: Logical Pixel Data Path*
- *Engine Operations: Background Information: Source and Destination Mixing Logic*

|      |   |               | USR_DST_PITCH |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                 | MM: 0_BC |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
|------|---|---------------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----------------------------------------------------------------|----------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|
| BITS |   | 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 |  |  |  |  |  |  |  |  |  |
|      |   |               |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                 |          |   |   |   |   |   | a |  |  |  |  |  |  |  |  |  |
| a    | W | USR_DST_PITCH |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DST_PITCH preset value for DP_SET_GUI_ENGINE/DP_SET_GUI_ENGINE2 |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |

*Usage*

Use this register with DP\_SET\_GUI\_ENGINE and DP\_SET\_GUI\_ENGINE2.

|      |   |                 | USR1_DST_OFF_PITCH |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                   | MM: 0_AE |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
|------|---|-----------------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------------------|----------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|
| BITS |   | 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 |  |  |  |  |  |  |  |  |  |
|      |   | b               |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                   | a        |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| a    | W | USR1_DST_OFFSET |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DST1_OFFSET value |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| b    | W | USR1_DST_PITCH  |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DST1_PITCH value  |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |

*Usage*

Use this register to support 2D/3D operations on the secondary display.

|      |   |                 | USR2_DST_OFF_PITCH |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                   | MM: 0_AF |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
|------|---|-----------------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------------------|----------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|
| BITS |   | 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 |  |  |  |  |  |  |  |  |  |
|      |   | b               |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                   | a        |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| a    | W | USR2_DST_OFFSET |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DST2_OFFSET value |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| b    | W | USR2_DST_PITCH  |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DST2_PITCH value  |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |

**Usage**

Use this register to support 2D/3D operations on the secondary display.

|      |   | DP_SET_GUI_ENGINE    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | MM: 0_BF |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|---|----------------------|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |   | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |   | n                    | m  | l  | k  | j  | i  | h  |    |                                                                                                                                                                                                                                                                              |    | g  |    |    |    | f  | e  | d  |    |    |    | c  |    |   |   | b | a        |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | W | SET_DP_DST_PIX_WIDTH |    |    |    |    |    |    |    | 000 = Mono<br>001 = Reserved<br>010 = 8 Bpp<br>011 = 15 Bpp<br>100 = 16 Bpp<br>101 = Reserved<br>110 = 32 Bpp<br>111 = Reserved                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | W | SET_DP_SRC_PIX_WIDTH |    |    |    |    |    |    |    | 0 = Mono<br>1 = Set same as SET_DP_DST_PIX_WIDTH setting                                                                                                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | W | SET_DST_OFFSET       |    |    |    |    |    |    |    | 0 = 0<br>1 = 256KB<br>2 = 512KB<br>3 = 768KB<br>4 = 1MB<br>5 = Reserved<br>6 = USR1_DST_OFFSET<br>7 = USR2_DST_OFFSET                                                                                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d    | W | SET_DST_PITCH        |    |    |    |    |    |    |    | 0 = USR1_DST_PITCH (if SET_DST_PITCH_BY_2 = 0)<br>USR2_DST_PITCH (if SET_DST_PITCH_BY_2 = 1)<br>1 = 320<br>2 = 352<br>3 = 384<br>4 = 640<br>5 = 800<br>6 = 896<br>7 = 512<br>8 = 1024<br>9 = 1152<br>10 = 1280<br>11 = 400<br>12 = 832<br>13 = 1600<br>14 = 448<br>15 = 2048 |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| e    | W | SET_DST_PITCH_BY_2   |    |    |    |    |    |    |    | Modify SET_DST_PITCH setting accordingly<br>0 = leave alone<br>1 = DstPitch*2 (Ignored when SET_DST_PITCH = 0)                                                                                                                                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Cont'd |   | DP_SET_GUI_ENGINE     |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_BF |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
|--------|---|-----------------------|----|----|----|----|----|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|
| BITS   |   | 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 |  |  |  |  |  |  |  |  |  |  |
|        |   | n                     | m  | l  | k  | j  | i  | h  |    | g                                                                                                                                                                                                                                                  |    | f  | e  | d  |    | c  |    | b  | a  |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| f      | W | SET_SRC_OFFPITCH_COPY |    |    |    |    |    |    |    | 0 = SRC_OFF_PITCH set to 0<br>1 = SRC_OFF_PITCH set to DST_OFF_PITCH                                                                                                                                                                               |    |    |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| g      | W | SET_SRC_HGTWID1_2     |    |    |    |    |    |    |    | 0 = Height = 8, width = 8<br>1 = Height = 1, width = 32<br>2 = Height = 8, width = 24<br>3 = Reserved                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| h      | W | SET_DRAWING_COMBO     |    |    |    |    |    |    |    | See DRAWING_COMBO table below                                                                                                                                                                                                                      |    |    |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| i      | W | SET_BUS_MASTER_OP     |    |    |    |    |    |    |    | GUI operation performed by the bus master<br>0 = Frame buffer to system memory operation<br>1 = System memory to frame buffer operation<br>2 = Foreground register to system memory operation<br>3 = System memory to host data register operation |    |    |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| j      | W | SET_BUS_MASTER_EN     |    |    |    |    |    |    |    | Enable bus mastering for any subsequent GUI operations                                                                                                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| k      | W | SET_BUS_MASTER_SYNC   |    |    |    |    |    |    |    | Synchronize GUI operations to bus master<br>No operations permitted until both GUI and bus master are complete                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| l      | W | DP_HOST_TRIPLE_EN     |    |    |    |    |    |    |    | Enable triplication of monochrome host data                                                                                                                                                                                                        |    |    |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| m      | W | FAST_FILL_EN          |    |    |    |    |    |    |    | Fast filling for transparent DST<br>Not needed if auto-fast-fills are enabled (see HW_DEBUG)<br>Write as '0'                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| n      | W | BLOCK_WRITE_EN        |    |    |    |    |    |    |    | Enable block write blit using SGRAM color register<br>Not needed if auto-block-writes are enabled (see HW_DEBUG)<br>Write as '0'                                                                                                                   |    |    |    |    |    |    |    |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |

### Usage

Writing this register will set the following registers to the known values indicated, in addition to the registers set by the bit fields:

**Table 5-11 Registers Set by DP\_SET\_GUI\_ENGINE**

| Register         | Value                       |
|------------------|-----------------------------|
| DST_Y_X          | 0                           |
| DST_HEIGHT_WIDTH | 0                           |
| SRC_Y_X          | 0                           |
| SC_TOP_BOTTOM    | 3FFF0000h = OPEN completely |

**Table 5-11 Registers Set by DP\_SET\_GUI\_ENGINE**

| <b>Register</b>                     | <b>Value</b>                             |
|-------------------------------------|------------------------------------------|
| SC_LEFT_RIGHT                       | 1FFF0000h = OPEN completely              |
| DP_WRITE_MSK                        | FFFFFFFh = enable all destination writes |
| DP_HOST_PIX_WIDTH@DP_PIX_WIDTH      | 0                                        |
| DP_BYTE_PIX_ORDER@DP_PIX_WIDTH      | 0                                        |
| SRC_8x8x8_BRUSH@SRC_CNTL            | 0                                        |
| SRC_8x8x8_BRUSH_LOADED@SRC_CNTL     | 0                                        |
| CLR_CMP_CNTL                        | 0                                        |
| SRC_X_START                         | 0                                        |
| DP_SRC_AUTONA_FIX_DIS@DP_PIX_WIDTH  | 0                                        |
| DP_FAST_SRCCOPY_DIS@DP_PIX_WIDTH    | 0                                        |
| DP_CI4_RGB_INDEX@DP_PIX_WIDTH       | 0                                        |
| DP_CONVERSION_TEMP@DP_PIX_WIDTH     | 0                                        |
| DP_CI4_RGB_LOW_NIBBLE@DP_PIX_WIDTH  | 0                                        |
| DP_CI4_RGB_HIGH_NIBBLE@DP_PIX_WIDTH | 0                                        |
| DP_SCALE_PIX_WIDTH@DP_PIX_WIDTH     | 0                                        |
| DP_COMPOSITE_PIX_WIDTH@DP_PIX_WIDTH | 0                                        |
| SRC_Y_START                         | 0                                        |
| COLOR_REG_WRITE_EN@SRC_CNTL         | 0                                        |
| BLOCK_WRITE_EN@SRC_CNTL             | 0                                        |
| TRAIL_X_DIR@DST_CNTL                | 0                                        |
| TRAIL_FILL_DIR@DST_CNTL             | 0                                        |
| TRAIL_BRES_SIGN@DST_CNTL            | 0                                        |

**Table 5-12 DRAWING\_COMBO Table**

|      | <b>DP_SRC</b>                            | <b>DP_MI_X</b> | <b>GUI_TRAJ_CNTL</b>                                       | <b>Used in</b>                                                     |
|------|------------------------------------------|----------------|------------------------------------------------------------|--------------------------------------------------------------------|
| 0000 | XXXXXXXX                                 | XXXXXX<br>XXX  | XXXXXXXX                                                   | state is unknown and undefined                                     |
| 0001 | 0000100h<br>(FgFrgdClr)                  | 070003h        | 00000023h<br>DstXDir+DstYDir+<br>DstLastPel                | DefaultContext<br>(Default Screen Blit)                            |
| 0010 | 0000200h<br>(FgHost)                     | 070007h        | 00000003h<br>DstXDir+DstYDir                               | BltSCol2DScr via<br>HOST_DATA (GWM3).                              |
| 0011 | 0020100h<br>(MonoHost+FgFrgdClr )        | 070007h        | 00000003h<br>DstXDir + DstYDir                             | BltSMonl2DScr via<br>HOST_DATA (GWM4).                             |
| 0100 | 0000100h<br>(FgFrgdClr)                  | 070007h        | 00000023h<br>DstXDir+DstYDir+<br>DstLastPel                | SolPat2DstScr<br>PATCOPY (GWM1)                                    |
| 0101 | 0010100h<br>(MonoPattRegs+<br>FgFrgdClr) | 070007h        | 01000003h<br>DstXDir+DstYDir+<br>PatMonoEnable             | BltHatPat2DstScr<br>MonoPATCOPY                                    |
| 0110 | 0000100h (FgFrgdClr)                     | 070007h        | 00000003<br>DstXDir+DstYDir                                | patCopy and srcCopy for<br>solid ROPs for Apple                    |
| 0111 | 0000300h (FgBlit)                        | 070007h        | 00030003<br>DstXDir+DstYDir+S<br>rcPattEn+SrcPattRot<br>En | patCopy and srcCopy for<br>pattern ROPs for Apple                  |
| 1000 | 0000300h<br>(FgBlit)                     | 070007h        | 00000000h                                                  | DefaultContext<br>+ S to S SRCCOPY                                 |
| 1001 | 0000300h<br>(FgBlit)                     | 070007h        | 00000001h                                                  | DefaultContext<br>+ S to S SRCCOPY                                 |
| 1010 | 0000300h<br>(FgBlit)                     | 070007h        | 00000002h                                                  | DefaultContext<br>+ S to S SRCCOPY                                 |
| 1011 | 0000300h<br>(FgBlit)                     | 070007h        | 00000003h                                                  | DefaultContext<br>+ S to S SRCCOPY<br>+ CacToS SRCCOPY<br>(GWM3,5) |

**Table 5-12 DRAWING\_COMBO Table**

|      | DP_SRC                          | DP_MI_X | GUI_TRAJ_CNTL                                                                                | Used in                                    |
|------|---------------------------------|---------|----------------------------------------------------------------------------------------------|--------------------------------------------|
| 1100 | 0020100h<br>(FgFrgdClr+MonoHst) | 070003h | 1004001Bh<br>(HostByteAlign+<br>SrcLinearEnable+<br>DstXDir + DstYDir+<br>DstXTile+DstYTile) | MonoContext :<br>(Default MonoExpand Blit) |
| 1101 | 0020100h<br>(FgFrgdClr+MonoHst) | 070003h | 0004001Bh<br>(SrcLinearEnable+<br>DstXDir + DstYDir<br>+<br>DstXTile +<br>DstYTile)          | MonoContext :<br>(Text Blit)               |
| 1111 | 0000300h (FgBlit)               | 070007h | 0004001Bh<br>(SrcLinearEnable +<br>DstXDir + DstYDir<br>+<br>DstXTile +<br>DstYTile)         | Src_8x8x8_Brush, polygon<br>fill, pat-copy |

|      |     | DP_SET_GUI_ENGINE2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |    |    |    |    | MM: 0_BE |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|----|----|----|----|----------|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | p                  | o  | n  | m  | l  | k  | j  | i  | h  | g  | f  | e  | d  | c  |    | b                   |    | a  |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | DP_BKGD_MIX        |    |    |    |    |    |    |    |    |    |    |    |    |    |    | as in DP_MIX        |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| b    | R/W | DP_FRGD_MIX        |    |    |    |    |    |    |    |    |    |    |    |    |    |    | as in DP_MIX        |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| c    | R/W | DP_BKGD_SRC        |    |    |    |    |    |    |    |    |    |    |    |    |    |    | as in DP_SRC        |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| d    | R/W | DP_FRGD_SRC        |    |    |    |    |    |    |    |    |    |    |    |    |    |    | as in DP_SRC        |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| e    | R/W | DP_MONO_SRC        |    |    |    |    |    |    |    |    |    |    |    |    |    |    | as in DP_SRC        |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| f    | R/W | DST_X_DIR          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | as in GUI_TRAJ_CNTL |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| g    | R/W | DST_Y_DIR          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | as in GUI_TRAJ_CNTL |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| h    | R/W | PAT_MONO_EN        |    |    |    |    |    |    |    |    |    |    |    |    |    |    | as in GUI_TRAJ_CNTL |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| i    | R/W | SRC_PATT_ROT_EN    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | as in GUI_TRAJ_CNTL |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| j    | R/W | FAST_FILL_EN       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | as in SRC_CNTL      |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |
| k    | R/W | BLOCK_WRITE_EN     |    |    |    |    |    |    |    |    |    |    |    |    |    |    | as in SRC_CNTL      |    |    |    |    |          |    |   |   |   |   |   |   |   |   |   |   |

| Cont'd |     | DP_SET_GUI_ENGINE2    |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_BE |    |    |    |                                                               |    |   |   |   |   |   |   |   |   |
|--------|-----|-----------------------|--|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|---------------------------------------------------------------|----|---|---|---|---|---|---|---|---|
|        |     | BITS                  |  | 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 |
|        |     | p                     |  | o  |    | n  |    | m  |    | l  | k  | j  | i  | h  | g  | f  | e  |    | d  | c        |    | b  |    | a                                                             |    |   |   |   |   |   |   |   |   |
| 1      | R/W | SET_DP_WRITE_MASK     |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    | Set DP_WRITE_MASK<br>0 = leave alone<br>1 = set to 0xFFFFFFFF |    |   |   |   |   |   |   |   |   |
| m      | R/W | DST_PIX_WIDTH         |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    | as in DP_PIX_WIDTH/DP_SET_GUI_ENGINE                          |    |   |   |   |   |   |   |   |   |
| n      | R/W | SET_SRC_PIX_WIDTH     |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    | as in DP_SET_GUI_ENGINE                                       |    |   |   |   |   |   |   |   |   |
| o      | R/W | SET_DST_PITCH         |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    | as in DP_SET_GUI_ENGINE                                       |    |   |   |   |   |   |   |   |   |
| p      | R/W | SRC_OFFSET_PITCH_COPY |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    | as in DP_SET_GUI_ENGINE                                       |    |   |   |   |   |   |   |   |   |

### Usage

Writing this register will set the following registers to the following known values in addition to the registers set by the bit fields:

|                                |  | Register | Value |
|--------------------------------|--|----------|-------|
| DST_Y_X                        |  |          | 0     |
| DST_HEIGHT_WIDTH               |  |          | 0     |
| SRC_Y_X                        |  |          | 0     |
| DP_HOST_PIX_WIDTH@DP_PIX_WIDTH |  |          | 0     |
| DP_BYTE_PIX_ORDER@DP_PIX_WIDTH |  |          | 0     |
| CLR_CMP_CNTL                   |  |          | 0     |

|      |     | DP_SRC      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_B6 |    |    |    |                                                                                                                                                                                                       |   |   |   |   |   |   |   |   |   |   |
|------|-----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |   |
|      |     |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | c        |    |    |    |                                                                                                                                                                                                       |   |   | b |   |   |   |   |   |   | a |
| a    | R/W | DP_BKGD_SRC |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    | Background source:<br>000 = Background color<br>001 = Foreground color<br>010 = Host data<br>011 = Blit source<br>100 = Pattern registers<br>101 = Scaler/3D data<br>011 = Reserved<br>111 = Reserved |   |   |   |   |   |   |   |   |   |   |

|      |     | DP_SRC      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                                                                                      |                                                                                           | MM: 0_B6 |   |   |   |  |  |  |  |
|------|-----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|--------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|----------|---|---|---|--|--|--|--|
| BITS |     | 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 |  |  |  |  |
|      |     |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | c  |    |   |   |   | b |                                                                                      |                                                                                           |          |   | a |   |  |  |  |  |
| b    | R/W | DP_FRGD_SRC |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | Foreground source – bit descriptions same as those for DP_BKGD_SRC[2:0], shown above |                                                                                           |          |   |   |   |  |  |  |  |
| c    | R/W | DP_MONO_SRC |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                                                                                      | Monochrome source<br>0 = '1'<br>1 = Pattern registers<br>2 = Host data<br>3 = Blit source |          |   |   |   |  |  |  |  |

### Description

This register controls the mono mux and the two color muxes in the pixel data path.

### Usage

DP\_FRGD\_SRC and DP\_MONO\_SRC are required to be set for all draw operations. DP\_BKGD\_SRC is *don't care* for non-trivial color expansion of monochrome data. A non-trivial monochrome source is anything but *Always\_1*.

### See Also

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Logical Pixel Data Path*

## 5.2.5 Color Compare Registers

The color compare function allows color keying on destination or source color values. Note that the color comparison function is not supported in 1 bpp mode.

When color keying on the texel source, the key is compared against the expanded (24 bit) source. When color keying 8 bit pseudo color sources, the source data is located on the low order 8 bits.

| CLR_CMP_CLR |     |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |   |   |   |   |   |   | MM: 0_C0 |   |   |   |
|-------------|-----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------|----|----|----|----|----|---|---|---|---|---|---|----------|---|---|---|
| BITS        | 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 |
|             | a   |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |   |   |   |   |   |   |          |   |   |   |
| a           | R/W | CLR_CMP_CLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Color comparison color |    |    |    |    |    |   |   |   |   |   |   |          |   |   |   |

### Description

This register is compared against the source or destination data to determine whether the source data will overwrite the destination data.

### Usage

Use this register only when CLR\_CMP\_FN@CLR\_CMP\_CNTL is set to a non-trivial compare function.

### See Also

CLR\_CMP\_CNTL on [page 5-61](#)

CLR\_CMP\_MSK on [page 5-60](#)

*mach64* Programmer's Guide:

- *Engine Operations: Draw Operations: Specialized BitBlt Source: Transparent BitBlts*

| CLR_CMP_MSK |     |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |    |    |    |    |   |   |   |   |   |   | MM: 0_C1 |   |   |   |
|-------------|-----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|----|----|----|----|----|---|---|---|---|---|---|----------|---|---|---|
| BITS        | 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 |
|             | a   |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |    |    |    |    |   |   |   |   |   |   |          |   |   |   |
| a           | R/W | CLR_CMP_MSK |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Color comparison mask |    |    |    |    |    |   |   |   |   |   |   |          |   |   |   |

### Description

This register is used in conjunction with CLR\_CMP\_FN. Both CLR\_CMP\_CLR and the source/destination data are masked by the color comparison mask.

### Usage

Use this register only when CLR\_CMP\_FN@CLR\_CMP\_CNTL is set to a non-trivial compare function.

### See Also

CLR\_CMP\_CLR on [page 5-60](#)

CLR\_CMP\_CNTL on [page 5-61](#)

*mach64* Programmer's Guide:

- *Engine Operations: Draw Operations: Specialized BitBlt Source: Transparent BitBlts*

|      |     |             | CLR_CMP_CNTL |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                               |    |    |    |    |    |    |    |    |    |    |   |   |   | MM: 0_C2 |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
|------|-----|-------------|--------------|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---|---|---|----------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|
| BITS |     |             | 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 |  |  |  |  |  |  |  |  |  |
|      |     |             | b            |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                               | a  |    |    |    |    |    |    |    |    |    |   |   |   |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| a    | R/W | CLR_CMP_FCN |              |    |    |    |    |    |    |    |    |    |    | Color comparison function<br>000 = False<br>001 = True<br>010 = Reserved<br>011 = Reserved<br>100 = DST_CLR != CLR_CMP_CLR<br>101 = DST_CLR = CLR_CMP_CLR<br>110 = Reserved<br>111 = Reserved |    |    |    |    |    |    |    |    |    |    |   |   |   |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| b    | R/W | CLR_CMP_SRC |              |    |    |    |    |    |    |    |    |    |    | Defines source for color keying<br>00 = Destination<br>01 = 2D Source<br>10 = Texel Source/Scaler Source<br>11 = Reserved                                                                     |    |    |    |    |    |    |    |    |    |    |   |   |   |          |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |

### Description

This register configures the source or destination compare logic.

CLR\_CMP\_SRC determines whether the CLR\_CMP\_CLR register is to be compared against the source or the destination data. When CLR\_CMP\_SRC is ‘1’, Auto Fastfill must be disabled.

CLR\_CMP\_FN determines the compare function. If the result of the comparison is false, the color source data is written to the destination; otherwise destination data is written to the destination.

Setting CLR\_CMP\_FN to any function other than FALSE or TRUE when CLR\_CMP\_SRC is set for destination keying will automatically cause the destination operation to be read-modify-write.

### Usage

Use this register for selectively inhibiting the drawing of certain pixels which key on the source data or destination data.

### See Also

CLR\_CMP\_CLR on [page 5-60](#)

CLR\_CMP\_MSK on [page 5-60](#)

*mach64* Programmer's Guide:

- *Engine Operations: Background Information: Logical Pixel Data Path*
- *Engine Operations: Draw Operations: Specialized BitBlt Source: Transparent BitBlts*

## 5.2.6 Command FIFO Registers

The command FIFO is ‘n’ words deep by 32 bits, where n > 16.

For the RAGE XL, n = 64, 256, or 512 as determined by

CMD\_FIFO\_SIZE\_MODE@GUI\_CNTL.

|      |   | FIFO_STAT |    |    |    |    |    |    |    |    |    |                                                                                                                 |    |    |    |    |    | MM: 0_C4 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|---|-----------|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS |   | 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 |
| a    |   |           |    |    |    |    |    |    |    |    |    |                                                                                                                 |    |    |    |    |    | a        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a    | R | FIFO_STAT |    |    |    |    |    |    |    |    |    | Register represents the occupancy of the last 16 entries in the FIFO, regardless of the actual total FIFO depth |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Description

Reading FIFO\_STAT returns the status of the command FIFO. Any occurrence of a ‘1’ in the FIFO\_STAT field indicates that the corresponding FIFO entry is filled.

Writing to the command FIFO when insufficient entries are available will cause the FIFO\_ERR bit to go high and lock the draw engine. This circumstance should never occur. An interrupt may be wired to the FIFO\_ERR bit for debugging purposes through

BUS\_CNTL. The draw engine may reset the error condition through GEN\_TEST\_CNTL.

Only registers with DWORD indices greater than or equal to 0x40 go through the command FIFO. All other registers bypass the FIFO.

### Usage

Each grouping of register writes through the command FIFO must be preceded by a FIFO check to ensure that sufficient entries are available.

### See Also

[BUS\\_CNTL](#) on [page 4-5](#)

[GEN\\_TEST\\_CNTL](#) on [page 4-24](#)

*mach64* Programmer's Guide:

- *Engine Initialization: Background Information on the mach64 Engine: FIFO Queue*
- *Engine Operations: Draw Operations*

|      |     | GUI_CMD FIFO DEBUG |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                          |    |    |    |    |    |   |   | MM: 1_5C |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | f                  |    |    |    | e  | d  | c  |    |    |    |    |    |    |    | b  |    |                                                                                          |    |    |    | a  |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | REG_INDEX          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Read: target register for register write                                                 |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | RADR               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Read: read pointer value driven by hardware<br>Write: (SNOOP mode): read pointer to FIFO |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | WADR               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Read: write pointer value driven by hardware                                             |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d    | R/W | REN                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Read: read enable driven by hardware<br>Write: (SNOOP mode): read enable to FIFO         |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| e    | R/W | WEN                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Read: write enable driven by hardware                                                    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| f    | R/W | SNOOP              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SNOOP mode:<br>0 = Disable snoop mode (normal operation)<br>1 = Enable snoop mode        |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |

| GUI_CMD FIFO DATA |   |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                     | MM: 1_5D |  |  |  |  |  |  |  |
|-------------------|---|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------------------------------------------|----------|--|--|--|--|--|--|--|
| BITS              |   | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                     |          |  |  |  |  |  |  |  |
|                   |   | a                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                     |          |  |  |  |  |  |  |  |
| a                 | R | GUI_CMD FIFO DATA                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Value read from FIFO pointed to by the read pointer |          |  |  |  |  |  |  |  |

| GUI_CNTL |     |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | MM: 1_5E         |  |  |  |  |  |  |  |  |  |
|----------|-----|---------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|------------------|--|--|--|--|--|--|--|--|--|
| BITS     |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                  |  |  |  |  |  |  |  |  |  |
|          |     | c b a                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                  |  |  |  |  |  |  |  |  |  |
| a        | R/W | CMDFIFO_SIZE_MODE                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Set CMDFIFO size |  |  |  |  |  |  |  |  |  |
|          |     |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                  |  |  |  |  |  |  |  |  |  |
|          |     |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                  |  |  |  |  |  |  |  |  |  |
|          |     |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                  |  |  |  |  |  |  |  |  |  |
| b        | R/W | IDCT_PRSR_MODE                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                  |  |  |  |  |  |  |  |  |  |
|          |     |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                  |  |  |  |  |  |  |  |  |  |
|          |     |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                  |  |  |  |  |  |  |  |  |  |
| c        | R/W | IDCT_BLOCK_GUI_INITIATOR                                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                  |  |  |  |  |  |  |  |  |  |
|          |     |                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                  |  |  |  |  |  |  |  |  |  |

## 5.2.7 Draw Engine Composite Control Registers

|      |     | GUI_TRAJ_CNTL           |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                           |    |    |    |    |    |    |    |    |    |   |   | MM: 0_CC |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|------|-----|-------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |
|      |     | aa                      | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o                                                                                                                                                                         | n  | m  | l  | k  | j  | i  | h  | g  | f  | e | d | c        | b | a |   |   |   |   |   |  |  |  |  |  |  |  |  |
| a    | R/W | DST_X_DIR               |    |    |    |    |    |    |    |    |    |    |    | Destination X direction<br>0 = Right to left<br>1 = Left to right                                                                                                         |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| b    | R/W | DST_Y_DIR               |    |    |    |    |    |    |    |    |    |    |    | Destination Y direction<br>0 = Bottom to top<br>1 = Top to bottom                                                                                                         |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| c    | R/W | DST_Y_MAJOR             |    |    |    |    |    |    |    |    |    |    |    | Destination Y major axis flag for bresenham lines<br>0 = X major line<br>1 = Y major line                                                                                 |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| d    | R/W | DST_X_TILE              |    |    |    |    |    |    |    |    |    |    |    | Enable rectangular tiling in the X direction                                                                                                                              |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| e    | R/W | DST_Y_TILE              |    |    |    |    |    |    |    |    |    |    |    | Enable rectangular tiling in the Y direction                                                                                                                              |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| f    | R/W | DST_LAST_PEL            |    |    |    |    |    |    |    |    |    |    |    | Destination last pel enable                                                                                                                                               |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| g    | R/W | DST_POLYGON_EN          |    |    |    |    |    |    |    |    |    |    |    | Destination polygon outline and polygon fill enable                                                                                                                       |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| h    | R/W | DST_24_ROT_EN           |    |    |    |    |    |    |    |    |    |    |    | Enable 24 bpp rotation. DSTPIXWIDTH must be set to 8 bpp                                                                                                                  |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| i    | R/W | DST_24_ROT              |    |    |    |    |    |    |    |    |    |    |    | Initial foreground color, background color, write mask, and monochrome pattern rotation when drawing packed 24 bpp                                                        |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| J    | R/W | DST_BRES_ZREO           |    |    |    |    |    |    |    |    |    |    |    | 0 = DEST_BRES_ERR = 0 is defined as a positive number<br>1 = DEST_BRES_ERR = 0 is defined as negative number                                                              |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| k    | R/W | DST_POLYGON RTEEDGE_DIS |    |    |    |    |    |    |    |    |    |    |    | Disable drawing of the right edge pixel of a polygon fill operation<br>0 = Enable drawing of right edge pixel<br>1 = Disable drawing of right edge pixel                  |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| l    | R/W | TRAIL_X_DIR             |    |    |    |    |    |    |    |    |    |    |    | Trapezoid trailing edge direction<br>0 = Right to left<br>1 = Left to right                                                                                               |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| m    | R/W | TRAP_FILL_DIR           |    |    |    |    |    |    |    |    |    |    |    | Trapezoid fill direction<br>0 = Right to left (trailing edge is to the left of the leading edge)<br>1 = Left to right (trailing edge is to the right of the leading edge) |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| n    | R/W | TRAIL_BRES_SIGN         |    |    |    |    |    |    |    |    |    |    |    | Sign of TRAIL_BRES_ERR when TRAIL_BRES_ERR = 0<br>0 = TRAIL_BRES_ERR = 0 is defined as a positive number<br>1 = TRAIL_BRES_ERR = 0 is defined as negative number          |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| o    | R/W | SRC_PATT_EN             |    |    |    |    |    |    |    |    |    |    |    | Enables pattern source<br>SRC_Y_END will only be used if this bit is enabled                                                                                              |    |    |    |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

| Cont'd |     | GUI_TRAJ_CNTL      |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MM: 0_CC                                                                                                                                                                                                                                                                                                                  |    |    |    |   |   |   |   |   |   |   |   |
|--------|-----|--------------------|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|---|---|---|---|---|---|---|---|
|        |     | BITS               |   | 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 |
|        |     | aa                 | z | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  | h  | g                                                                                                                                                                                                                                                                                                                         | f  | e  | d  | c | b | a |   |   |   |   |   |
| p      | R/W | SRC_PATT_ROT_EN    |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable pattern source rotation<br>SRC_X_START, SRC_Y_START will only be used if this bit is enabled                                                                                                                                                                                                                       |    |    |    |   |   |   |   |   |   |   |   |
| q      | R/W | SRC_LINEAR_EN      |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable the source to be advanced linearly in memory<br>The source starts at SRC_OFFSET and advances in the left-to-right direction. DST_X_DIR should also be set to the left-to-right to operate properly<br>Note that all other source registers and control bits with the exception of SRC_BYTE_ALIGN are ignored       |    |    |    |   |   |   |   |   |   |   |   |
| r      | R/W | SRC_BYTE_ALIGN     |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Allows the source to skip to the next data byte boundary when the destination advances in the Y direction<br>SRC_LINEAR_EN must be set                                                                                                                                                                                    |    |    |    |   |   |   |   |   |   |   |   |
| s      | R/W | SRC_LINE_X_DIR     |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Source X direction when drawing operation is a bresenham line                                                                                                                                                                                                                                                             |    |    |    |   |   |   |   |   |   |   |   |
| t      | R/W | SRC_8x8x8_BRUSH    |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Treats source as an 8x8x8 linear brush (SRC must be QWORD aligned)                                                                                                                                                                                                                                                        |    |    |    |   |   |   |   |   |   |   |   |
| u      | R/W | FAST_FILL_EN       |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Fast filling for transparent DST<br>Not needed if auto-fast-fills are enabled (see HW_DEBUG)<br>Write as '0'                                                                                                                                                                                                              |    |    |    |   |   |   |   |   |   |   |   |
| v      | R/W | SRC_TRACK_DST      |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Source will track the trajectory that the DST FIFO is using                                                                                                                                                                                                                                                               |    |    |    |   |   |   |   |   |   |   |   |
| w      | R/W | PAT_MONO_EN        |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable monochrome 8x8 pattern                                                                                                                                                                                                                                                                                             |    |    |    |   |   |   |   |   |   |   |   |
| x      | R/W | PAT_CLR_4x2_EN     |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable color 4x2 pattern                                                                                                                                                                                                                                                                                                  |    |    |    |   |   |   |   |   |   |   |   |
| y      | R/W | PAT_CLR_8x1_EN     |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable color 8x1 pattern                                                                                                                                                                                                                                                                                                  |    |    |    |   |   |   |   |   |   |   |   |
| z      | R/W | HOST_BYTE_ALIGN    |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable byte alignment of the host data                                                                                                                                                                                                                                                                                    |    |    |    |   |   |   |   |   |   |   |   |
| aa     | R/W | HOST_BIG_ENDIAN_EN |   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable big endian data translation for 15 bpp, 16 bpp, and 32 bpp pixel widths.<br>In 15 bpp and 16 bpp modes, the bytes within each word are swapped.<br>In 32 bpp mode, the order of the four bytes within each DWORD is reversed.<br>0 = Disable big endian data translation<br>1 = Enable big endian data translation |    |    |    |   |   |   |   |   |   |   |   |

### Description

This register is a composite of registers DST\_CNTL, SRC\_CNTL, PAT\_CNTL, and HOST\_CNTL.

### Usage

Use this register for general draw operations.

*See Also*

- DST\_CNTL on [\*page 5-5\*](#)
- SRC\_CNTL on [\*page 5-21\*](#)
- PAT\_CNTL on [\*page 5-37\*](#)
- HOST\_CNTL on [\*page 5-33\*](#)

## 5.2.8 Draw Engine Status Registers

|      |   | GUI_STAT               |    |    |    |    |    |    |    |                                                                                                                             |    |    |    |    |    |    |    | MM: 0_CE |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|------|---|------------------------|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| BITS |   | 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 |  |  |  |  |
|      |   | f                      |    |    |    |    |    |    |    | e d c b                                                                                                                     |    |    |    |    |    |    |    | a        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| a    | R | GUI_ACTIVE             |    |    |    |    |    |    |    | Indicates that the GUI engine is busy                                                                                       |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| b    | R | DSTX_LT_SCISSOR_LEFT   |    |    |    |    |    |    |    | Indicates DST_X is left of left scissor                                                                                     |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| c    | R | DSTX_GT_SCISSOR_RIGHT  |    |    |    |    |    |    |    | Indicates DST_X is right of right scissor                                                                                   |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| d    | R | DSTY_LT_SCISSOR_TOP    |    |    |    |    |    |    |    | Indicates DST_Y is above top scissor                                                                                        |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| e    | R | DSTY_GT_SCISSOR_BOTTOM |    |    |    |    |    |    |    | Indicates DST_Y is below bottom scissor                                                                                     |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| f    | R | GUI_FIFO               |    |    |    |    |    |    |    | Indicates the number of free DWORDS remaining in the FIFO. (the default value is determined by CMD FIFO_SIZE_MODE@GUI_CNTL) |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

### Description

This register reports the status of the draw engine.

### Usage

The GUI\_ACTIVE bit determines whether the draw engine is busy or idle. All status bits in this register should be read-only when the draw engine is idle.

### See Also

FIFO\_STAT on [page 5-62](#)

*mach64* Programmer's Guide:

- *Engine Initialization: Background Information on the mach64 Engine: FIFO Queue*

# Chapter 6

## Host Interface

### 6.1 PCI Configuration Space Registers

The RAGE XL is optimized to support the PCI local bus and to implement the PCI Configuration Space registers. A brief description of the registers with their byte addresses is given below (for detailed descriptions please refer to the *PCI Local Bus Specification*).

PCI configuration reads and writes may be in 8, 16, or 32 bits. A 32-bit read of byte address 0, for example, would read the four bytes 0 to 3.

| DEVICE ID<br>BGA (RAGE XL)<br>PKG BGAb = 0 | Description               |
|--------------------------------------------|---------------------------|
| GR (4752h)                                 | PCI 33MHz, 3.3V Signaling |
| GR (4752h)                                 | PCI 33MHz, 5V Signaling   |
| GO (474Fh)                                 | PCI 66MHz                 |
| GM (474Dh)                                 | AGP 1X, 2X                |

| VENDOR_ID |   |                                                                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Byte Addr: 1:0 |  |
|-----------|---|------------------------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------------|--|
| BITS      |   | 15                                                               | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0              |  |
| a         |   |                                                                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   | a              |  |
| a         | R | Power-up default = 1002h<br>This is ATI's assigned PCI vendor ID |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                |  |

| DEVICE_ID |   |                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Byte Addr: 3:2 |  |
|-----------|---|------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------------|--|
| BITS      |   | 15               | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0              |  |
| a         |   |                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   | a              |  |
| a         | R | Power-up default |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                |  |

**Usage**

Refer to Table 8-1.

The actual value is dependent on PCI33EN pin, and straps BUS\_TYPE (MA6), and CHANGE\_ID (MA0) on power up (refer to page 15 of XL Pinout Specification).

| COMMAND |     |                                                            |    |    |    |    |    |   |   |   |   |   |   |   |   | Byte Addr: 5:4 |   |   |   |
|---------|-----|------------------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|----------------|---|---|---|
| BITS    |     | 15                                                         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1              | 0 |   |   |
|         |     |                                                            |    |    |    |    |    |   |   |   |   |   |   |   |   | i              | h | g | f |
| a       | R/W | I/O Access Enable: (defaults to '0', disabled)             |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |   |   |
| b       | R/W | Memory Access Enable: (defaults to '0', disabled)          |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |   |   |
| c       | R/W | Bus Master Enable: (defaults to '0', disabled)             |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |   |   |
| d       | R   | Special Cycles Enable: (always '0', disabled)              |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |   |   |
| e       | R   | Memory Write and Invalidate Enable: (always '0', disabled) |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |   |   |
| f       | R/W | VGA Palette Snooping Enable: (defaults to '0', disabled)   |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |   |   |
| g       | R   | Parity Error Response: (always '0', disabled)              |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |   |   |
| h       | R   | Read Wait Cycle Control: (always '1')                      |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |   |   |
| i       | R   | SERR# Enable: (always '0', disabled)                       |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |   |   |

| STATUS |     |                                                                                   |    |    |    |    |    |   |   |   |   |   |   |   |   | Byte Addr: 7:6 |   |  |  |
|--------|-----|-----------------------------------------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|----------------|---|--|--|
| BITS   |     | 15                                                                                | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1              | 0 |  |  |
|        |     | h                                                                                 | g  | f  | e  | d  | c  |   | b |   | a |   |   |   |   |                |   |  |  |
| a      | R   | Capability List: (always "1", indicates device implements a list of capabilities) |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |  |  |
| b      | -   | Fast Back-to-Back Capable: (always '1')                                           |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |  |  |
| c      | R   | DEVSEL Timing: (defaults to '1', medium)                                          |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |  |  |
| d      | R   | Signaled Target Abort: (defaults to '0', no Target Abort)                         |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |  |  |
| e      | R/W | Received Target Abort: (defaults to '0', inactive)                                |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |  |  |
| f      | R/W | Received Master Abort: (defaults to '0', inactive)                                |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |  |  |
| g      | R   | Signaled System Error: (always '0', inactive)                                     |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |  |  |
| h      | R   | Detected Parity Error: (always '0', inactive)                                     |    |    |    |    |    |   |   |   |   |   |   |   |   |                |   |  |  |

|      |   | <b>ASIC_ID</b>                                          |   |   |   |   |   |   |   | <b>Byte Addr: 08</b> |  |  |  |  |
|------|---|---------------------------------------------------------|---|---|---|---|---|---|---|----------------------|--|--|--|--|
| BITS |   | 7                                                       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                      |  |  |  |  |
|      |   | c                                                       | b |   |   |   | a |   |   |                      |  |  |  |  |
| a    | R | Major ASIC version number: (A=0)*                       |   |   |   |   |   |   |   |                      |  |  |  |  |
| b    | R | ASIC foundry ID: (000=SGS, 001=NEC, 011=UMC, 100=TSMC)* |   |   |   |   |   |   |   |                      |  |  |  |  |
| c    | R | Minor ASIC revision number*                             |   |   |   |   |   |   |   |                      |  |  |  |  |

\*Refer to the ASIC ID table below for default values.

### Usage

The 8 bits at PCI address 8h are also known as the ASIC ID. The ASIC ID also appears in the CONFIG\_CHIP\_ID non-GUI register. The following are the ASIC ID's used to date:

**Table 6-1 ASIC IDs**

| <b>ASIC ID</b> | <b>Description</b> |
|----------------|--------------------|
| 24h            | TSMC B11           |
| 25h/65h        | TSMC B21/B22       |
| 26h            | B31                |
| 27h            | B41                |

|      |   | <b>REGISTER_LEVEL_PROGRAMMING_INTERFACE</b> |   |   |   |   |   |   |   | <b>Byte Addr: 09</b> |
|------|---|---------------------------------------------|---|---|---|---|---|---|---|----------------------|
| BITS |   | 7                                           | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                      |
|      |   | a                                           |   |   |   |   |   |   |   |                      |
| a    | R | Power-up default = 00h                      |   |   |   |   |   |   |   |                      |

| SUB_CLASS_CODE |   |                                                               |   |   |   |   |   | Byte Addr: 0A |   |
|----------------|---|---------------------------------------------------------------|---|---|---|---|---|---------------|---|
| BITS           |   | 7                                                             | 6 | 5 | 4 | 3 | 2 | 1             | 0 |
| a              |   |                                                               |   |   |   |   |   |               |   |
| a              | R | Strap setting<br>00h = VGA-compatible<br>80h = non-VGA device |   |   |   |   |   |               |   |

| BASE_CLASS_CODE |   |                                            |   |   |   |   |   | Byte Addr: 0B |   |
|-----------------|---|--------------------------------------------|---|---|---|---|---|---------------|---|
| BITS            |   | 7                                          | 6 | 5 | 4 | 3 | 2 | 1             | 0 |
| a               |   |                                            |   |   |   |   |   |               |   |
| a               | R | Power-up default = 03h, Display Controller |   |   |   |   |   |               |   |

| CACHE_LINE_SIZE |     |                        |   |   |   |   |   | Byte Addr: 0C |   |
|-----------------|-----|------------------------|---|---|---|---|---|---------------|---|
| BITS            |     | 7                      | 6 | 5 | 4 | 3 | 2 | 1             | 0 |
| a               |     |                        |   |   |   |   |   |               |   |
| a               | R/W | Power-up default = 00h |   |   |   |   |   |               |   |

| LATENCY_TIMER |     |                        |   |   |   |   |   | Byte Addr: 0D |   |
|---------------|-----|------------------------|---|---|---|---|---|---------------|---|
| BITS          |     | 7                      | 6 | 5 | 4 | 3 | 2 | 1             | 0 |
| a             |     |                        |   |   |   |   |   |               |   |
| a             | R/W | Power-up default = 00h |   |   |   |   |   |               |   |

| HEADER_TYPE |   |                        |   |   |   |   |   | Byte Addr: 0E |   |
|-------------|---|------------------------|---|---|---|---|---|---------------|---|
| BITS        |   | 7                      | 6 | 5 | 4 | 3 | 2 | 1             | 0 |
| a           |   |                        |   |   |   |   |   |               |   |
| a           | R | Power-up default = 00h |   |   |   |   |   |               |   |

| <b>BIST</b> |   |                                  |   |   |   |   |   | Byte Addr: 0F |   |  |  |  |  |  |  |
|-------------|---|----------------------------------|---|---|---|---|---|---------------|---|--|--|--|--|--|--|
| BITS        |   | 7                                | 6 | 5 | 4 | 3 | 2 | 1             | 0 |  |  |  |  |  |  |
|             |   | a                                |   |   |   |   |   |               |   |  |  |  |  |  |  |
| a           | R | Power-up default = 00h, not used |   |   |   |   |   |               |   |  |  |  |  |  |  |

| <b>MEMORY_APERTURE_BASE_ADDRESS</b> |     |                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    | Byte Addr: 13:10 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------------------|-----|--------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS                                |     | 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 |
|                                     |     | d                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    | c                |    |    |    |    |    |    |    |   |   |   |   |   |   | b | a |   |   |
| a                                   | R   | Reserved. Power-up default = 0h                        |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b                                   | R/W | Memory Prefetch Enable: (default to 0h, strap setting) |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| c                                   | R   | Reserved. Power-up default = 00000h                    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| d                                   | R/W | Memory aperture base address                           |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>BLOCK_DECODED_I/O_BASE</b> |     |                           |    |    |    |    |    |    |    |    |    |    |    |    |    | Byte Addr: 17:14 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------------|-----|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS                          |     | 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 |
|                               |     | b                         |    |    |    |    |    |    |    |    |    |    |    |    |    |                  | a  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a                             | R   | Always 01h                |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b                             | R/W | Block Decoded I/O Address |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>REGISTE_APERTURE_BASE_ADDRESS</b> |     |                                |    |    |    |    |    |    |    |    |    |    |    |    |    | Byte Addr: 1B:18 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------------------------------|-----|--------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS                                 |     | 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 |
|                                      |     | b                              |    |    |    |    |    |    |    |    |    |    |    |    |    |                  | a  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a                                    | R   | Always 000h                    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b                                    | R/W | Register Aperture Base Address |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|      |   |                              | <b>ADAPTER_ID</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Byte Addr: 2F:2C |   |   |   |   |   |   |  |
|------|---|------------------------------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------------------|---|---|---|---|---|---|--|
| BITS |   | 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 |  |
|      |   | a                            |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                  |   |   |   |   |   |   |  |
| a    | R | Power-up default = 69871002h |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                  |   |   |   |   |   |   |  |

|      |     |                                            | <b>BIOS_ROM_ENABLE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | Byte Addr: 33:30 |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|--------------------------------------------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|------------------|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | d                                          |                        |    |    |    |    |    |    |    |    |    |    | c  |    |    |    |    |    |    |    | b  |    |   |   | a |   |                  |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | BIOS ROM Enable: (defaults to 0)           |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                  |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R   | Reserved: (always 00h)                     |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                  |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R   | Reserved: (always 00h)                     |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                  |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d    | R/W | BIOS ROM Base Address: (defaults to 0000h) |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                  |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|      |   |                                     | <b>POINTER_TO_CAPABILITY</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Byte Addr: 37:34 |   |   |   |   |   |   |  |
|------|---|-------------------------------------|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------------------|---|---|---|---|---|---|--|
| BITS |   | 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 |  |
|      |   |                                     |                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | a                |   |   |   |   |   |   |  |
| a    | R | Pointer to capability: (always 50h) |                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                  |   |   |   |   |   |   |  |

|      |     |                        | <b>INTERRUPT_LINE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | Byte Addr: 3C |   |   |   |   |   |  |  |
|------|-----|------------------------|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---------------|---|---|---|---|---|--|--|
| BITS |     | 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 |  |  |
|      |     |                        |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | a             |   |   |   |   |   |  |  |
| a    | R/W | Power-up default = 00h |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |               |   |   |   |   |   |  |  |

| INTERRUPT_PIN |   |                                                                             |  |  |  |  |  |  | Byte Addr: 3D |
|---------------|---|-----------------------------------------------------------------------------|--|--|--|--|--|--|---------------|
|               |   |                                                                             |  |  |  |  |  |  | a             |
| a             | R | Power-up default = 01h (00h = no default if interrupt is disabled by strap) |  |  |  |  |  |  |               |

| MINIMUM_GRANT |   |                        |  |  |  |  |  |  | Byte Addr: 3E   |
|---------------|---|------------------------|--|--|--|--|--|--|-----------------|
| BITS          |   |                        |  |  |  |  |  |  | 7 6 5 4 3 2 1 0 |
|               |   |                        |  |  |  |  |  |  | a               |
| a             | R | Power-up default = 08h |  |  |  |  |  |  |                 |

| MAXIMUM_LATENCY |   |                        |  |  |  |  |  |  | Byte Addr: 3F   |
|-----------------|---|------------------------|--|--|--|--|--|--|-----------------|
| BITS            |   |                        |  |  |  |  |  |  | 7 6 5 4 3 2 1 0 |
|                 |   |                        |  |  |  |  |  |  | a               |
| a               | R | Power-up default = 00h |  |  |  |  |  |  |                 |

| USER_DEFINED_CONFIGURATION |     |                                                                                                                                                                                                             |  |  |  |  |  |  | Byte Addr: 40   |
|----------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|-----------------|
| BITS                       |     |                                                                                                                                                                                                             |  |  |  |  |  |  | 7 6 5 4 3 2 1 0 |
|                            |     |                                                                                                                                                                                                             |  |  |  |  |  |  | .a              |
| a                          | R/W | Disable decoding of GENENA VGA register at I/O address 46E8h<br>0 = Decode 46E8h<br>1 = Disable decode of 46E8h<br>Power-up default = 1h<br>Note: These bits are set by straps on non-shared configurations |  |  |  |  |  |  |                 |

| ADAPTER_ID_W |   |                              |  |  |  |  |  |  | Byte Addr: 4F:4C                                                                      |
|--------------|---|------------------------------|--|--|--|--|--|--|---------------------------------------------------------------------------------------|
| BITS         |   |                              |  |  |  |  |  |  | 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 |
|              |   |                              |  |  |  |  |  |  | a                                                                                     |
| a            | W | Power-up default = 69871002h |  |  |  |  |  |  |                                                                                       |

|      |   | AGP_CAPABILITY                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Byte Addr: 53:50 |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|---|------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |   | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |   | d                                                                                  |    |    |    |    |    |    |    |    |    |    |    | c  |    |    |    | b  |    |    |    |    |    |   |   | a                |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R | Cap ID (always = 02h, indicating that this list item is for AGP registers)         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R | Next Ptr (pointer to next capability): (always = 5Ch, Power Management Capability) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R | AGP MINOR: (always = 0h)                                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d    | R | AGP MAJOR: (always = 1h, this chip conforms to AGP spec 1.0)                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|      |   | RATE_SBA                                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Byte Addr: 57:54 |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|---|----------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------------------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |   | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |   | c                                                                                |    |    |    |    |    |    |    |    |    |    |    | b  |    |    |    |    |    |    |    |    |    |   |   | a |                  |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R | Rate: (always = 3h, indicates data transfer rate supported <Bit 0:1X, Bit 1:2X>) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                  |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R | SBA (Side Band Address) support: (always = 1h)                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                  |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R | The maximum number of AGP commands this device can manage (always = FFh)         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                  |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|      |     | DATA_RATE                                                                                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | Byte Addr: 5B:58 |   |   |   |   |   |  |  |   |  |  |  |  |  |  |  |  |  |  |
|------|-----|------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|------------------|---|---|---|---|---|--|--|---|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |   |  |  |  |  |  |  |  |  |  |  |
|      |     | f                                                                                                                            |    |    |    |    |    |    |    |    |    |    |    | e  |    |    |    |    |    |    |    |    |    |   |   | d | c | b                |   |   |   |   |   |  |  | a |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | Data rate: (defaults to 0h after reset)<br>Indicates enabled transfer rate, bit [0:1X], bit [1:2X]<br>Only one bit may be on |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                  |   |   |   |   |   |  |  |   |  |  |  |  |  |  |  |  |  |  |
| b    | R   | Reserved: (always = 0h)                                                                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                  |   |   |   |   |   |  |  |   |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | Enable AGP: (defaults to 0h after reset)                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                  |   |   |   |   |   |  |  |   |  |  |  |  |  |  |  |  |  |  |
| d    | R/W | Enable Side Band Addressing: (defaults to 0h after reset)                                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                  |   |   |   |   |   |  |  |   |  |  |  |  |  |  |  |  |  |  |
| e    | R   | Reserved: (always 0h)                                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                  |   |   |   |   |   |  |  |   |  |  |  |  |  |  |  |  |  |  |
| f    | R/W | Number of requests the device is allowed to enqueue: (defaults to 0h after reset)                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |                  |   |   |   |   |   |  |  |   |  |  |  |  |  |  |  |  |  |  |

| POWER_MANAGEMENT_CAPABILITY_ID |   |                       |   |   |   |   |   | Byte Addr: 5C |   |
|--------------------------------|---|-----------------------|---|---|---|---|---|---------------|---|
| BITS                           |   | 7                     | 6 | 5 | 4 | 3 | 2 | 1             | 0 |
| a                              |   |                       |   |   |   |   |   |               |   |
| a                              | R | Power-up default = 1h |   |   |   |   |   |               |   |

| NEXT_POINTER |   |                       |   |   |   |   |   | Byte Addr: 5D |   |
|--------------|---|-----------------------|---|---|---|---|---|---------------|---|
| BITS         |   | 7                     | 6 | 5 | 4 | 3 | 2 | 1             | 0 |
| a            |   |                       |   |   |   |   |   |               |   |
| a            | R | Power-up default = 0h |   |   |   |   |   |               |   |

| POWER_MANAGEMENT_CAPABILITY |   |                                                |    |    |    |    |    |   |   |   |   |   |   |   |   | Byte Addr: 5F:5E |   |  |
|-----------------------------|---|------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|------------------|---|--|
| BITS                        |   | 15                                             | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                | 0 |  |
| g                           |   |                                                |    |    |    |    |    |   |   |   |   |   |   |   |   |                  |   |  |
| a                           | R | PME Clock: (power-up default = 0h)             |    |    |    |    |    |   |   |   |   |   |   |   |   |                  |   |  |
| b                           | R | Auxiliary Power Source (power-up default = 0h) |    |    |    |    |    |   |   |   |   |   |   |   |   |                  |   |  |
| c                           | R | DSI: (power-up default = 0h)                   |    |    |    |    |    |   |   |   |   |   |   |   |   |                  |   |  |
| d                           | R | Reserved: (power-up default = 0h)              |    |    |    |    |    |   |   |   |   |   |   |   |   |                  |   |  |
| e                           | R | D1 Support: (power-up default = 1h)            |    |    |    |    |    |   |   |   |   |   |   |   |   |                  |   |  |
| f                           | R | D2 Support: (power-up default = 1h in RAGE XL) |    |    |    |    |    |   |   |   |   |   |   |   |   |                  |   |  |
| g                           | R | PME Support (power-up default = 0h)            |    |    |    |    |    |   |   |   |   |   |   |   |   |                  |   |  |

| POWER_MANAGEMENT_CONTROL/STATUS |     |                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Byte Addr: 63:60 |  |
|---------------------------------|-----|----------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------|--|
| BITS                            |     | 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                |  |
|                                 |     | a                                                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                  |  |
| a                               | R/W | Power State: (power-up default = 0h)<br>00 = D0<br>01 = D1<br>10 = D2<br>11 = D3 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                  |  |

## 6.2 Bus Mastering Registers

### 6.2.1 System Bus Mastering Registers

The following registers are used for controlling and determining the status of the bus mastering operations.

| BM_FRAME_BUF_OFFSET MM: 1_60 |   |                  |    |    |    |    |    |    |    |    |    |    |    |                                                           |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------------------------|---|------------------|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS                         |   | 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 |
|                              |   | a                |    |    |    |    |    |    |    |    |    |    |    |                                                           |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a                            | R | FRAME_BUF_OFFSET |    |    |    |    |    |    |    |    |    |    |    | Frame buffer byte offset for current bus master operation |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| BM_SYSTEM_MEM_ADDR MM: 1_61 |   |                   |    |    |    |    |    |    |    |    |    |    |    |                                                                        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------------------------|---|-------------------|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS                        |   | 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 |
|                             |   | a                 |    |    |    |    |    |    |    |    |    |    |    |                                                                        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a                           | R | FRAME_MEM_ADDRESS |    |    |    |    |    |    |    |    |    |    |    | System memory byte address (physical) for current bus master operation |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| BM_COMMAND MM: 1_62 |   |                    |    |    |    |    |    |    |    |    |    |    |    |                                                                   |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|---|--------------------|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS                |   | 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 |
|                     |   | c                  | b  | a  |    |    |    |    |    |    |    |    |    |                                                                   |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| a                   | R | BYTE_COUNT         |    |    |    |    |    |    |    |    |    |    |    | Number of bytes for transferring (up to 4096)                     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b                   | R | FRAME_OFFSET_HOLD  |    |    |    |    |    |    |    |    |    |    |    | 0 = Increment frame buffer offset<br>1 = Hold frame buffer offset |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| c                   | R | END_OF_LIST_STATUS |    |    |    |    |    |    |    |    |    |    |    | 1 = End of bus master list                                        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### 6.2.2 Draw Engine Bus Mastering Registers

#### *See Also*

BM\_ADDR on *Chapter 6*

BM\_DATA on *Chapter 6*

The register below has two purposes. See *Usage*.

|      |     | BM_ADDR                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | MM: 0_92 |                                                                                                                                                                   |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|----------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|-----------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | d                                                  | c  | b  |    |    |    |    |    |    |    | a  |    |    |    |    |    |    |    |    |    |    |    |   |   |          |                                                                                                                                                                   |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | GUIREG_ADDR                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | Index offset to desired GUI/ENG_3D/IDCT register, or 'don't care' in case of IDCT_FLAGS = 0b00, or index offset of IDCT_RUNS register in case of IDCT_FLAGS=0B01h |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | GUIREG_COUNTER                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | The number of GUI registers to be consecutively written                                                                                                           |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | <b>IDCT_IDCT_FLAGS</b>                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | <b>Value to program</b>                                                                                                                                           |   |   |   |   |   | <b>Auto-increment</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | 0 xx                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | N-1 YES                                                                                                                                                           |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | 1 00                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | X n/a                                                                                                                                                             |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | 1 01                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | T*3 - 1 YES/NO                                                                                                                                                    |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | 1 10                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | N - 1 YES                                                                                                                                                         |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | <b>Where:</b>                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | N = The number of BM_DATA writes that follow                                                                                                                      |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | T = Number of BM_DATA R, L, L triplets that follow |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | X = Don't care                                                                                                                                                    |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | IDCT_FLAGS                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | If IDCT = 1 these bits determine type of IDCT packet (no effect otherwise)                                                                                        |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | 0 00                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | 0 = End of IDCT block request (i.e. IDCT block with all 0 coefficients will be generated). No BM_DATA is required/allowed                                         |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | 01                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | (data will follow)                                                                                                                                                |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | 10                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | 10 = Write to IDCT registers with auto-increment of GUIREG_ADDR                                                                                                   |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | 11                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | 11 = Reserved                                                                                                                                                     |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d    | R/W | IDCT                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          | 0 = Data for command FIFO (i.e. guiengine, eng_3d)                                                                                                                |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|      |     | 1 = Data for IDCT                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |          |                                                                                                                                                                   |   |   |   |   |   |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Including the following register:

|      |   | BM_DATA     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | MM: 0_92                                         |   |   |   |   |   |   |  |
|------|---|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|--------------------------------------------------|---|---|---|---|---|---|--|
| BITS |   | 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 |  |
|      |   | a           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                                                  |   |   |   |   |   |   |  |
| a    | W | GUIREG_DATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Data for register at offset specified by BM_ADDR |   |   |   |   |   |   |  |

### Description

BM\_ADDR determines the 8-bit memory mapped offset for the desired GUI register.  
 BM\_DATA is used to write the 32-bit data.

**Usage**

The BM\_ADDR/DATA register is dual-purpose. Note that the BM\_ADDR/DATA register is mapped to the same address intentionally to support this type of bus mastering operation. Upon the first write, the address of the desired GUI register is loaded into BM\_ADDR. This is an 8-bit address defined by the memory-mapped (MM) offset designated for the register. Only GUI registers in block zero can be loaded in this manner. The second write (to BM\_DATA) permits the 32-bit data written to be loaded into the specified register. After this write, the BM returns to address mode to await an the next register address.

Writing any register except BM\_ADDR will reset BM\_ADDR/DATA to address mode.

This register is extremely useful for transferring a list of register setup information from system memory using the bus master. Simply set up memory as a series of alternating register offset/data pairs (2 DWORDS per pair) and initiate a bus master operation (system → frame) that transfers the data in this list to the BM\_ADDR register. Ensure that the frame buffer offset points to the BM\_ADDR/DATA register and the FRAME\_OFFSET\_HOLD bit is set in the BM\_COMMAND DWORD entry for the current descriptor.

**See Also**

BM\_HOSTDATA on [Chapter 6](#)

|      |     | BM_GUI_TABLE      |    |    |    |    |    |    |    |    |    |    |    |                                                                                                       |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|-------------------|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | b                 |    |    |    |    |    |    |    |    |    |    |    |                                                                                                       |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | a |   |   |   |
| a    | R/W | CIRCULAR_BUF_SIZE |    |    |    |    |    |    |    |    |    |    |    | 00 = 16KB (1K entries)<br>01 = 32KB (2K entries)<br>10 = 64KB (4K entries)<br>11 = 128KB (8K entries) |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| b    | R/W | GUI_TABLE_ADDR    |    |    |    |    |    |    |    |    |    |    |    | Physical address [31:4] in system memory for start of GUI Descriptor Table                            |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Usage**

The GUI\_TABLE\_ADDR will wrap when it internally reaches a 16KB, 32KB, 64KB, or 128KB boundary (according to its circular buffer size).

|      |     | BM_GUI_TABLE_CMD  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | MM: 0_93                                                                   |   |   |   |   |   |   |   |
|------|-----|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------------------------------------------------------------------------|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | b                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                            | a |   |   |   |   |   |   |
| a    | R/W | CIRCULAR_BUF_SIZE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                            |   |   |   |   |   |   |   |
| b    | R/W | GUL_TABLE_ADDR    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Physical address [31:4] in system memory for start of GUI Descriptor Table |   |   |   |   |   |   |   |

### Usage

BM\_GUI\_TABLE\_CMD is an alias for BM\_GUI\_TABLE. The distinction is that BM\_GUI\_TABLE\_CMD goes through the GUI command FIFO and is thus synchronized to the command stream.

## 6.3 AGP Registers

|      |     | AGP_BASE                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | MM: 1_52                                                    |   |   |   |   |   |   |   |
|------|-----|-------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------------------------------------------------------------|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     | a                                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                             |   |   |   |   |   |   |   |
| a    | R/W | AGP_BASE_ADDR                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | AGP Base address                                            |   |   |   |   |   |   |   |
|      |     | AGP base address = bits [31:22], when aperture size = 4MB   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | AGP base address = bits [31:23], when aperture size = 8MB   |   |   |   |   |   |   |   |
|      |     | AGP base address = bits [31:24], when aperture size = 16MB  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | AGP base address = bits [31:25], when aperture size = 32MB  |   |   |   |   |   |   |   |
|      |     | AGP base address = bits [31:26], when aperture size = 64MB  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | AGP base address = bits [31:27], when aperture size = 128MB |   |   |   |   |   |   |   |
|      |     | AGP base address = bits [31:28], when aperture size = 256MB |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                             |   |   |   |   |   |   |   |

|      |     | AGP_CNTL              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | MM: 1_53 |                                                                                                                                                                                                     |   |   |   |   |   |  |  |  |  |  |
|------|-----|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |
|      |     |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          |                                                                                                                                                                                                     |   | a |   |   |   |  |  |  |  |  |
| a    | R/W | AGP_APER_SIZE         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          | AGP Aperture size                                                                                                                                                                                   |   |   |   |   |   |  |  |  |  |  |
|      |     |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          | 111111 = 4MB                                                                                                                                                                                        |   |   |   |   |   |  |  |  |  |  |
|      |     |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          | 111110 = 8MB                                                                                                                                                                                        |   |   |   |   |   |  |  |  |  |  |
|      |     |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          | 111100 = 16MB                                                                                                                                                                                       |   |   |   |   |   |  |  |  |  |  |
|      |     |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          | 111000 = 32MB                                                                                                                                                                                       |   |   |   |   |   |  |  |  |  |  |
|      |     |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          | 110000 = 64MB                                                                                                                                                                                       |   |   |   |   |   |  |  |  |  |  |
|      |     |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          | 100000 = 128MB                                                                                                                                                                                      |   |   |   |   |   |  |  |  |  |  |
|      |     |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          | 000000 = 256MB (default)                                                                                                                                                                            |   |   |   |   |   |  |  |  |  |  |
| b    | R/W | MAX_IDLE_CLK          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          | Number of clocks (MAX_IDLE_CLK times 32) that the AGP block will wait before stopping the generation of the 2X sideband strobe after it no longer has a request to service: (default = 0, disabled) |   |   |   |   |   |  |  |  |  |  |
| c    | R/W | HIGH_PRIORITY_READ_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          | 1 = Generate all read as high priority reads                                                                                                                                                        |   |   |   |   |   |  |  |  |  |  |
| d    | R/W | AGP_TRDY_MODE         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |          | 0 = DATA comes in clock after TRDY sampled<br>1 = DATA comes in clock in which TRDY sampled (default)                                                                                               |   |   |   |   |   |  |  |  |  |  |

# *Chapter 7*

## *VGA-Compatible Registers*

---

### **7.1 VGA Compatible Registers Summary – By I/O Port**

VGA registers in the RAGE XL are fully hardware-compatible with registers in the IBM VGA video adapter. They are grouped and described in details on the pages as indicated in the table below.

**Table 7-1 Register Functional Classes**

| Register Classes                                                | Page                 |
|-----------------------------------------------------------------|----------------------|
| CRT Controller Registers (GRAx <sub>x</sub> )                   | <a href="#">7-5</a>  |
| Attribute Controller Registers (ATTRx <sub>x</sub> )            | <a href="#">7-17</a> |
| General Status and Configuration Registers (GENx <sub>x</sub> ) | <a href="#">7-22</a> |
| Sequencer Registers (SEQx <sub>x</sub> )                        | <a href="#">7-25</a> |
| DAC Registers (DACx <sub>x</sub> )                              | <a href="#">7-29</a> |
| Graphics Controller Registers (GRAx <sub>x</sub> )              | <a href="#">7-30</a> |

Also, for convenience, they are listed by I/O port address (and by index) in table 9-2 on the next three pages.

Note:

under the Port column:

? = B when

[0]=0 (Monochrome emulation).

? = D when GENMO[0]=1 (Color/Graphics emulation).

**Table 7-2 VGA Compatible Registers Reference List**

| <b>Port</b> | <b>Index</b> | <b>Function</b> | <b>Type</b> | <b>Mnemonic</b> | <b>Register Name</b>          | <b>Page</b>          |
|-------------|--------------|-----------------|-------------|-----------------|-------------------------------|----------------------|
| 0102        | –            | General         | W           | GENVS           | VGA Sleep                     | <a href="#">7-22</a> |
| 03?4        | –            | CRT Controller  | R/W         | CRTX            | CRTC Index                    | <a href="#">7-5</a>  |
| 03?5        | 0            |                 | R/W         | CRT00           | Horizontal Total              | <a href="#">7-5</a>  |
| 03?5        | 1            |                 | R/W         | CRT01           | Horizontal Display Enable End | <a href="#">7-5</a>  |
| 03?5        | 2            |                 | R/W         | CRT02           | Start Horizontal Blanking     | <a href="#">7-6</a>  |
| 03?5        | 3            |                 | R/W         | CRT03           | End Horizontal Blanking       | <a href="#">7-6</a>  |
| 03?5        | 4            |                 | R/W         | CRT04           | Start Horizontal Retrace      | <a href="#">7-7</a>  |
| 03?5        | 5            |                 | R/W         | CRT05           | End Horizontal Retrace        | <a href="#">7-7</a>  |
| 03?5        | 6            |                 | R/W         | CRT06           | Vertical Total                | <a href="#">7-7</a>  |
| 03?5        | 7            |                 | R/W         | CRT07           | CRTC Overflow                 | <a href="#">7-8</a>  |
| 03?5        | 8            |                 | R/W         | CRT08           | Preset Row Scan               | <a href="#">7-8</a>  |
| 03?5        | 9            |                 | R/W         | CRT09           | Maximum Scan Line             | <a href="#">7-9</a>  |
| 03?5        | A            |                 | R/W         | CRT0A           | Cursor Start                  | <a href="#">7-10</a> |
| 03?5        | B            |                 | R/W         | CRT0B           | Cursor End                    | <a href="#">7-10</a> |
| 03?5        | C            |                 | R/W         | CRT0C           | Start Address (High Byte)     | <a href="#">7-11</a> |
| 03?5        | D            |                 | R/W         | CRT0D           | Start Address (Low Byte)      | <a href="#">7-11</a> |
| 03?5        | E            |                 | R/W         | CRT0E           | Cursor Location (High Byte)   | <a href="#">7-11</a> |
| 03?5        | F            |                 | R/W         | CRT0F           | Cursor Location (Low Byte)    | <a href="#">7-12</a> |
| 03?5        | 10           |                 | R/W         | CRT10           | Start Vertical Retrace        | <a href="#">7-12</a> |
| 03?5        | 11           |                 | R/W         | CRT11           | End Vertical Retrace          | <a href="#">7-12</a> |
| 03?5        | 12           |                 | R/W         | CRT12           | Vertical Display Enable End   | <a href="#">7-13</a> |
| 03?5        | 13           |                 | R/W         | CRT13           | Offset                        | <a href="#">7-13</a> |
| 03?5        | 14           |                 | R/W         | CRT14           | Underline Location            | <a href="#">7-14</a> |
| 03?5        | 15           |                 | R/W         | CRT15           | Start Vertical Blanking       | <a href="#">7-14</a> |
| 03?5        | 16           |                 | R/W         | CRT16           | End Vertical Blanking         | <a href="#">7-14</a> |
| 03?5        | 17           |                 | R/W         | CRT17           | CRT Mode                      | <a href="#">7-15</a> |

**Table 7-2 VGA Compatible Registers Reference List**

Cont'd

| <b>Port</b> | <b>Index</b> | <b>Function</b>      | <b>Type</b> | <b>Mnemonic</b> | <b>Register Name</b>            | <b>Page</b>          |
|-------------|--------------|----------------------|-------------|-----------------|---------------------------------|----------------------|
| 03?5        | 18           | CRT Controller       | R/W         | CRT18           | Line Compare                    | <a href="#">7-16</a> |
| 03?5        | 1E,1F        |                      | R           | CRT1E, 1F       | Graphic Controller Index Decode | <a href="#">7-16</a> |
| 03?5        | 22           |                      | R           | CRT22           | RAM Data Latch Readback         | <a href="#">7-17</a> |
| 03?A        | –            | General              | W           | GENFC           | Feature Control                 | <a href="#">7-22</a> |
| 03?A        | –            |                      | R           | GENS1           | Input Status 1                  | <a href="#">7-23</a> |
| 03C0        | –            | Attribute Controller | R/W         | ATTRX           | Attribute Controller Index      | <a href="#">7-17</a> |
| 03C0        | 00-0F        |                      | W           | ATTR(00:0F)     | Palette (00 to 0F)              | <a href="#">7-18</a> |
| 03C0        | 10           |                      | W           | ATTR10          | Mode Control                    | <a href="#">7-18</a> |
| 03C0        | 11           |                      | W           | ATTR11          | Overscan Color                  | <a href="#">7-19</a> |
| 03C0        | 12           |                      | W           | ATTR12          | Color Map Enable                | <a href="#">7-20</a> |
| 03C0        | 13           |                      | W           | ATTR13          | Horizontal PEL Panning          | <a href="#">7-20</a> |
| 03C0        | 14           |                      | W           | ATTR14          | Color Select                    | <a href="#">7-21</a> |
| 03C1        | 00-0F        |                      | R           | ATTR(00:0F)     | Palette (00 to 0F)              | <a href="#">7-18</a> |
| 03C1        | 10           |                      | R           | ATTR10          | Mode Control                    | <a href="#">7-18</a> |
| 03C1        | 11           |                      | R           | ATTR11          | Overscan Color                  | <a href="#">7-19</a> |
| 03C1        | 12           |                      | R           | ATTR12          | Color Map Enable                | <a href="#">7-20</a> |
| 03C1        | 13           |                      | R           | ATTR13          | Horizontal PEL Panning          | <a href="#">7-20</a> |
| 03C1        | 14           |                      | R           | ATTR14          | Color Select                    | <a href="#">7-21</a> |
| 03C2        | –            | General              | W           | GENMO           | Miscellaneous Output            | <a href="#">7-23</a> |
| 03C2        | –            |                      | R           | GENSO           | Input Status 0                  | <a href="#">7-24</a> |
| 03C3        | –            |                      | R           | GENENB          | Video Subsystem Enable (Board)  | <a href="#">7-24</a> |
| 03C4        | –            | Sequencer            | R/W         | SEQX            | Sequencer Index                 | <a href="#">7-25</a> |
| 03C5        | 0            |                      | R/W         | SEQ00           | Reset                           | <a href="#">7-26</a> |
| 03C5        | 1            |                      | R/W         | SEQ01           | Clock Mode                      | <a href="#">7-26</a> |
| 03C5        | 2            |                      | R/W         | SEQ02           | Map Mask                        | <a href="#">7-27</a> |
| 03C5        | 3            |                      | R/W         | SEQ03           | Character Map Select            | <a href="#">7-27</a> |
| 03C5        | 4            |                      | R/W         | SEQ04           | Memory Mode                     | <a href="#">7-28</a> |

**Table 7-2 VGA Compatible Registers Reference List Cont'd**

| <b>Port</b> | <b>Index</b> | <b>Function</b>     | <b>Type</b> | <b>Mnemonic</b> | <b>Register Name</b>            | <b>Page</b>          |
|-------------|--------------|---------------------|-------------|-----------------|---------------------------------|----------------------|
| 03C6        | –            | DAC                 | R/W         | DAC_MASK        | DAC Mask                        | <a href="#">7-29</a> |
| 03C7        | –            |                     | R/W         | DAC_R_INDEX     | DAC Read Current Color Index    | <a href="#">7-29</a> |
| 03C8        | –            |                     | R/W         | DAC_W_INDEX     | DAC Write Current Color Index   | <a href="#">7-29</a> |
| 03C9        | –            |                     | R/W         | DAC_DATA        | DAC Data                        | <a href="#">7-29</a> |
| 03CA        | –            | General             | R           | GENFC           | Feature Control                 | <a href="#">7-22</a> |
| 03CC        | –            |                     | R           | GENMO           | Miscellaneous Output            | <a href="#">7-23</a> |
| 03CE        | –            | Graphics Controller | R/W         | GRAX            | Graphics Controller Index       | <a href="#">7-30</a> |
| 03CF        | 0            |                     | R/W         | GRA00           | Set/Reset                       | <a href="#">7-30</a> |
| 03CF        | 1            |                     | R/W         | GRA01           | Enable Set/Reset                | <a href="#">7-31</a> |
| 03CF        | 2            |                     | R/W         | GRA02           | Color Compare                   | <a href="#">7-32</a> |
| 03CF        | 3            |                     | R/W         | GRA03           | Data Rotate                     | <a href="#">7-32</a> |
| 03CF        | 4            |                     | R/W         | GRA04           | Read Map Select                 | <a href="#">7-33</a> |
| 03CF        | 5            |                     | R/W         | GRA05           | Graphics Mode                   | <a href="#">7-33</a> |
| 03CF        | 6            |                     | R/W         | GRA06           | Graphics Miscellaneous          | <a href="#">7-35</a> |
| 03CF        | 7            |                     | R/W         | GRA07           | Color Don't Care                | <a href="#">7-35</a> |
| 03CF        | 8            |                     | R/W         | GRA08           | Bit Mask                        | <a href="#">7-36</a> |
| 46E8        | –            | General             | W           | GENENA          | Video Subsystem Enable (Add-On) | <a href="#">7-25</a> |

The following sections describe the registers grouped under the six register classes mentioned earlier. **I/O** indicates the read and write address of the register, and **Index** is included if the register is accessible indirectly.

## 7.2 VGA CRT Controller Registers

In the I/O address, note that:

? = B when GENMO[0]=0 (Monochrome emulation).

? = D when GENMO[0]=1 (Color/Graphics emulation).

| CRTC_INDEX (CRTX) |     |                |   |   |                                                                                                                                                                                                 |   |   | I/O: 3?4 | INDEX:- |
|-------------------|-----|----------------|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|---------|
| BITS              |     | 7              | 6 | 5 | 4                                                                                                                                                                                               | 3 | 2 | 1        | 0       |
|                   |     | a              |   |   |                                                                                                                                                                                                 |   |   |          |         |
| a                 | R/W | VCRTC_IDX[5:0] |   |   | This index points to one of the internal registers of the CRT controller (CRTC) at address 3?5h, for the next CRTC read/write operation<br>These registers are described on the following pages |   |   |          |         |

| HORIZONTAL_TOTAL (CRT00) |     |              |   |   |                                                                                                                                                                                     |   |   | I/O: 3?5 | INDEX: 00 |
|--------------------------|-----|--------------|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                     |     | 7            | 6 | 5 | 4                                                                                                                                                                                   | 3 | 2 | 1        | 0         |
|                          |     | a            |   |   |                                                                                                                                                                                     |   |   |          |           |
| a                        | R/W | H_TOTAL[7:0] |   |   | These bits define the active horizontal display in a scan line, including the retrace period<br>The value is five less than the total number of displayed characters in a scan line |   |   |          |           |

| HORIZONTAL_DISPLAY_ENABLE_END (CRT01) |     |                 |   |   |                                                                                                                                                      |   |   | I/O: 3?5 | INDEX: 01 |
|---------------------------------------|-----|-----------------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                                  |     | 7               | 6 | 5 | 4                                                                                                                                                    | 3 | 2 | 1        | 0         |
|                                       |     | a               |   |   |                                                                                                                                                      |   |   |          |           |
| a                                     | R/W | H_DISP_END[7:0] |   |   | These bits define the active horizontal display in a scan line<br>The value is one less than the total number of displayed characters in a scan line |   |   |          |           |

| START_HORIZONTAL_BLANKING<br>(CRT02) |     |                    |   |   |                                                                                                                                                                                                                                                        |   |   | I/O: 3?5 | INDEX: 02 |
|--------------------------------------|-----|--------------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                                 |     | 7                  | 6 | 5 | 4                                                                                                                                                                                                                                                      | 3 | 2 | 1        | 0         |
|                                      |     | a                  |   |   |                                                                                                                                                                                                                                                        |   |   |          |           |
| a                                    | R/W | H_BLANK_START[7:0] |   |   | These bits define the horizontal character count that represents the character count in the active display area plus the right border In other words, the count is from the start of active display to the start of triggering of the H blanking pulse |   |   |          |           |

| END_HORIZONTAL_BLANKING<br>(CRT03) |     |                  |   |   |                                                                                                                                                                                                                                                                                                                      |   |   | I/O: 3?5 | INDEX: 03 |  |
|------------------------------------|-----|------------------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|--|
| BITS                               |     | 7                | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                    | 3 | 2 | 1        | 0         |  |
|                                    |     | c                | b |   |                                                                                                                                                                                                                                                                                                                      | a |   |          |           |  |
| a                                  | R/W | H_BLANK_END[4:0] |   |   | H Blanking End bits [4:0] respectively<br>These are the five low-order bits (of six bits in total) of horizontal character count for triggering the end of the horizontal blanking pulse<br>The sixth bit is CRT05[7]<br>The character count is equal to the sum of "H blanking start" plus "H blanking pulse width" |   |   |          |           |  |
| b                                  | R/W | H_DE_SKEW[1:0]   |   |   | Display Enable Skew<br>00 = Zero-character-clock skew<br>01 = One-character-clock skew<br>10 = Two-character-clock skew<br>11 = Three-character-clock skew                                                                                                                                                           |   |   |          |           |  |
| c                                  | R/W | CR10CR11_R_DISB  |   |   | Compatibility Read:<br>0 = Enable write-only to CRT10 and CRT11<br>1 = Enable read/write access to both vertical retrace start/end register CRT10 and CRT11                                                                                                                                                          |   |   |          |           |  |

| START HORIZONTAL RETRACE<br>(CRT04) |     |                   |   |   |                                                                                                       |   |   | I/O: 3?5 | INDEX: 04 |
|-------------------------------------|-----|-------------------|---|---|-------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                                |     | 7                 | 6 | 5 | 4                                                                                                     | 3 | 2 | 1        | 0         |
|                                     |     | a                 |   |   |                                                                                                       |   |   |          |           |
| a                                   | R/W | H_SYNC_START[7:0] |   |   | These bits define the horizontal character count at which the horizontal retrace pulse becomes active |   |   |          |           |

| END_HORIZONTAL_RETRACE (CRT05) |     |                  |   |   |                                                                                                                                                                                                |   |   | I/O: 3?5 | INDEX: 05 |
|--------------------------------|-----|------------------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                           |     | 7                | 6 | 5 | 4                                                                                                                                                                                              | 3 | 2 | 1        | 0         |
|                                |     | c                |   |   | b                                                                                                                                                                                              |   |   |          |           |
| a                              | R/W | H_SYNC_END[4:0]  |   |   | H Retrace Ends bits<br>These are the 5-bit result from the sum of CRT04 plus the width of the horizontal retrace pulse in character clock units                                                |   |   |          |           |
| b                              | R/W | H_SYNC_SKEW[1:0] |   |   | H Retrace Delay bits<br>00 = Zero character clocks<br>01 = One character clock<br>10 = Two character clocks<br>11 = Three character clocks<br>These two bits skew the Horizontal Retrace pulse |   |   |          |           |
| c                              | R/W | H_BLANK_START[5] |   |   | H Blanking End bit [5]<br>This is bit 5 of the 6-bit character count for the H blanking end pulse<br>The other five low-order bits are CRT03[4:0]                                              |   |   |          |           |

| VERTICAL_TOTAL (CRT06) |     |              |   |   |                                                                                                                                                                                                                                                                                                   |   |   | I/O: 3?5 | INDEX: 06 |
|------------------------|-----|--------------|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                   |     | 7            | 6 | 5 | 4                                                                                                                                                                                                                                                                                                 | 3 | 2 | 1        | 0         |
|                        |     | a            |   |   |                                                                                                                                                                                                                                                                                                   |   |   |          |           |
| a                      | R/W | V_TOTAL[7:0] |   |   | These are the eight low-order bits of the 10-bit vertical total register<br>The two high-order bits are CRT07[5:0] in the CRTC overflow register. The value of this register represents the total number of H raster scans plus vertical retrace (active display, blanking), minus two scan lines |   |   |          |           |

| CRTC_OVERFLOW (CRT07) |     |                  |   |   |                                                                                                                                           |   |   | I/O: 3?5 | INDEX: 07 |   |
|-----------------------|-----|------------------|---|---|-------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|---|
| BITS                  |     | 7                | 6 | 5 | 4                                                                                                                                         | 3 | 2 | 1        | 0         |   |
|                       |     | h                | g | f |                                                                                                                                           | e | d | c        | b         | a |
| a                     | R/W | V_TOTAL[8]       |   |   | V Total bit [8] (CRT06)<br>Bit 8 of 10-bit vertical count for V Total (for functional description, see CRT06 register)                    |   |   |          |           |   |
| b                     | R/W | V_DISP_END[8]    |   |   | End V Display bit [8] (CRT12)<br>Bit 8 of 10-bit vertical count for V Display enable end (for functional description, see CRT12 register) |   |   |          |           |   |
| c                     | R/W | V_SYNC_START[8]  |   |   | Start V Retrace bit [8] (CRT10)<br>Bit 8 of 10-bit vertical count for V Retrace start (for functional description, see CRT10 register)    |   |   |          |           |   |
| d                     | R/W | V_BLANK_START[8] |   |   | Start V Blanking bit [8] (CRT15)<br>Bit 8 of 10-bit vertical count for V Blanking start (for functional description, see CRT15 register)  |   |   |          |           |   |
| e                     | R/W | LINE_CMP[8]      |   |   | Line Compare bit [8] (CRT18)<br>Bit 8 of 10-bit vertical count for Line Compare (for functional description, see CRT18 register)          |   |   |          |           |   |
| f                     | R/W | V_TOTAL[9]       |   |   | V Total bit [9] (CRT06)<br>Bit 9 or 10-bit vertical count for V Total (for functional description, see CRT06 register)                    |   |   |          |           |   |
| g                     | R/W | V_DISP_END[9]    |   |   | End V Display bit [9] (CRT12)<br>Bit 9 of 10-bit vertical count for V Display Enable End (for functional description, see CRT12 register) |   |   |          |           |   |
| h                     | R/W | V_SYNC_START[9]  |   |   | Start V Retrace bit [9] (CRT10)<br>Bit 9 of 10-bit vertical count for V Retrace start (for functional description, see CRT10 register)    |   |   |          |           |   |

| PRESET_ROW_SCAN (CRT08) |     |                     |   |   |                                                                                                                                                                                                                                                                                                                                |   |   | I/O: 3?5 | INDEX: 08 |
|-------------------------|-----|---------------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                    |     | 7                   | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                              | 3 | 2 | 1        | 0         |
|                         |     |                     |   | b |                                                                                                                                                                                                                                                                                                                                | a |   |          |           |
| a                       | R/W | ROW_SCAN_START[4:0] |   |   | This register is used for software-controlled vertical scrolling in text or graphics modes<br>The value specifies the first line to be scanned after a V retrace (in the next frame)<br>Each H Retrace pulse increments the counter by '1', up to the Maximum Scan Line value programmed by CRT09, then the counter is cleared |   |   |          |           |

|      |     | PRESET_ROW_SCAN (CRT08) |   |                                                                                                                                                                                                        |   |   |   | I/O: 3?5 | INDEX: 08 |
|------|-----|-------------------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|----------|-----------|
| BITS |     | 7                       | 6 | 5                                                                                                                                                                                                      | 4 | 3 | 2 | 1        | 0         |
| b    | R/W | BYTE_PAN[1:0]           |   | Byte Panning Control bits [1] and [0] respectively<br>Bits [6] and [5] extend the capability of byte panning (shifting) by up to three characters (for description, see H PEL Panning register ATTR13) |   |   |   |          |           |
| a    |     |                         |   |                                                                                                                                                                                                        |   |   |   |          |           |

|      |     | MAXIMUM_SCAN_LINE (CRT09) |   |   |                                                                                                                                                                                                                                                                                                                                                                     |   |   | I/O: 3?5 | INDEX: 09 |  |  |  |  |
|------|-----|---------------------------|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|--|--|--|--|
| BITS |     | 7                         | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                   | 3 | 2 | 1        | 0         |  |  |  |  |
| d    |     | d                         | c | b |                                                                                                                                                                                                                                                                                                                                                                     | a |   |          |           |  |  |  |  |
| a    | R/W | MAX_ROW_SCAN[4:0]         |   |   | Maximum Scan Line bits<br>These bits define a value that is the actual number of scan line per character minus one                                                                                                                                                                                                                                                  |   |   |          |           |  |  |  |  |
| b    | R/W | V_BLANK_START[9]          |   |   | Start V Blanking bit [9] (CRT15)<br>Bit 9 of 10-bit vertical count for V Blanking start (for functional description, see CRT15 register)                                                                                                                                                                                                                            |   |   |          |           |  |  |  |  |
| c    | R/W | LINE_CMP[9]               |   |   | Line Compare bit [9] (CRT18)<br>Bit 9 of 10-bit vertical count for line compare (for functional description, see CRT18 register)                                                                                                                                                                                                                                    |   |   |          |           |  |  |  |  |
| d    | R/W | DOUBLE_CHAR_HEIGHT        |   |   | 200-/400 Line Scan<br>0 = Counter is incremented per scan line<br>1 = Clock pulses to the row scan counter are divided by two.<br>Effectively, this allows the line in 200-line mode to be displayed twice before the row scan counter is incremented once<br>NOTE: H/V display and blanking timings etc. (in CRT00-CRT06 registers) are not affected by these bits |   |   |          |           |  |  |  |  |

| CURSOR_START (CRT0A) |     |                   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |   | I/O: 3?5 | INDEX: 0A |  |
|----------------------|-----|-------------------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|--|
| BITS                 |     | 7                 | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3 | 2 | 1        | 0         |  |
|                      |     |                   |   | b | a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |          |           |  |
| a                    | R/W | CURSOR_START[4:0] |   |   | <p>Cursor Starts bits [4:0], respectively<br/>These bits define a value that is the starting scan line (on a character row) for the line cursor. The five-bit value is equal to the actual number minus one. This value is used together with Cursor End bits CRT0B [4:0] to determine the height of the cursor</p> <p>The cursor height in VGA does not wrap around (as in EGA) and is actually absent when the 'end' value is less than the 'start' value. In EGA when the 'end' value is less, the cursor is a full block cursor which is the same height as the character cell</p> |   |   |          |           |  |
| b                    | R/W | CURSOR_DISABLE    |   |   | <p>Cursor On/Off<br/>0 = Cursor on<br/>1 = Cursor off</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |   |          |           |  |

| CURSOR_END (CRT0B) |     |                  |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |   | I/O: 3?5 | INDEX: 0B |  |
|--------------------|-----|------------------|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|--|
| BITS               |     | 7                | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 3 | 2 | 1        | 0         |  |
|                    |     |                  |   | b | a                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |   |          |           |  |
| a                  | R/W | CURSOR_END[4:0]  |   |   | <p>Cursor End bits[ 4:0], respectively<br/>These bits define the ending scan row (on a character line) for the line cursor. In EGA, this 5-bit value is equal to the actual number of lines plus one</p> <p>The cursor height in VGA does not wrap around (as in EGA) and is actually absent when the 'end' value is less than the 'start' value. In EGA when the 'end' value is less, the cursor is a full block cursor which is the same height as the character cell</p> |   |   |          |           |  |
| b                  | R/W | CURSOR_SKEW[1:0] |   |   | <p>Cursor Skew bits [1] and [0], respectively<br/>These bits define the number of characters the cursor is to be shifted to the right (skewed) from the character pointed at by the cursor location (registers CRT0E and CRT0F), in VGA mode.<br/>Skew values when in EGA mode are enclosed in brackets</p> <p>00 = Zero (zero) character skew<br/>01 = One (zero) character skew<br/>10 = Two (one) character skew<br/>11 = Three (two) character skew</p>                 |   |   |          |           |  |

| START_ADDRESS (HIGH BYTE)<br>(CRT0C) |     |                  |   |   |                                                                                                                                                                                                                                                                                             |   |   | I/O: 3?5 | INDEX: 0C |
|--------------------------------------|-----|------------------|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                                 |     | 7                | 6 | 5 | 4                                                                                                                                                                                                                                                                                           | 3 | 2 | 1        | 0         |
|                                      |     | a                |   |   |                                                                                                                                                                                                                                                                                             |   |   |          |           |
| a                                    | R/W | DISP_START[15:8] |   |   | SA bits [15:8]<br>These are the eight high-order bits of the 16-bit display buffer start location. The low order bits are contained in CRT0D<br>In split screen mode, CRT0C + CRT0D points to the starting location of screen A (top half). The starting address for screen B is always '0' |   |   |          |           |

| STAR_ADDRESS (LOW BYTE) (CRT0D) |     |                 |   |   |                                                                                                                                                                                                                                                                                            |   |   | I/O: 3?5 | INDEX: 0D |
|---------------------------------|-----|-----------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                            |     | 7               | 6 | 5 | 4                                                                                                                                                                                                                                                                                          | 3 | 2 | 1        | 0         |
|                                 |     | a               |   |   |                                                                                                                                                                                                                                                                                            |   |   |          |           |
| a                               | R/W | DISP_START[7:0] |   |   | SA bits [7:0]<br>These are the eight low-order bits of the 16-bit display buffer start location. The high-order bits are contained in CRT0C.<br>In split screen mode, CRT0C + CRT0D points to the starting location of screen A (top half.) The starting address for screen B is always 0. |   |   |          |           |

| CURSOR_LOCATION (HIGH BYTE)<br>(CRT0E) |     |                  |   |   |                                                                                                                                                                                                                                                                                                                                                          |   |   | I/O: 3?5 | INDEX: 0E |
|----------------------------------------|-----|------------------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                                   |     | 7                | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                        | 3 | 2 | 1        | 0         |
|                                        |     | a                |   |   |                                                                                                                                                                                                                                                                                                                                                          |   |   |          |           |
| a                                      | R/W | CURSOR_LOC[15:8] |   |   | CA bits [15:8]<br>These are the eight high-order bits of the 16-bit cursor start address.<br>The low-order CA bits are contained in CRT0F.<br>This address is relative to the start of physical display memory address pointed to by CRT0C + CRT0D. In other words, if CRT0C + CRT0D is changed, the cursor still points to the same character as before |   |   |          |           |

| CURSOR_LOCATION (LOW BYTE)<br>(CRT0F) |     |                 |   |   |                                                                                                                                                                                                                                                                                                                                                        |   |   | I/O: 3?5 | INDEX: 0F |
|---------------------------------------|-----|-----------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                                  |     | 7               | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                      | 3 | 2 | 1        | 0         |
|                                       |     | a               |   |   |                                                                                                                                                                                                                                                                                                                                                        |   |   |          |           |
| a                                     | R/W | CURSOR_LOC[7:0] |   |   | CA bits [7:0]<br>These are the eight low-order bits of the 16-bit cursor start address.<br>The high-order CA bits are contained in CRT0E<br>This address is relative to the start of physical display memory address pointed to by CRT0C + CRT0D. In other words, if CRT0C + CRT0D is changed, the cursor still points to the same character as before |   |   |          |           |

| START_VERTICAL_RETRACE (CRT10) |     |                   |   |   |                                                                                                                                                                                                                                                             |   |   | I/O: 3?5 | INDEX: 10 |
|--------------------------------|-----|-------------------|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                           |     | 7                 | 6 | 5 | 4                                                                                                                                                                                                                                                           | 3 | 2 | 1        | 0         |
|                                |     | a                 |   |   |                                                                                                                                                                                                                                                             |   |   |          |           |
| a                              | R/W | V_SYNC_START[7:0] |   |   | Bits CRT10 [7:0] are the eight low-order bits of the 10-bit vertical retrace start count<br>The two high-order bits are CRT07 [2:7], located in the CRTC overflow register<br>These bits define the horizontal scan count that triggers the V retrace pulse |   |   |          |           |

This register is read/write enabled if CRT03[7] is set to one. It is write-only enabled if CRT03[7] is set to zero.

| END_VERTICAL_RETRACE (CRT11) |     |                 |   |   |                                                                                                                           |   |   | I/O: 3?5 | INDEX: 11 |
|------------------------------|-----|-----------------|---|---|---------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                         |     | 7               | 6 | 5 | 4                                                                                                                         | 3 | 2 | 1        | 0         |
|                              |     | e               | d | c | b                                                                                                                         |   |   | a        |           |
| a                            | R/W | V_SYNC_END[3:0] |   |   | V Retrace End bits [3:0]<br>Bits CRT11[0:3] define the horizontal scan count that triggers the end of the V Retrace pulse |   |   |          |           |
| b                            | R/W | V_INTR_CLR      |   |   | V Retrace Interrupt Set<br>0 = V Retrace interrupt cleared                                                                |   |   |          |           |

|      |     | END_VERTICAL_RETRACE (CRT11) |   |   |                                                                                                                                                                                                                |   |   |   |   | I/O: 3?5 | INDEX: 11 |
|------|-----|------------------------------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|----------|-----------|
| BITS |     | 7                            | 6 | 5 |                                                                                                                                                                                                                | 4 | 3 | 2 | 1 | 0        |           |
|      |     | e                            | d | c |                                                                                                                                                                                                                | b | a |   |   |          |           |
| c    | R/W | V_INTR_EN                    |   |   | V Retrace Interrupt Disabled<br>0 = Enable V Retrace interrupt                                                                                                                                                 |   |   |   |   |          |           |
| d    | R/W | SEL_5RFRSH                   |   |   | Reserved                                                                                                                                                                                                       |   |   |   |   |          |           |
| e    | R/W | C0T7_WR_ONLY                 |   |   | Write Protect (CRT00-CRT06)<br>0 = Enable normal read/write of CRT00 to CRT07<br>1 = Write-protect registers CRT00 to CRT07 when in VGA mode as follows: all register bits except CRT07[4] are write-protected |   |   |   |   |          |           |

This register is read/write enabled if CRT03[7] is set to one. It is write-only enabled if CRT03[7] is set to zero.

|      |     | VERTICAL_DISPLAY_ENABLE_END (CRT12) |   |   |                                                                                                                                                                                                                                 |   |   |   |   | I/O: 3?5 | INDEX: 12 |
|------|-----|-------------------------------------|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|----------|-----------|
| BITS |     | 7                                   | 6 | 5 | 4                                                                                                                                                                                                                               | 3 | 2 | 1 | 0 |          |           |
|      |     | a                                   |   |   |                                                                                                                                                                                                                                 |   |   |   |   |          |           |
| a    | R/W | V_DISP_END[7:0]                     |   |   | These are the eight low-order bits of the 10-bit register containing the horizontal scan count indicating where the active display on the screen should end<br>The high-order bits are CRT07 [1:6] in the CRT overflow register |   |   |   |   |          |           |

|      |     | OFFSET (CRT13)  |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |   | I/O: 3?5 | INDEX: 13 |
|------|-----|-----------------|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|----------|-----------|
| BITS |     | 7               | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 3 | 2 | 1 | 0 |          |           |
|      |     | a               |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |   |          |           |
| a    | R/W | DISP_PITCH[7:0] |   |   | These bits define an offset value, equal to the logical line width of the screen (from the first character of the current line to the first character of the next line)<br>Memory organization is dependent on the video mode. Bit CRT17[6] selects byte or word mode. Bit CRT14[6], which overrides the byte/word mode setting, selects Double-Word mode when it is logical one<br>The first character of the next line is specified by the start address (CRT0C + CRT0D) plus the offset. The offset for byte mode is 2x CRT13; for word mode, 4x; for double word mode, 8x |   |   |   |   |          |           |

| UNDERLINE_LOCATION (CRT14) |     |                 |   |   |                                                                                                                                                                                                                                                                                                     |   |   |   | I/O: 3?5 | INDEX: 14 |
|----------------------------|-----|-----------------|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|----------|-----------|
| BITS                       | 7   | 6               | 5 | 4 | 3                                                                                                                                                                                                                                                                                                   | 2 | 1 | 0 |          |           |
|                            |     |                 | c | b | a                                                                                                                                                                                                                                                                                                   |   |   |   |          |           |
| a                          | R/W | UNDRLN_LOC[4:0] |   |   | H Row Scan Bits [4:0]<br>These bits define the horizontal scan row, from the top of the character line, that should be used for underlining. The 5-bit value is equal to the actual number minus one                                                                                                |   |   |   |          |           |
| b                          | R/W | ADDR_CNT_BY4    |   |   | Count-by-4<br>0 = Character clock is used unmodified at the memory address counter for byte addressing<br>1 = Character clock is divided-by-4 at the clock input to the Memory address counter. Count-by-4 clocks are used for double-word addressing. This bit overrides Addr_Cnt_By2 bit CRT17[3] |   |   |   |          |           |
| c                          | R/W | DOUBLE_WORD     |   |   | Double-Word Mode<br>0 = Allows addressing mode to be selected by CRT17[6]<br>1 = Enable double-word addressing mode. This bit overrides byte/word bit CRT17[6]                                                                                                                                      |   |   |   |          |           |

| START_VERTICAL_BLANKING (CRT15) |     |                    |   |   |                                                                                                                                                                                                                                                                                                |   |   |   | I/O: 3?5 | INDEX: 15 |
|---------------------------------|-----|--------------------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|----------|-----------|
| BITS                            | 7   | 6                  | 5 | 4 | 3                                                                                                                                                                                                                                                                                              | 2 | 1 | 0 |          |           |
|                                 |     |                    |   |   |                                                                                                                                                                                                                                                                                                |   |   |   | a        |           |
| a                               | R/W | V_BLANK_START[7:0] |   |   | Eight low-order bits of the 10-bit vertical blanking start register. Bit 9 is CRT09[5]; bit 8 is CRT07[3]<br>The 10 bits specify the starting location of the vertical blanking pulse, in units of horizontal scan lines. The value is equal to the actual number of displayed lines minus one |   |   |   |          |           |

| END_VERTICAL_BLANKING (CRT16) |     |                  |   |   |                                                                                                                                                                                                                                                                                                                                      |   |   |   | I/O: 3?5 | INDEX: 16 |  |
|-------------------------------|-----|------------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|----------|-----------|--|
| BITS                          | 7   | 6                | 5 | 4 | 3                                                                                                                                                                                                                                                                                                                                    | 2 | 1 | 0 |          |           |  |
|                               |     |                  |   |   |                                                                                                                                                                                                                                                                                                                                      |   |   |   |          |           |  |
| a                             | R/W | V_BLANK_END[7:0] |   |   | These bits define the point at which to trigger the end of the vertical blanking pulse (the location is specified in units of horizontal scan lines)<br>The value to be stored in this register is the seven low-order bits of the sum of “pulse width count” plus the content of Start Vertical Blanking register (CRT15) minus one |   |   |   |          |           |  |

|      |     | CRT_MODE (CRT17) |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   | I/O: 3?5 | INDEX: 17 |  |
|------|-----|------------------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|----------|-----------|--|
| BITS |     | 7                | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3 | 2 | 1 | 0 |          |           |  |
|      |     | g                | f | e |                                                                                                                                                                                                                                                                                                                                                                                                                                        | d | c | b | a |          |           |  |
| a    | R/W | RAO_AS_A13b      |   |   | Compatibility Mode<br>0 = Substitutes row scan counter bit 0 as bit 13 of CRTC output during active display time. For example, this allows for compatibility with the 6845 controller or CGA APA modes<br>1 = Enable row scan counter bit 13 as bit 13 of CRTC output                                                                                                                                                                  |   |   |   |   |          |           |  |
| b    | R/W | RA1_AS_A146      |   |   | Select Row Scan Counter<br>0 = Selects row scan counter bit 1 (RA1) as bit 14 at the CRTC output during active display time. This substitution allows for compatibility with Hercules graphics and other 400-line graphics modes<br>1 = Elects row scan counter bit 14 (RA14) as bit 14 at the CRTC output                                                                                                                             |   |   |   |   |          |           |  |
| c    | R/W | VCOUNT_BY2       |   |   | Vertical_by_2<br>0 = Increments the vertical timing counter every horizontal retrace<br>1 = Increments the vertical timing counter every two horizontal retrace pulses. It effectively doubles the vertical resolution by two, for example, to 2048 horizontal scan lines in VGA and 1024 in EGA<br>NOTE: When bit 2 is logical one, other vertical register values should be adjusted as well (CRT06, CRT10, CRT12, CRT15, and CRT18) |   |   |   |   |          |           |  |
| d    | R/W | ADDR_CNT_BY2     |   |   | Count_by_2<br>0 = Increments the memory address counter for every character clock<br>1 = Increments the memory address counter for every two character clocks                                                                                                                                                                                                                                                                          |   |   |   |   |          |           |  |
| e    | R/W | WRAP_A15toA0     |   |   | Address Wrap<br>0 = Indicates only 64K video memory is to be addressed. In word mode, address counter bits are left-shifted once, so bit 13 (MA13) is wrapped around to bit 0 position at the CRTC output<br>1 = Enable 256K video memory addressing. In word mode, address counter bits are rotated left by one, so bit 15(MA15) is wrapped around to bit 0 position at the CRTC output                                               |   |   |   |   |          |           |  |
| f    | R/W | BYTE_MODE        |   |   | Byte/Word Mode<br>0 = Selects word mode memory addressing. The memory address is rotated left by one<br>1 = Selects byte mode memory addressing                                                                                                                                                                                                                                                                                        |   |   |   |   |          |           |  |
| g    | R/W | CRTC_SYNC_EN     |   |   | H/V Retrace Enable<br>0 = Disable horizontal and vertical retrace<br>1 = Enable horizontal and vertical retrace                                                                                                                                                                                                                                                                                                                        |   |   |   |   |          |           |  |

640x200 mode is programmed for 100 horizontal scan lines with two row scan addresses per character row. Odd scan lines are offset in the display memory by 8K bytes.

| LINE_COMPARE (CRT18) |     |               |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |   | I/O: 3?5 | INDEX: 18 |
|----------------------|-----|---------------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                 |     | 7             | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 3 | 2 | 1        | 0         |
|                      |     | a             |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |   |          |           |
| a                    | R/W | LINE_CMP[7:0] |   |   | <p>These bits are the eight low-order of the 10-bit line compare register Bit [8] is CRT07[4], bit [9] is CRT09[6]. The value of this register is used to disable scrolling on a portion of the display screen, as when the split screen is active. When the vertical counter reaches this value, the memory address and row scan counters are cleared</p> <p>The screen area above the line specified by this register is commonly called screen A. The screen below is screen B. Screen B cannot be scrolled, but it can be panned together with screen A, controlled by the PEL panning compatibility bit ATTR10[5]. For a description of this control bit, see ATTR10[5]</p> |   |   |          |           |

| GRAPHICS_CONTROLLER_INDEX<br>DECODE (CRT1E,1F) |   |               |   |   |                                                                         |   |   | I/O: 3?5 | INDEX:1E,1F |
|------------------------------------------------|---|---------------|---|---|-------------------------------------------------------------------------|---|---|----------|-------------|
| BITS                                           |   | 7             | 6 | 5 | 4                                                                       | 3 | 2 | 1        | 0           |
|                                                |   | a             |   |   |                                                                         |   |   |          |             |
| a                                              | R | GRPH_DEC[8:0] |   |   | This register is used to read back the graphics controller index decode |   |   |          |             |

| RAM_DATA_LATCH_READBACK<br>(CRT22) |   |                      |   |   |                                                                                                                                                                                            |   |   | I/O: 3?5 | INDEX: 22 |
|------------------------------------|---|----------------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                               |   | 7                    | 6 | 5 | 4                                                                                                                                                                                          | 3 | 2 | 1        | 0         |
|                                    |   | a                    |   |   |                                                                                                                                                                                            |   |   |          |           |
| a                                  | R | GRPH_LATCH_DATA[7:0] |   |   | This register is used to read the data in the Graphics Controller CPU data latches<br>The Graphics Controller Read Map Select register bits [0] and [1] determines which byte is read back |   |   |          |           |

## 7.3 VGA Attribute Controller Registers

Notes:

After initialization, OUT commands toggle between writing to the ATTRX and the indexed Attribute registers.

The Attribute registers operate with the Palette registers to establish the video DAC PEL definition.

| ATTR_INDEX (ATTRX) |     |                |   |   |                                                                                                                                                                                                                                                                                                                                                                                                        |   |   | I/O: 3C0 | INDEX:- |  |
|--------------------|-----|----------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|---------|--|
| BITS               |     | 7              | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                      | 3 | 2 | 1        | 0       |  |
|                    |     | b              |   |   | a                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |          |         |  |
| a                  | R/W | ATTR_IDX[4:0]  |   |   | ATTR Index bits [4:0]<br>This index points to one of the internal registers of the attribute controller (ATTR) at addresses 3C1h/3C0h, for the next ATTR read/write operation<br>Since both the index and data registers are at the same I/O port, a pointer to the registers is necessary. This pointer can be initialized to point to the index register by a read instruction to the GENS1 register |   |   |          |         |  |
| b                  | R/W | ATTR_PALRW_ENB |   |   | Palette Address Source<br>0 = Allows the processor to load the color palette registers<br>1 = Allows memory data to access the color palette registers<br>After loading the color palette, this bit should be set to logical one                                                                                                                                                                       |   |   |          |         |  |

| PALETTE 00-0F (ATTR00_0F) |     |               |   |   |                                                                                                                                                                                                                               |   |   | I/O: 3C1(R)<br>3C0(W) | INDEX:<br>00 to 0F |
|---------------------------|-----|---------------|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|-----------------------|--------------------|
| BITS                      |     | 7             | 6 | 5 | 4                                                                                                                                                                                                                             | 3 | 2 | 1                     | 0                  |
|                           |     | a             |   |   |                                                                                                                                                                                                                               |   |   |                       |                    |
| a                         | R/W | ATTR_PAL[5:0] |   |   | Color bits [5:0]<br>These bits map the text attribute or graphic color input value to a display color on the screen. Color is disabled for those bits that are set to logical zero, enabled for those bits set to logical one |   |   |                       |                    |

## Notes:

1. The two high-order bits of a 6-bit palette register content are stored in ATTR14[3:2].
2. Color bits 4 and 5 are substituted by ATTR14[1:0] when color source select ATTR10[7] is logical one.
3. In all modes except 256-color mode, pre-mapped 4-bit pixel values are used as addresses into the 16 ATTR palette registers. These internal registers allow 16 colors to be displayed simultaneously. The actual color output is the content of these registers.
4. In 256-color mode, where 256 colors can be displayed simultaneously, these registers are used only to index into the external registers, also called the DAC color table, where the color output values are stored.
5. Modification of these 16 internal palette registers enables the user to access 64 different addresses in the DAC color table.

| MODE_CONTROL (ATTR10) |     |                |   |   |                                                                                                                                                                                                                                                                                                                                          |   |   | I/O: 3C1(R)<br>3C0(W) | INDEX: 10 |
|-----------------------|-----|----------------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|-----------------------|-----------|
| BITS                  |     | 7              | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                        | 3 | 2 | 1                     | 0         |
|                       |     | g              | f | e |                                                                                                                                                                                                                                                                                                                                          | d | c | b                     | a         |
| a                     | R/W | ATTR_GRPH_MODE |   |   | Graphics/*Alphanumeric Mode<br>0 = Selects A/N (alphanumeric mode)<br>1 = Selects APA (graphics mode)                                                                                                                                                                                                                                    |   |   |                       |           |
| b                     | R/W | ATTR_MONO_EN   |   |   | Monochrome/*Color Attributes Select<br>0 = Selects color display<br>1 = Selects monochrome display                                                                                                                                                                                                                                       |   |   |                       |           |
| c                     | R/W | ATTR_LGRPH_EN  |   |   | Line Graphics Enable<br>0 = Sets the ninth dot to the background color: mandatory for character fonts that do not use the line graphics character codes (C0h-DFh)<br>1 = Enable the special line graphics character codes for monochrome emulation, and sets the ninth dot of a line graphics character to be the same as the eighth dot |   |   |                       |           |

| Cont'd |     | MODE_CONTROL (ATTR10) |   |   |                                                                                                                                                                                                                                                                                                                                                                                                            |   |   |   |   | I/O: 3C1(R)<br>3C0(W) | INDEX: 10 |  |
|--------|-----|-----------------------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|-----------------------|-----------|--|
|        |     | BITS                  |   | 7 | 6                                                                                                                                                                                                                                                                                                                                                                                                          | 5 | 4 | 3 | 2 | 1                     | 0         |  |
|        |     | g                     | f | e |                                                                                                                                                                                                                                                                                                                                                                                                            | d | c | b | a |                       |           |  |
| d      | R/W | ATTR_BLINK_EN         |   |   | Blink Enable/*Background intensity<br>0 = Allows bit [7] of the character attribute to control background intensity<br>1 = Allows bit [7] of the character attribute to control blinking                                                                                                                                                                                                                   |   |   |   |   |                       |           |  |
| e      | R/W | ATTR_PANTOPONLY       |   |   | PEL Panning Compatibility<br>0 = Allows both halves of a split screen to pan together by preventing a line compare split screen function from affecting the output of PEL panning register ATTR13 and byte panning bits CRT08 [6:5]<br>1 = For panning only the top half of a split screen by forcing ATTR13 output to zero until the start of the next V sync pulse when line compare condition is "true" |   |   |   |   |                       |           |  |
| f      | R/W | ATTR_PCLKBY2          |   |   | PEL Clock Select<br>0 = Shift registers are clocked every dot clock<br>1 = For 256 color mode 13h: eight bits of video data are packed to form a pixel                                                                                                                                                                                                                                                     |   |   |   |   |                       |           |  |
| g      | R/W | ATTR_CSEL_EN          |   |   | Alternate Color Source<br>0 = Selects palette register bits [4] and [5] (in ATTR00-0F) as source for color output bits P4 and P5<br>1 = Selects ATTR14 [1:0] as source for color output bits P4 and P5, respectively                                                                                                                                                                                       |   |   |   |   |                       |           |  |

|      |     | OVERSCAN_COLOR (ATTR11) |   |   |                |   |   |   |   | I/O: 3C1(R)<br>3C0hW | INDEX: 11 |  |
|------|-----|-------------------------|---|---|----------------|---|---|---|---|----------------------|-----------|--|
| BITS |     | 7                       | 6 | 5 | 4              | 3 | 2 | 1 | 0 |                      |           |  |
|      |     | a                       |   |   |                |   |   |   |   |                      |           |  |
| a    | R/W | ATTR_OVSC[7:0]          |   |   | Overscan color |   |   |   |   |                      |           |  |

## Notes:

- These bits define the color of the border (overscan) area in 80-column modes. Overscan borders are not supported in 40-column modes.
- Refer to the description and notes for registers ATTR00-0F for information regarding how the color bits are substituted: bits 6 and 7, ATTR14[3:2], and bits 4 and 5, ATTR14[1:0].

| COLOR_MAP_ENABLE (ATTR12) |     |                  |   |   |                                                                                                                              |   |   | I/O: 3C1(R)<br>3C0(W) | INDEX: 12 |
|---------------------------|-----|------------------|---|---|------------------------------------------------------------------------------------------------------------------------------|---|---|-----------------------|-----------|
| BITS                      |     | 7                | 6 | 5 | 4                                                                                                                            | 3 | 2 | 1                     | 0         |
| a                         | R/W | ATTR_MAP_EN[3:0] |   |   | b                                                                                                                            |   |   |                       |           |
| a                         | R/W | ATTR_VSMUX[1:0]  |   |   | a                                                                                                                            |   |   |                       |           |
| a                         | R/W | ATTR_PPAN[3:0]   |   |   | Shift Count bits [3:0]<br>The shift count value (0-8) indicates how many pixel positions to shift left (see table 9-3 below) |   |   |                       |           |

| HORIZONTAL_PEL_PANNING (ATTR13) |     |                |   |   |                                                                                                                              |   |   | I/O: 3C1(R)<br>3C0(W) | INDEX: 13 |
|---------------------------------|-----|----------------|---|---|------------------------------------------------------------------------------------------------------------------------------|---|---|-----------------------|-----------|
| BITS                            |     | 7              | 6 | 5 | 4                                                                                                                            | 3 | 2 | 1                     | 0         |
| a                               | R/W | ATTR_PPAN[3:0] |   |   | a                                                                                                                            |   |   |                       |           |
| a                               | R/W | ATTR_PPAN[3:0] |   |   | Shift Count bits [3:0]<br>The shift count value (0-8) indicates how many pixel positions to shift left (see table 9-3 below) |   |   |                       |           |

Table 7-3 Left Shift vs Shift Count

| COUNT<br>VALUE | MODES<br>0+, 1+, 2+, 3+, 7, 7+ | MODE 13 | ALL OTHER<br>MODES |
|----------------|--------------------------------|---------|--------------------|
| 0              | 1                              | 0       | 0                  |
| 1              | 2                              | -       | 1                  |
| 2              | 3                              | 1       | 2                  |
| 3              | 4                              | -       | 3                  |
| 4              | 5                              | 2       | 4                  |
| 5              | 6                              | -       | 5                  |
| 6              | 7                              | 3       | 6                  |
| 7              | 8                              | -       | 7                  |

**Table 7-3 Left Shift vs Shift Count****Cont'd**

| COUNT<br>VALUE | MODES<br>0+, 1+, 2+, 3+, 7, 7+ | MODE 13 | ALL OTHER<br>MODES |
|----------------|--------------------------------|---------|--------------------|
| 8              | 0                              | -       | -                  |

Note: A/N modes 0+, 1+, 2+, 3+, and 7+ are enhanced modes with 9x16 box size resolution. A/N mode 7 has a 9x14 box size. APA mode 13 has a 320x200 screen resolution.

| COLOR_SELECT (ATTR14) |     |                |   |                                                                                                                                                                                                                                                   |   |   |   | I/O: 3C1(R)<br>3C0(W) | INDEX: 14 |  |
|-----------------------|-----|----------------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|-----------------------|-----------|--|
| BITS                  |     | 7              | 6 | 5                                                                                                                                                                                                                                                 | 4 | 3 | 2 | 1                     | 0         |  |
| a                     | R/W | ATTR_CSEL[1:0] |   | Color bits P5 and P6, respectively<br>These bits are the color output bits (instead of bits [5] and [4] of the internal palette registers ATTR00-0F) when alternate color source, bit ATTR10[7], is logical one                                   |   |   |   |                       |           |  |
| b                     | R/W | ATTR_CSEL[3:2] |   | Color bits P7 and P6, respectively<br>These two bits are the two high-order bits of the 8-bit color used for rapid color set switching (addressing different parts of the DAC color lookup table). The lower-order bits are in registers ATTR00-F |   |   |   |                       |           |  |

## 7.4 General VGA Status and Configuration Registers

| VGA_SLEEP (GENVS) |   |             |   |   |                                                                                                                                                                                                                                             |   |   | I/O:102 | INDEX:- |
|-------------------|---|-------------|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---------|---------|
| BITS              | 7 | 6           | 5 | 4 | 3                                                                                                                                                                                                                                           | 2 | 1 | 0       |         |
| a                 | W |             |   |   |                                                                                                                                                                                                                                             |   |   |         |         |
| a                 | W | VGA_ENABLE2 |   |   | VGA Sleep<br>0 = Disable VGA video subsystem (controller)<br>The VGA video subsystem only responds to memory read operations to the BIOS ROM. All other I/O or memory read/write operations are suspended<br>1 = Enable VGA video Subsystem |   |   |         |         |

Notes:

1. Writes to this register are controlled by GENENA[4].
2. Example of enabling the VGA:

```

MOV DX, 46E8
MOV AL, 10
OUT DX, AL
MOV DX, 102
MOV AL, 1
OUT DX, AL
MOV DX, 46E8
MOV AL, 8
OUT DX, AL

```

| FEATURE_CONTROL (GENFC) |     |           |   |   |                                                                                                                |   |   | I/O: 3CA(R)<br>3?A(W) | INDEX:- |
|-------------------------|-----|-----------|---|---|----------------------------------------------------------------------------------------------------------------|---|---|-----------------------|---------|
| BITS                    | 7   | 6         | 5 | 4 | 3                                                                                                              | 2 | 1 | 0                     |         |
| a                       | R/W | VSYNC_SEL |   |   | Vertical Sync Select<br>0 = Normal vertical sync<br>1 = Sync is 'vertical sync' ORed' vertical display enable' |   |   |                       |         |

| INPUT_STATUS_1 (GENS1) |   |                      |   |   |                                                                                                                                                                                                                                                                     |   |   |   | I/O: 3?A | INDEX:- |  |  |  |  |
|------------------------|---|----------------------|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|----------|---------|--|--|--|--|
| BITS                   |   | 7                    | 6 | 5 | 4                                                                                                                                                                                                                                                                   | 3 | 2 | 1 | 0        |         |  |  |  |  |
|                        |   |                      |   |   | c                                                                                                                                                                                                                                                                   | b |   |   |          | a       |  |  |  |  |
| a                      | R | NO_DISPLAY           |   |   | Display Enable<br>0 = Enable display of video data<br>1 = Disable display of video data                                                                                                                                                                             |   |   |   |          |         |  |  |  |  |
| b                      | R | VGA_VSTATUS          |   |   | Vertical Retrace Status                                                                                                                                                                                                                                             |   |   |   |          |         |  |  |  |  |
| c                      | R | PIXEL_READ_BACK[1:0] |   |   | Diagnostic bits [0] and [1] respectively<br>These two bits are connected to two of the eight color outputs (P7:P0) of the attribute controller<br>Connections are controlled by ATTR12(5,4) as follows:<br>00 = P2, P0<br>01 = P5, P4<br>10 = P3, P1<br>11 = P7, P6 |   |   |   |          |         |  |  |  |  |

Note:

Bits 0 and 3 can be used to synchronize the video buffer updates with the screen refresh cycles to minimize interference with the displayed image.

| MISCELLANEOUS_OUTPUT (GENMO) |     |                    |   |   |                                                                                                                                                                                                                                          |   |   |   | I/O: 3CC(R)<br>3C2(W) | INDEX:- |  |
|------------------------------|-----|--------------------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|-----------------------|---------|--|
| BITS                         |     | 7                  | 6 | 5 | 4                                                                                                                                                                                                                                        | 3 | 2 | 1 | 0                     |         |  |
|                              |     | e                  | d |   |                                                                                                                                                                                                                                          | c |   | b | a                     |         |  |
| a                            | R/W | GENMO_MONO_ADDRESS |   |   | 0 = Addressing for monochrome emulation (0)<br>1 = Addressing for color/graphic emulation                                                                                                                                                |   |   |   |                       |         |  |
| b                            | R/W | VGA_RAM_ENABLE     |   |   | 0 = Disable CPU access to video RAM (0) (default value)<br>1 = Enable CPU access to video RAM                                                                                                                                            |   |   |   |                       |         |  |
| c                            | R/W | VGA_CKSEL[1:0]     |   |   | 00 = 25.1744 MHz (640PELs)<br>01 = 28.3212 MHz (720PELs)                                                                                                                                                                                 |   |   |   |                       |         |  |
| d                            | R/W | ODD_EVEN_PGSEL     |   |   | This bit is used in Even/Odd display modes<br>(A/N modes: 0,1,2,3, and 7)<br>This bit is ignored when bit GRA06[1] or SEQ4[3] is enabled<br>0 = Select odd (high) video memory locations<br>1 = Select even (low) video memory locations |   |   |   |                       |         |  |

| Cont'd |     | MISCELLANEOUS_OUTPUT (GENMO)   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |   | I/O: 3CC(R)<br>3C2(W) | INDEX:- |
|--------|-----|--------------------------------|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|-----------------------|---------|
| BITS   |     | 7                              | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                                             | 3 | 2 | 1 | 0 |                       |         |
|        |     | e                              |   | d |                                                                                                                                                                                                                                                                                                                                                                                                                               | c |   |   | b | a                     |         |
| e      | R/W | VGA_VSYNC_POL<br>VGA_HSYNC_POL |   |   | Dual purpose bits used to select screen size and retrace sync polarity: (x=Bit not used for selection)<br><br>Screen Size:<br>00 = Reserved<br>01 = Screen size is 400 lines<br>10 = Screen size is 350 lines<br>11 = Screen size is 480 lines<br><br>Sync Polarity<br>x0 = H Retrace pulse is active high<br>x1 = H Retrace pulse is active low<br>0x = V Retrace pulse is active high<br>1x = V Retrace pulse is active low |   |   |   |   |                       |         |

## Note:

In VGA mode, this register controls I/O port and video buffer addressing, and selects the dot clock frequency.

|      |   | INPUT_STATUS_0 (GENS0) |   |   |                                                                                                                                                            |   |   |   |   | I/O: 3C2 | INDEX:- |  |  |  |
|------|---|------------------------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|----------|---------|--|--|--|
| BITS |   | 7                      | 6 | 5 | 4                                                                                                                                                          | 3 | 2 | 1 | 0 |          |         |  |  |  |
|      |   | b                      |   | a |                                                                                                                                                            |   |   |   |   |          |         |  |  |  |
| a    | R | SENSE_SWITCH           |   |   | Switch Sense<br><br>0 = Output state of the DAC lookup table. Comparators are inactive<br>1 = Output state of the DAC lookup table. Comparators are active |   |   |   |   |          |         |  |  |  |
| b    | R | CRT_INTR               |   |   | CRT Interrupt<br><br>0 = Vertical retrace interrupt is cleared<br>1 = Vertical retrace interrupt is pending                                                |   |   |   |   |          |         |  |  |  |

|      |   | VIDEO_SUBSYSTEM_ENABLE (BOARD)<br>(GENENB) |   |   |                                                      |   |   |   |   | I/O: 3C3 | INDEX:- |
|------|---|--------------------------------------------|---|---|------------------------------------------------------|---|---|---|---|----------|---------|
| BITS |   | 7                                          | 6 | 5 | 4                                                    | 3 | 2 | 1 | 0 |          |         |
|      |   |                                            |   |   |                                                      |   |   |   |   | a        |         |
| a    | R | VGA_ENABLE1                                |   |   | VGA Enable<br><br>Read back status of GENVS[0](0102) |   |   |   |   |          |         |

| VIDEO_SUBSYSTEM_ENABLE (ADD ON) (GENENA) |   |              |   |   |   |   |                                                                                                                                                                                                                                                                                                                                                                      | I/O: 46E8 | INDEX:- |  |
|------------------------------------------|---|--------------|---|---|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|--|
| BITS                                     |   | 7            | 6 | 5 | 4 | 3 | 2                                                                                                                                                                                                                                                                                                                                                                    | 1         | 0       |  |
|                                          |   |              |   |   |   | b | a                                                                                                                                                                                                                                                                                                                                                                    |           |         |  |
| a                                        | W | VGA_ENABLE0  |   |   |   |   | VGA Enable<br>0 = Puts VGA video subsystem into sleep mode, during which the VGA video subsystem only responds to memory read operations to the BIOS ROM, and I/O writes to register 102h. All other I/O or video memory read/write operations are suspended<br>1 = Enable I/O and memory address decoding of VGA video subsystem, if GENVS[0] is also a logical one |           |         |  |
| b                                        | W | GENVS ENABLE |   |   |   |   | GENVS[0] Enable<br>0 = Disable I/O write to GENVS(0102)<br>1 = Enable I/O write to GENVS(0102)                                                                                                                                                                                                                                                                       |           |         |  |

Note:

The decode of this register is optionally controlled by the PCI configuration space. Refer to *Chapter 8, PCI Configuration Registers*.

## 7.5 VGA Sequencer Registers

| SEQUENCER_INDEX (SEQX) |     |              |   |   |   |   |                                                                                                                                                                                   | I/O: 3C4 | INDEX:- |  |
|------------------------|-----|--------------|---|---|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------|--|
| BITS                   |     | 7            | 6 | 5 | 4 | 3 | 2                                                                                                                                                                                 | 1        | 0       |  |
|                        |     |              |   |   |   |   |                                                                                                                                                                                   | a        |         |  |
| a                      | R/W | SEQ_IDX[2:0] |   |   |   |   | This index points to one of the sequencer registers (SEQ) at I/O port address 3C5h, for the next SEQ read/write operation<br>These registers are described on the following pages |          |         |  |

| RESET (SEQ00) |     |           |   |   |                                                                                                                                                                                    |   |   | I/O: 3C5 | INDEX: 00 |
|---------------|-----|-----------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS          |     | 7         | 6 | 5 | 4                                                                                                                                                                                  | 3 | 2 | 1        | 0         |
| a             | R/W | SEQ_RST0b |   |   | Synchronous Reset bit [0]<br>0 = Follows SEQ00[1]<br>1 = Allows the sequencer to run unless SEQ00[1] is zero                                                                       |   |   |          |           |
| b             | R/W | SEQ_RST1b |   |   | Synchronous Reset bit [1]<br>0 = Disable character clock, and display requests to the video memory and H/V sync signals<br>1 = Allows the sequencer to run unless SEQ00[0] is zero |   |   |          |           |

## Notes:

1. Bits 0 and 1 must both be zero (sequencer halted) before any clock select bits are changed; for example, clock selects GENMO[3:2] or SEQ01[0:3].
2. The SEQ00[0:1] bits must both be set to one for normal operation.

| CLOCK_MODE (SEQ01) |     |                          |   |   |                                                                                                                                                                                                                                                                      |   |   | I/O: 3C5 | INDEX: 01 |
|--------------------|-----|--------------------------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS               |     | 7                        | 6 | 5 | 4                                                                                                                                                                                                                                                                    | 3 | 2 | 1        | 0         |
| a                  | R/W | SEQ_DOT8                 |   |   | 8/9 Dot Clocks<br>0 = Selects 9-dot character clocks<br>1 = Selects 8-dot character clocks<br>Modes 0, 1, 2, 3, 7 use 9-dot characters<br>To change bit 0, GENVS[0] must be logical zero                                                                             |   |   |          |           |
| b, c               | R/W | SEQ_SHIFT4<br>SEQ_SHIFT2 |   |   | Shift 4, Shift Load bits<br>00 = Loads video serializers every character clock<br>01 = Loads video serializers every other character clock<br>10 = Loads video serializers every fourth character clock<br>11 = Loads video serializers every fourth character clock |   |   |          |           |
| d                  | R/W | SEQ_PCLKBY2              |   |   | Dot Clock<br>0 = Indicates dot clock is Master clock<br>1 = Indicates dot clock is Master clock divided by 2<br>Typically, 320 and 360 horizontal modes use divide-by-2 to provide 40 column displays. To change this bit SEQ00[0:0] must first be set to zero       |   |   |          |           |
| e                  | R/W | SEQ_MAXBW                |   |   | 0 = Allows CPU:CRT interleaved access to video memory<br>1 = Blanks the screen and disables video-generation logic access to video memory. Allows CPU uninterrupted access to video memory                                                                           |   |   |          |           |

Note: To change this register, SEQ00[1 or 0] must first be logical zero.

|      |     | MAP_MASK (SEQ02) |   |   |                                                                                                     |   |   |   |   | I/O: 3C5 | INDEX: 02 |
|------|-----|------------------|---|---|-----------------------------------------------------------------------------------------------------|---|---|---|---|----------|-----------|
| BITS |     | 7                | 6 | 5 | 4                                                                                                   | 3 | 2 | 1 | 0 |          |           |
|      |     |                  |   |   |                                                                                                     |   | d | c | b | a        |           |
| a    | R/W | SEQ_MAP0_EN      |   |   | Enable Map 0<br>0 = Disable write access to memory map 0<br>1 = Enable write access to memory map 0 |   |   |   |   |          |           |
| b    | R/W | SEQ_MAP1_EN      |   |   | Enable Map 1<br>0 = Disable write access to memory map 1<br>1 = Enable write access to memory map 1 |   |   |   |   |          |           |
| c    | R/W | SEQ_MAP2_EN      |   |   | Enable Map 2<br>0 = Disable write access to memory map 2<br>1 = Enable write access to memory map 2 |   |   |   |   |          |           |
| d    | R/W | SEQ_MAP3_EN      |   |   | Enable Map 3<br>0 = Disable write access to memory map 3<br>1 = Enable write access to memory map 3 |   |   |   |   |          |           |

## Notes:

1. In 4 bit per PEL graphics modes, when the value of this register is set to '1111' (0Fh), the processor can complete a 32-bit write operation in one memory cycle.
2. In text modes, the CPU only needs to access maps 0 and 1; therefore, this register should have a value of 03h.
3. When in odd/even modes, the map mask value for maps 0 and 1 should be same as the map mask value for maps 2 and 3.
4. Memory map updating such as bit map layering can be selectively enabled or disabled using bits in this register. For pixel-oriented operations, the graphics controller provides better control.

|               |     | CHARACTER_MAP_SELECT (SEQ03) |   |   |                                   |   |   |   |   | I/O: 3C5 | INDEX: 03 |
|---------------|-----|------------------------------|---|---|-----------------------------------|---|---|---|---|----------|-----------|
| BITS          |     | 7                            | 6 | 5 | 4                                 | 3 | 2 | 1 | 0 |          |           |
|               |     |                              |   |   | f                                 | e | d | c | b | a        |           |
| a,<br>b,<br>e | R/W | SEQ_FONTB[2:0]               |   |   | Character Map Select B bits [2:0] |   |   |   |   |          |           |
| c,<br>d,<br>f | R/W | SEQ_FONTA[2:0]               |   |   | Character Map Select A bits [2:0] |   |   |   |   |          |           |

## Notes:

1. The above register may seem unusual in the way that bits 1,0,4 and 3,2,5 are grouped. This is correct and the above notation is valid.
2. Extended memory SEQ04[1] must be logical in order to enable this select function; otherwise, the first 8K of map 2 is always selected.

3. Any changes made to this register take effect at the start of the next character line on the display.

4. \*Bit Pattern      Map Selected      Offset into Map

|       |   |     |
|-------|---|-----|
| 0 0 0 | 0 | 0K  |
| 0 0 1 | 1 | 16K |
| 0 1 0 | 2 | 32K |
| 0 1 1 | 3 | 48K |
| 1 0 0 | 4 | 8K  |
| 1 0 1 | 5 | 24K |
| 1 1 0 | 6 | 40K |
| 1 1 1 | 7 | 56K |

| MEMORY_MODE (SEQ04) |     |             | I/O: 3C5 | INDEX: 04                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |
|---------------------|-----|-------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| BITS                |     | 3           | 2        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0 |
|                     |     | c           | b        | a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |
| a                   | R/W | SEQ_256K    |          | Extended Memory<br>Indicates 256K of video memory is present. Also enables character map selection in SEQ03                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |
| b                   | R/W | SEQ_ODDEVEN |          | Odd/Even<br>0 = Uses the LSB CPU address bit A0 to select which memory map to access. Even CPU addresses access maps 0 and 2; odd addresses access maps 1 and 3<br>1 = Enable sequential access to video data maps for odd/even modes. Map Mask register bits SEQ02[0:3] identify which maps are to be accessed for each CPU address                                                                                                                                                                                                                                                                                               |   |
| c                   | R/W | SEQ_CHAIN   |          | Chain<br>0 = Enable sequential data access within a bit map. Map Mask register bits SEQ02[0:3] identify which maps are to be accessed at any one time<br>1 = In 256 color modes, map select is by CPU address bits A0 and A1:<br>A1, A0    Map Selected<br>0 0        0<br>0 1        1<br>1 0        2<br>1 1        3<br>When Chain is logical one, it takes priority over odd/even mode bits SEQ04[2] and GRA05[4]. Unlike odd/even mode, SEQ04[2] is the only bit used to enable chain mode (double odd/even)<br>Chain does not affect CRTC access to video memory<br>Odd/even bit SEQ04[2] should be the opposite of GRA05[4] |   |

## 7.6 VGA DAC Registers

| DAC_MASK (DAC_MASK) |     |          |                                                                       |   |   |   |   | I/O: 03C6 | INDEX:- |  |
|---------------------|-----|----------|-----------------------------------------------------------------------|---|---|---|---|-----------|---------|--|
| BITS                | 7   | 6        | 5                                                                     | 4 | 3 | 2 | 1 | 0         |         |  |
| a                   | R/W | DAC_MASK | Participating bit positions in the mask for DAC lookup are set to one |   |   |   |   |           |         |  |

| DAC_READ_CURRENT_COLOR_INDEX<br>(DAC_R_INDEX) |     |             |                                                                                                                                    |   |   |   |   | I/O: 03C7 | INDEX:- |  |
|-----------------------------------------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|-----------|---------|--|
| BITS                                          | 7   | 6           | 5                                                                                                                                  | 4 | 3 | 2 | 1 | 0         |         |  |
| a                                             | R/W | DAC_R_INDEX | The current read index for a DAC operation - increments after every third read of DAC_Data (03C9h)<br>Refer to DAC_W_Index (03C8h) |   |   |   |   |           |         |  |

Note:

Only bit 0 of this register is readable. Writing the DAC at 03C8h results in a read-back value of 0. Writing the DAC at 03C7h results in a read-back value of 1.

| DAC_WRITE_CURRENT_COLOR_INDEX (DAC_W_INDEX) |     |             |                                                                                 |   |   |   |   | I/O: 03C8 | INDEX:- |  |
|---------------------------------------------|-----|-------------|---------------------------------------------------------------------------------|---|---|---|---|-----------|---------|--|
| BITS                                        | 7   | 6           | 5                                                                               | 4 | 3 | 2 | 1 | 0         |         |  |
| a                                           | R/W | DAC_W_INDEX | The current write index for a DAC operation<br>Refer to see DAC_R_INDEX (03C7h) |   |   |   |   |           |         |  |

| DAC_DATA (DAC_DATA) |     |          |          |   |   |   |   | I/O: 03C9 | INDEX:- |  |
|---------------------|-----|----------|----------|---|---|---|---|-----------|---------|--|
| BITS                | 7   | 6        | 5        | 4 | 3 | 2 | 1 | 0         |         |  |
| a                   | R/W | DAC_DATA | DAC Data |   |   |   |   |           |         |  |

## 7.7 VGA Graphics Controller Registers

| GRAPHICS_CONTROLLER_INDEX<br>(GRAX) |     |               |   |   |                                                                                                                                                              |   |   | I/O: 3CE | INDEX:- |
|-------------------------------------|-----|---------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|---------|
| BITS                                |     | 7             | 6 | 5 | 4                                                                                                                                                            | 3 | 2 | 1        | 0       |
|                                     |     |               |   |   |                                                                                                                                                              |   |   | a        |         |
| a                                   | R/W | GRPH_IDX[3:0] |   |   | This index is used to address one of the internal registers of the graphics controller (GRAC) at I/O port 3CFh<br>These are described on the following pages |   |   |          |         |

| SET_RESET (GRA00) |     |                   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                           |   |   | I/O: 3CF | INDEX: 00 |   |   |
|-------------------|-----|-------------------|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|---|---|
| BITS              |     | 7                 | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                                         | 3 | 2 | 1        | 0         |   |   |
|                   |     |                   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                           |   |   | d        | c         | b | a |
| a                 | R/W | GRPH_SET_RESET[0] |   |   | Set/Reset Map 0<br>0 = All eight bits of buffer map 0 are to be written with zeros during CPU write if write mode is 0 (See write mode bits GRA05[1:0], and if the enable set/reset bit GRA01[0] is a logical one<br>1 = All eight bits of buffer map 1 are to be written with one during CPU write if write mode is 0 or 3 (See write mode bits GRA05[1:0]), and if the enable set/reset bit GRA01[0] is a logical one   |   |   |          |           |   |   |
| b                 | R/W | GRPH_SET_RESET[1] |   |   | Set/Reset Map 1<br>0 = All eight bits of buffer map 1 are to be written with zeros during CPU write if write mode is 0 (see write mode bits GRA05[1:0]), and if the enable set/reset bit GRA01[1] is a logical one<br>1 = All eight bits of buffer map 1 are to be written with ones during CPU write if write mode is 0 or 3 (see write mode bits GRA05[1:0]), and if the enable set/reset bit GRA01[1] is a logical one |   |   |          |           |   |   |
| c                 | R/W | GRPH_SET_RESET[2] |   |   | Set/Reset Map 2<br>0 = All eight bits of buffer map 2 are to be written with zeros during CPU write if write mode is 0 (see write mode bits GRA05[1:0]), and if the enable set/reset bit GRA01[2] is a logical one<br>1 = All eight bits of buffer map 2 are to be written with ones during CPU write if write mode is 0 or 3 (See write mode bits GRA05[1:0]), and if the enable set/reset bit GRA01[2] is a logical one |   |   |          |           |   |   |

| Cont'd |     | SET_RESET (GRA00) |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                          |   |   | I/O: 3CF | INDEX: 00 |   |   |
|--------|-----|-------------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|---|---|
| BITS   |     | 7                 | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                                        | 3 | 2 | 1        | 0         |   |   |
|        |     |                   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                          |   |   | d        | c         | b | a |
| d      | R/W | GRPH-SET-RESET[3] |   |   | Set/Reset Map 3<br>0 = All eight bits of buffer map 3 are to be written with zeros during CPU write if write mode is 0 (See write mode bits GRA05[1:0], and if the enable set/reset bit GRA01[3] is a logical one<br>1 = All eight bits of buffer map 3 are to be written with ones during CPU write if write mode is 0 or 3 (See write mode bits GRA05[1:0]), and if the enable set/reset bit GRA01[3] is a logical one |   |   |          |           |   |   |

|      |     | ENABLE_SET_RESET (GRA01) |   |   |                                                                                                                                                                                                      |   |   | I/O: 3CF | INDEX: 01 |   |   |
|------|-----|--------------------------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|---|---|
| BITS |     | 7                        | 6 | 5 | 4                                                                                                                                                                                                    | 3 | 2 | 1        | 0         |   |   |
|      |     |                          |   |   |                                                                                                                                                                                                      |   |   | d        | c         | b | a |
| a    | R/W | GRPH_SET_RESET_ENA[0]    |   |   | Enable Set/Reset Map 0<br>0 = If write mode is 0 (GRA05[1:0]=0), CPU data is written to memory map 0<br>1 = If write mode is 0 (GRA05[1:0]=0), GRA00[0] is written to all eight bits of memory map 0 |   |   |          |           |   |   |
| b    | R/W | GRPH_SET_RESET_ENA[1]    |   |   | Enable Set/Reset Map 1<br>0 = If write mode is 0 (GRA05[1:0]=0), CPU data is written to memory map 1<br>1 = If write mode is 0 (GRA05[1:0]=0), GRA00[1] is written to all eight bits of memory map 1 |   |   |          |           |   |   |
| c    | R/W | GRPH_SET_RESET_ENA[2]    |   |   | Enable Set/Reset Map 2<br>0 = If write mode is 0 (GRA05[1:0]=0), CPU data is written to memory map 2<br>1 = If write mode is 0 (GRA05[1:0]=0), GRA00[2] is written to all eight bits of memory map 2 |   |   |          |           |   |   |
| d    | R/W | GRPH_SET_RESET_ENA[3]    |   |   | Enable Set/Reset Map 3<br>0 = If write mode is 0 (GRA05[1:0]=0), CPU data is written to memory map 3<br>1 = If write mode is 0 (GRA05[1:0]=0), GRA00[3] is written to all eight bits of memory map 3 |   |   |          |           |   |   |

**Note:**

This register has no effect on data source select when the video memory map write mode is 1, 2, or 3.

| COLOR_COMPARE (GRA02) |     |                 |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   | I/O: 3CF | INDEX: 02 |
|-----------------------|-----|-----------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                  |     | 7               | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 3 | 2 | 1        | 0         |
|                       |     | a               |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |          |           |
| a                     | R/W | GRPH_CCOMP[3:0] |   |   | Color Compare Map bits [3:0]<br>In Read mode (GRA05[3] being logical one), the four bits from this register are compared with the 4-bit PEL value (made up of one bit from each map), from bit positions 0 to 7<br>As long as the Color Don't care bits (GRA07[0:3]) for the respective maps are logical ones, the compare takes place only on those bits of the PEL value, and the CPU reads a one for a match in that bit position<br>If the Color Don't Care bit for one map is logical zero, the latched data from the map is excluded from the compare, and only the remaining three bits are compared to generate the bus data |   |   |          |           |

| DATA_ROTATE (GRA03) |     |                  |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   | I/O: 3CF | INDEX: 03 |  |  |  |  |
|---------------------|-----|------------------|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|--|--|--|--|
| BITS                |     | 7                | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                                                   | 3 | 2 | 1        | 0         |  |  |  |  |
|                     |     | b                |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                     | a |   |          |           |  |  |  |  |
| a                   | R/W | GRPH_ROTATE[2:0] |   |   | Rotate Count bits [2:0]<br>Specifies the number of bit positions the CPU data is to be rotated to the right, before doing the function selected by bits 3 and 4 above and subsequent bit mask select and write operations<br>Rotation is carried out only in write modes 0 and 3. In these two modes, the CPU data is rotated first, then operated on by the function bits GRA03 [4:3], then updated by the bit mask register GRA05 |   |   |          |           |  |  |  |  |
| b                   | R/W | GRPH_FN_SEL[1:0] |   |   | Function Select bits [1] and [2]<br>00 = CPU data replaces latched data<br>01 = CPU data ANDed with latched data<br>10 = CPU data ORed with latched data<br>11 = CPU data XORed with latched data<br>These functions are performed on the CPU data before the selected bits are updated by the bit mask register, and then written to the display buffers                                                                           |   |   |          |           |  |  |  |  |

|      |     | READ_MAP_SELECT (GRA04) |   |   |                                                                                                                                                                                                                                                                                                                                                                  |   |   | I/O: 3CF | INDEX: 04 |
|------|-----|-------------------------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS |     | 7                       | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                | 3 | 2 | 1        | 0         |
|      |     |                         |   |   |                                                                                                                                                                                                                                                                                                                                                                  |   |   |          | a         |
| a    | R/W | GRPH_RMAP               |   |   | Bits [1] and [2], respectively<br>Read mode 0 only: GRA controller returns the contents of one of the four latched buffer bytes to the CPU each time a CPU read loads the latches<br>These two bits ([0] and [1]) define a value that represents the bit map where the CPU is to read data - useful in transferring bit map data between the maps and system RAM |   |   |          |           |

## Notes:

1. In Odd/Even modes, the value may be binary 00 or 01 for chained bit maps 0 and 1.
2. In mode 13h, where all maps are chained to form one map and in read mode 1, this register is ignored.

|      |     | GRAPHIC_MODE (GRA05) |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |   |   | I/O: 3CF | INDEX: 05 |  |
|------|-----|----------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|----------|-----------|--|
| BITS |     | 7                    | 6 | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 4 | 3 | 2 | 1        | 0         |  |
|      |     |                      | d |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | c | b |   | a        |           |  |
| a    | R/W | GRPH_WRITE_MODE[1:0] |   | Write mode<br>00 = The CPU data byte can be written to video buffers map data latches in two dimensions<br>1. Byte-oriented: to update any or all maps<br>2. Pixel-oriented: to update any or all eight pixels using predefined pixel value<br>Updates are controlled using values in the internal registers of this graphics controller, namely GRA00-GRA08. If enable set/reset bits are all zeros, CPU data updates the latches according to the function bits GRA03 [4:3], and each map is updated as masked by GRA08 [7:0]<br>01 = Each map is written with the contents of its respective latches. These latches are loaded by a previous CPU memory read operation<br>10 = Pixel-oriented: The four low-order bits of the CPU data are combined with the pixel values from the maps according to the functions specified by GRA03 [4:3], and each map is updated as masked by GRA08 [7:0]<br>11 = Pixel-oriented, write mode 3 involves the following data manipulations:<br>1. CPU data is rotated by GRA03 [2:0], then logical ANDed with the Bit Mask register bits GRA08 [7:0]. The result is an 8-bit mask for use in write mode 3, to determine which pixels (from step 2 below) are to be updated by the set/reset value, and which pixels are updated directly from the latches<br>2. The set/reset pixel values are produced as follows: The set/reset bits GRA00 [0:3] are compared with each pixel value from the latches according to function bits GRA03 [4:3] |   |   |   |          |           |  |

| Cont'd |      | GRAPHIC_MODE (GRA05)  |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |      |      | I/O: 3CF | INDEX: 05 |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
|--------|------|-----------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|----------|-----------|-----|-----|-----|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|-----|-----|-----|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| BITS   |      | 7                     | 6    | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 4    | 3    | 2    | 1        | 0         |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
|        |      |                       | d    | c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | b    |      |      | a        |           |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| b      | R/W  | GRPH_READ1            |      | Read Mode<br>0 = Byte-oriented: The CPU reads the memory map specified by the Read Map Select Register GRA04 unless SEQ04[3] is logical one (Chain). In the case where SEQ04[3] is logical one, CPU address bits [A0] and [A1] are used to read the specified memory map<br>1 = Pixel-oriented, 4-bit value: The value is made up of one bit from each map. The CPU reads the result of the comparison of this pixel value ANDed with the 4-bit color compare register value. If a bit in the Color Don't Care register (GRA07) is zero, that bit position is excluded from the compare. A match causes that position in the byte to be read out by the CPU as a one. This process is repeated for all eight pixels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |      |      |          |           |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| c      | R/W  | CGA_ODDEVEN           |      | Odd/Even Addressing Enable<br>Used to enable CGA emulation, this bit enables the odd/even addressing mode when it is logical one. Normally this bit and memory mode bit SEQ04[2] are set to agree with each other in enabling odd/even mode emulation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |      |      |      |          |           |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| d      | R/W  | GRPH_PACK<br>GRPH_OES |      | Bit [6] = 256-color Mode<br>Bit [5] = Shift Register Mode<br>These bits control how data from memory is loaded into the shift registers. M0D0:M0D7, M1D0:M1D7, M2D0:M2D7, and M3D0:M3D7 are representations of this data<br>The LSB bits are shifted out first:<br>00 = <table style="margin-left: 20px; border-collapse: collapse;"> <tr><td style="text-align: right;">MSB</td><td style="text-align: center;">LSB</td><td style="text-align: left;">O/P</td></tr> <tr><td>M0D0</td><td>M0D1</td><td>M0D2</td><td>M0D3</td><td>M0D4</td><td>M0D5</td><td>M0D6</td><td>M0D7</td><td>→ C0</td></tr> <tr><td>M1D0</td><td>M1D1</td><td>M1D2</td><td>M1D3</td><td>M1D4</td><td>M1D5</td><td>M1D6</td><td>M1D7</td><td>→ C1</td></tr> <tr><td>M2D0</td><td>M2D1</td><td>M2D2</td><td>M2D3</td><td>M2D4</td><td>M2D5</td><td>M2D6</td><td>M2D7</td><td>→ C3</td></tr> <tr><td>M3D0</td><td>M3D1</td><td>M3D2</td><td>M3D3</td><td>M3D4</td><td>M3D5</td><td>M3D6</td><td>M3D7</td><td>→ C4</td></tr> </table><br>01 = <table style="margin-left: 20px; border-collapse: collapse;"> <tr><td style="text-align: right;">MSB</td><td style="text-align: center;">LSB</td><td style="text-align: left;">O/P</td></tr> <tr><td>M1D0</td><td>M1D2</td><td>M1D4</td><td>M1D6</td><td>M0D0</td><td>M0D2</td><td>M0D4</td><td>M0D6</td><td>→ C0</td></tr> <tr><td>M1D1</td><td>M1D3</td><td>M1D5</td><td>M1D7</td><td>M0D1</td><td>M0D3</td><td>M0D5</td><td>M0D7</td><td>→ C1</td></tr> <tr><td>M3D0</td><td>M3D2</td><td>M3D4</td><td>M3D6</td><td>M2D0</td><td>M2D2</td><td>M2D4</td><td>M2D6</td><td>→ C2</td></tr> <tr><td>M3D1</td><td>M3D3</td><td>M3D5</td><td>M3D7</td><td>M2D1</td><td>M2D3</td><td>M2D5</td><td>M0D7</td><td>→ C3</td></tr> </table><br>10 = When GRA05[6] = 1, bit 5 is ignored - maps 0:3 data is consequently read as packed pixels<br>11 = When GRA05[6] = 1, bit 5 is ignored - maps 0:3 data is consequently read as packed pixels |      |      |      |          |           | MSB | LSB | O/P | M0D0 | M0D1 | M0D2 | M0D3 | M0D4 | M0D5 | M0D6 | M0D7 | → C0 | M1D0 | M1D1 | M1D2 | M1D3 | M1D4 | M1D5 | M1D6 | M1D7 | → C1 | M2D0 | M2D1 | M2D2 | M2D3 | M2D4 | M2D5 | M2D6 | M2D7 | → C3 | M3D0 | M3D1 | M3D2 | M3D3 | M3D4 | M3D5 | M3D6 | M3D7 | → C4 | MSB | LSB | O/P | M1D0 | M1D2 | M1D4 | M1D6 | M0D0 | M0D2 | M0D4 | M0D6 | → C0 | M1D1 | M1D3 | M1D5 | M1D7 | M0D1 | M0D3 | M0D5 | M0D7 | → C1 | M3D0 | M3D2 | M3D4 | M3D6 | M2D0 | M2D2 | M2D4 | M2D6 | → C2 | M3D1 | M3D3 | M3D5 | M3D7 | M2D1 | M2D3 | M2D5 | M0D7 | → C3 |
| MSB    | LSB  | O/P                   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |      |      |          |           |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| M0D0   | M0D1 | M0D2                  | M0D3 | M0D4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | M0D5 | M0D6 | M0D7 | → C0     |           |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| M1D0   | M1D1 | M1D2                  | M1D3 | M1D4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | M1D5 | M1D6 | M1D7 | → C1     |           |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| M2D0   | M2D1 | M2D2                  | M2D3 | M2D4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | M2D5 | M2D6 | M2D7 | → C3     |           |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| M3D0   | M3D1 | M3D2                  | M3D3 | M3D4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | M3D5 | M3D6 | M3D7 | → C4     |           |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| MSB    | LSB  | O/P                   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |      |      |          |           |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| M1D0   | M1D2 | M1D4                  | M1D6 | M0D0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | M0D2 | M0D4 | M0D6 | → C0     |           |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| M1D1   | M1D3 | M1D5                  | M1D7 | M0D1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | M0D3 | M0D5 | M0D7 | → C1     |           |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| M3D0   | M3D2 | M3D4                  | M3D6 | M2D0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | M2D2 | M2D4 | M2D6 | → C2     |           |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| M3D1   | M3D3 | M3D5                  | M3D7 | M2D1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | M2D3 | M2D5 | M0D7 | → C3     |           |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |     |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |

| GRAPHICS_MISC (GRA06) |     |                  |   |   |                                                                                                                                                                                                                                                                                                                                                              |   |   | I/O: 3CF | INDEX: 06 |
|-----------------------|-----|------------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|
| BITS                  |     | 7                | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                            | 3 | 2 | 1        | 0         |
|                       |     |                  |   |   |                                                                                                                                                                                                                                                                                                                                                              |   | c | b        | a         |
| a                     | R/W | GRPH_GRAPHICS    |   |   | Graphics/Alphanumeric Mode<br>0 = Selects A/N (alphanumeric mode): display data bypasses the graphics controller and latches into the attribute controller<br>1 = Selects APA (graphics) mode: color data is serialized in the shift registers before it is passed to the attribute controller                                                               |   |   |          |           |
| b                     | R/W | GRPH_ODDEVEN     |   |   | Chain Odd Maps to Even<br>1= CPU address bit AO is replaced by a higher order address bit.<br>Even maps (0 and 2) are select when AO = zero; odd maps are selected when AO = one                                                                                                                                                                             |   |   |          |           |
| c                     | R/W | GRPH_ADRSEL[1:0] |   |   | Memory Map Read Bits 1 and 0, respectively:<br>00 = Maps the display buffer into processor address A0000h for 128K bytes<br>01 = Maps the display buffer into processor address A0000h for 64K bytes<br>10 = Maps the display buffer into processor address B0000h for 32K bytes<br>11 = Maps the display buffer into processor address B8000h for 32K bytes |   |   |          |           |

| COLOR_DON'T_CARE (GRA07) |     |               |   |   |              |   |   | I/O: 3CF | INDEX: 07 |   |
|--------------------------|-----|---------------|---|---|--------------|---|---|----------|-----------|---|
| BITS                     |     | 7             | 6 | 5 | 4            | 3 | 2 | 1        | 0         |   |
|                          |     |               |   |   |              |   | d | c        | b         | a |
| a                        | R/W | GRPH_XCARE[0] |   |   | Ignore Map 0 |   |   |          |           |   |
| b                        | R/W | GRPH_XCARE[1] |   |   | Ignore Map 1 |   |   |          |           |   |
| c                        | R/W | GRPH_XCARE[2] |   |   | Ignore Map 2 |   |   |          |           |   |
| d                        | R/W | GRPH_XCARE[3] |   |   | Ignore Map 3 |   |   |          |           |   |

| COLOR_DON'T_CARE (GRA07) |   |   |   |   |   |   |   | I/O: 3CF | INDEX: 07 |  |
|--------------------------|---|---|---|---|---|---|---|----------|-----------|--|
| BITS                     | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |           |  |
|                          |   |   |   |   | d | c | b | a        |           |  |

Notes:

1. A byte is latched from each memory map in a CPU read, mode 1. The color value of a pixel (PEL) is made up of a bit from each map. The 4-bit PEL value is ANDed with the four bits from this register.
2. Any bit (map x) indicated by a logical zero in this register causes the corresponding bit in the PEL value to exclude itself from the comparison with the color compare bits. The remaining bits are ANDed with the 4-bit color compare register, where a match produces a logical one for that bit position in the CPU data byte as read data.
3. For example, if register value is '1111', the entire 4-bit PEL value is compared with the color compare bits. If any bit position matches, a logical one in the corresponding bit position is generated as the CPU reads the data.

| BIT_MASK (GRA08) |     |                 |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                          |   |   | I/O: 3CF | INDEX: 08 |  |
|------------------|-----|-----------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|-----------|--|
| BITS             |     | 7               | 6 | 5 | 4                                                                                                                                                                                                                                                                                                                                                                                                                        | 3 | 2 | 1        | 0         |  |
|                  |     |                 |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                          |   |   |          | a         |  |
| a                | R/W | GRPH_BMSK [7:0] |   |   | 0 = Data is from latches. Logical zero in a bit position preserves the memory content of the four maps in the same bit position<br>1 = Data is from CPU byte. Logical one in a bit position allows updating of the four map bits that are in the same bit position.<br>This register is used directly in write modes 0-2 only. Bit masking in write mode 3 involves the CPU data, which is described in register GRA05fs |   |   |          |           |  |

This page intentionally left blank.



# Chapter 8

## LCD Panel

The LCD panel registers can only be accessed through memory mapped I/O and relocatable block I/O space. All registers are indexed.

### 8.1 Index and Data Registers

|      |     | LCD_INDEX         |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                 |    |    |    |    |    |    |    |   |   |   |   |   |   | Offset: 0_29 |   |   |   |
|------|-----|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|---|---|---|---|---|---|--------------|---|---|---|
| BITS |     | 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 |
|      |     | k                 | j  | i  | h  | g  | f  |    |    |    |    |    |    |    |    |                                                                                                                                 |    |    |    |    |    | e  | d  | c | b |   |   | a |   |              |   |   |   |
| a    | R/W | LCD_REG_INDEX     |    |    |    |    |    |    |    |    |    |    |    |    |    | Selects register in lreg block to read or write<br>Access to LCD_DATA register (offset 2A) is using this index to read or write |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |
| b    | R/W | LCD_DISPLAY_DIS   |    |    |    |    |    |    |    |    |    |    |    |    |    | Disables the display, forcing the LCD data to be '0'                                                                            |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |
| c    | R/W | LCD_SRC_SEL       |    |    |    |    |    |    |    |    |    |    |    |    |    | Selects display path for LCD out<br>0 = CRTC1 (primary display)<br>1 = <b>NOT supported</b>                                     |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |
| d    | R/W | CRTC2_DISPLAY_DIS |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>NOT supported.</b><br>MUST be set to 0.                                                                                      |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |
| e    | R   | GUI_ACTIVE        |    |    |    |    |    |    |    |    |    |    |    |    |    | Indicates GUI engine is active (read only)                                                                                      |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |
| f    | R   | MONDET_SENSE      |    |    |    |    |    |    |    |    |    |    |    |    |    | For detecting the connectivity of a panel<br>Direct input from MONDET pin<br>1 = Panel connected<br>0 = No panel connected      |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |
| g    | R/W | MONDET_INT_POL    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Interrupt on falling edge of MON_DET<br>1 = Interrupt on the rising edge                                                    |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |
| h    | R/W | MONDET_INT_EN     |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = No interrupt generated from MONDET<br>1 = Generate PCI interrupt when specified edge occurs on MONDET                       |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |
| i    | R   | MONDET_INT        |    |    |    |    |    |    |    |    |    |    |    |    |    | 1 = Specified edge has occurred on MONDET pin<br>0 = Edge has not occurred on MONDET pin                                        |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |
| i    | W   | MONDET_INT_ACK    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1 = Clear this bit to '0'                                                                                                       |    |    |    |    |    |    |    |   |   |   |   |   |   |              |   |   |   |

| Cont'd |     | LCD_INDEX |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                                              | Offset: 0_29 |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|-----|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------------------------------------------------------------------------------------------------------------------|--------------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS   |     | 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 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|        |     | k         | j  | i  | h  | g  | f  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | e                                                                                                                            | d            | c | b |   |   |   |   | a |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| j      | R/W | MONDET_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable MONDET feature<br>0 = TMDS transmitter ignores state of MONDET pin<br>1 = Disable TMDS transmitter when MONDET is low |              |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| k      | R   | EN_PL     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Status of TMDS drivers enable (read only).                                                                                   |              |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| LCD_DATA |     |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                                                                                                                            |   |   |   |   |   |   | Offset: 0_2A |  |  |  |  |  |  |  |
|----------|-----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|--------------|--|--|--|--|--|--|--|
| BITS     |     | 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 |              |  |  |  |  |  |  |  |
|          |     | a            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                                                                                                                            |   |   |   |   |   |   |              |  |  |  |  |  |  |  |
| a        | R/W | LCD_REG_DATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Data that will be written or read from the indexed LCD registers<br>Indexed registers are described on the following pages |   |   |   |   |   |   |              |  |  |  |  |  |  |  |

## 8.2 Configuration and Timing Registers

|          |     | CONFIG_PANEL                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Offset: 0_2A Index: 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------|-----|---------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS     |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|          |     | o                                                 |    |    |    |    |    | n  | m  | l  | k  | j  | i  | h  | g  | f  | e  | d  | c  |    | b  |    |    | a |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>a</b> | R/W | PANEL_FORMAT                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Specifies type of pixel format the LCD panel uses<br><b>For split-panel color STN panels:</b><br>000 = PACK6 (12-bit interface: 6-bit to upperpanel,<br>6-bit to lower panel)<br>001 = PACK8 (16-bit interface: 8-bit to upper panel,<br>8-bit to lower panel)<br>010 = PACK12 (24-bit interface: 12-bit to upper panel,<br>12-bit to lower panel)<br><b>For single-panel color STN panels:</b><br>000 = PACK12 (12-bit interface)<br>001 = PACK16 (16-bit interface)<br><b>For TFT panels:</b><br>000 = 8-color panel - 111 RGB<br>001 = 512-color panel - 333 RGB<br>010 = 4096-color panel - 444 RGB<br>100 = 18-bit/pixel panel - 666 RGB (LT mode)<br>101 = 24-bit/pixel panel - 888 RGB<br>110 = 18-bit/pixel panel - 666 RGB (FPDI-2 mode)<br>All other non-specified combinations are reserved. |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>b</b> | R/W | PANEL_TYPE<br>(Monochrome panel is not supported) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Specifies what type panel is being used<br>0001 = Split Panel STN Color<br>0011 = Single Panel STN Color<br>010X = Reserved<br>0111 = Color TFT (1 pixel per clock)<br>1111 = Color TFT (2 pixels per clock)<br>All other non-specified combinations are reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>c</b> | R/W | NO_OF_GREY                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Determines how many levels of grey levels will be supported<br>(in the case of a color panel, it is the number of grey levels per color component)<br>000 = Indicates no frame modulation should be done (applies only to TFT panels)<br>001 = 2 levels of grey support (applies only to TFT panels)<br>010 = 4 levels of grey support (applies only to TFT panels)<br>011 = 8 levels of grey support (applies only to STN panels)<br>100 = 16 levels of grey support (applies only to STN panels)<br>101 = 32 levels of grey support (applies only to monochrome STN panels)<br>110 = 64 levels of grey support (applies only to STN panels)<br>111 = Reserved                                                                                                                                         |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Cont'd |     | CONFIG_PANEL     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A Index: 0                                                                                                                                                                                       |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | o                |    |    |    |    | n  | m  | 1  | k  | j  | i  | h  | g  | f  | e  | d  | c  |    | b  |    |                                                                                                                                                                                                             | a  |   |   |   |   |   |   |   |   |   |   |
| d      | R/W | EXT_LVDS_CLK     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>NOT supported in RAGE XL.</b><br>Clock select for external LVDS/Panel Link with DSTN panel<br>00 = Disabled<br>01 = Output VCLK on LCDTMG(0) pin<br>10 = Output VCLK/2 on LCDTMG(0) pin<br>11 = Reserved |    |   |   |   |   |   |   |   |   |   |   |
| e      | R/W | BLINK_RATE       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Cursor blink<br>0 = Same as CRT<br>1 = Blink every 32 frames                                                                                                                                                |    |   |   |   |   |   |   |   |   |   |   |
| f      | R/W | DONT_SHADOW_HEND |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Use shadowed value for horizontal display end<br>1 = Use non shadow value for horizontal display end                                                                                                    |    |   |   |   |   |   |   |   |   |   |   |
| g      | R/W | LCD_IO_DRIVE     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | LCD I/O output drive strength control (applies to all LCDDO and LCDTMG pins)<br>0 = No boost<br>1 = Boost                                                                                                   |    |   |   |   |   |   |   |   |   |   |   |
| h      | R/W | FP_POL           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Active high Frame Pulse / Vsync<br>1 = Active low Frame Pulse / Vsync                                                                                                                                   |    |   |   |   |   |   |   |   |   |   |   |
| i      | R/W | LP_POL           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Active high Line Pulse / Hsync<br>1 = Active low Line Pulse / Hsync                                                                                                                                     |    |   |   |   |   |   |   |   |   |   |   |
| j      | R/W | DTMG_POL         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Active high Display Enable / MOD<br>1 = Active low Display Enable / MOD                                                                                                                                 |    |   |   |   |   |   |   |   |   |   |   |
| k      | R/W | SCK_POL          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Active high Shift Clock / PCLK<br>1 = Active low Shift Clock / PCLK                                                                                                                                     |    |   |   |   |   |   |   |   |   |   |   |
| l      | R/W | DITHER_SEL       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 00 = Disable dithering<br>01 = Dither to 4 bits<br>10 = Dither to 5 bits<br>11 = Dither to 6 bits                                                                                                           |    |   |   |   |   |   |   |   |   |   |   |
| m      | R/W | INVERSE_VIDEO_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Disable inverse video<br>1 = Enable inverse video                                                                                                                                                       |    |   |   |   |   |   |   |   |   |   |   |
| n      | R/W | BL_CLK_SEL       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Backlight modulation clock selection<br>0 = 29 MHz reference clock<br>1 = 29 MHz reference clock divided by 3                                                                                               |    |   |   |   |   |   |   |   |   |   |   |
| o      | R/W | HSYNC_DELAY(3:0) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Hsync delay for the LCD Panel<br>0000 = No delay<br>0001 = Delay by 1 VCLK<br>...<br>1111 = Delay by 15 VCLKs                                                                                               |    |   |   |   |   |   |   |   |   |   |   |

### ***Description***

This register configures the LCD Engine in order to support different types of LCD panels.

### ***Usage***

LCD Engine configuration should be done in the adapter BIOS only and before LCD panel is turned on. Most of the parameters depend on the panel type that is connected to the Graphics Controller. Panel type can be detected by reading PANEL\_ID field in the CONFIG\_STAT0 register. Only the adapter BIOS should touch this register.

### ***See Also***

LCD\_GEN\_CTRL below; specifications for the LCD panel that will be connected to the RAGE XL Graphics Controller; and documents about LCD panel interface.

## 8.3 LCD General Control Registers

|      |     | LCD_GEN_CTRL       |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
|------|-----|--------------------|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |
|      |     | A                  | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o                                                                                                                                                                                                                                                                                  | n  | m  | l  | k  | j  | i  | h  | g  | f  | e | d | c | b | a |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| a    | R/W | CRT_ON             |    |    |    |    |    |    |    |    |    |    |    | 0 = CRT off                                                                                                                                                                                                                                                                        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| b    | R/W | LCD_ON             |    |    |    |    |    |    |    |    |    |    |    | 0 = LCD off                                                                                                                                                                                                                                                                        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| c    | R/W | HORZ_DIVBY2_EN     |    |    |    |    |    |    |    |    |    |    |    | This bit is to control the following horizontal CRTC parameters:<br>Htotal, Hdisp, Hblank, Hsync and SHsync<br>0 = Do not divide horizontal CRT parameters when shadow registers are used and SEQ_PCLKBY2 is active<br>1 = Divide horizontal CRT parameters when SEQ_PCLKBY2 = '1' |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| d    | R/W | DONT_DS_ICON       |    |    |    |    |    |    |    |    |    |    |    | Double scan hardware icon<br><b>NOT supported.</b> MUST set to 1.                                                                                                                                                                                                                  |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| e    | R/W | LOCK_8DOT          |    |    |    |    |    |    |    |    |    |    |    | 0 = Character clock can be 9-dot or 8-dot                                                                                                                                                                                                                                          |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| f    | R/W | ICON_ENABLE        |    |    |    |    |    |    |    |    |    |    |    | <b>NOT supported.</b> MUST set to 0.                                                                                                                                                                                                                                               |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| g    | R/W | DONT_SHADOW_VPAR   |    |    |    |    |    |    |    |    |    |    |    | This bit is to control the use of Vsync, Vblank, and Vtotal register values<br>0 = Use shadowed values for vertical CRT parameters<br>1 = Use non-shadowed values for vertical CRT parameters                                                                                      |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| h    | R/W | V2CLK_ALWAYS_ONB   |    |    |    |    |    |    |    |    |    |    |    | <b>NOT supported.</b> MUST set to 1.                                                                                                                                                                                                                                               |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| i    | R/W | RST_FM             |    |    |    |    |    |    |    |    |    |    |    | 0 = Enable frame modulation circuitry to function                                                                                                                                                                                                                                  |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| j    | R/W | DISABLE_PCLK_RESET |    |    |    |    |    |    |    |    |    |    |    | 0 = Generate PCLK reset when memory cntl (reset is generated)<br>1 = Disable PCLK reset when memory cntl (reset is generated)                                                                                                                                                      |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| k    | R/W | DIS_HOR_CRT_DIVBY2 |    |    |    |    |    |    |    |    |    |    |    | 0 = Use non shadow H sync for CRT if HORZ_DIVBY2_EN = 1 in 40 column VGA mode<br>1 = Use divided shadow H sync for CRT                                                                                                                                                             |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| l    | R/W | SCLK_SEL           |    |    |    |    |    |    |    |    |    |    |    | 0 = Select the divided LCD_VCLK as the LCD output shift clock<br>1 = Select the PLL output as the LCD output shift clock                                                                                                                                                           |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| m    | R/W | SCLK_DELAY         |    |    |    |    |    |    |    |    |    |    |    | Adjust setup/hold time for LCD data (1 ns increment)<br>0 - 7 = SCLK comes before LCD data<br>8 = SCLK and LCD data have the same delay (default after reset)<br>9 - 15 = SCLK comes after LCD data                                                                                |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| n    | R/W | TVCLK_ALWAYS_ONb   |    |    |    |    |    |    |    |    |    |    |    | <b>NOT supported.</b> MUST set to 1.                                                                                                                                                                                                                                               |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |

| Cont'd |     | LCD_GEN_CTRL        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A Index: 1                                                                                                                                                                                                                         |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | A                   | z  | y  | x  | w  | v  | u  | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  | h  | g                                                                                                                                                                                                                                             | f  | e | d | c | b | a |   |   |   |   |   |
| o      | R/W | VCLK_DAC_ALWAYS_ONb |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = VCLK_DAC is always on<br>1 = VCLK_DAC is off during blank time                                                                                                                                                                            |    |   |   |   |   |   |   |   |   |   |   |
| p      | R/W | VCLK_LCD_OFF        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = VCLK_LCD is on regardless of the LCD_ON bit<br>1 = VCLK_LCD is off if LCD_ON is 0 otherwise VCLK_LCD is on                                                                                                                                |    |   |   |   |   |   |   |   |   |   |   |
| q      | R/W | XTALIN_ALWAYS_ONb   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = XTALIN is always on<br>1 = XTALIN depends on power management state<br>(e.g. stops in suspend)                                                                                                                                            |    |   |   |   |   |   |   |   |   |   |   |
| r      | R/W | V2CLK_DAC_ALWAYS_ON |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>NOT supported.</b> MUST set to 1.                                                                                                                                                                                                          |    |   |   |   |   |   |   |   |   |   |   |
| s      | R/W | LVDS_EN             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Disable on-chip LVDS interface<br>1 = Enable on-chip LVDS interface                                                                                                                                                                       |    |   |   |   |   |   |   |   |   |   |   |
| t      | R/W | LVDS_PLL_EN         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Disable LVDS PLL<br>1 = Enable LVDS PLL                                                                                                                                                                                                   |    |   |   |   |   |   |   |   |   |   |   |
| u      | R/W | LVDS_PLL_RESET      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Reset LVDS PLL                                                                                                                                                                                                                                |    |   |   |   |   |   |   |   |   |   |   |
| v      | R/W | LVDS_RESERVED_BITS  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Controls value to output on the LVDS_B reserved bits                                                                                                                                                                                          |    |   |   |   |   |   |   |   |   |   |   |
| w      | R/W | CRTC_RW_SELECT      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | All CRTC register reads/writes go to primary CRT -<br>MUST set to 0.                                                                                                                                                                          |    |   |   |   |   |   |   |   |   |   |   |
| x      | R/W | USE_SHADOWED_VEND   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Disable the shadow vertical end register<br>1 = Use the shadowed vertical end register CRTC_V_TOTAL_DISP [26:16]                                                                                                                          |    |   |   |   |   |   |   |   |   |   |   |
| y      | R/W | USE_SHADOWED_ROWCUR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Disable the shadow VGA cursor start and end, max_row_scan,<br>underline register<br>1 = Use the shadow VGA cursor start and end, max_row_scan,<br>underline register<br>CRT0A bit [4:0], CRT0B bit [4:0], CRT9 bit [4:0], CRT14 bit [4:0] |    |   |   |   |   |   |   |   |   |   |   |
| z      | R/W | SHADOW_EN           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Use the normal CRTC registers to generate the CRT timing<br>1 = Use the shadow registers to generate the CRT timing, except<br>shadow of CRT09 [4,0], CRT14, CRTA, CRTB,<br>CRTC_V_TOTAL_DISP [26:16]                                     |    |   |   |   |   |   |   |   |   |   |   |
| A      | R/W | SHADOW_RW_EN        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Disable read/write to the panel shadow registers<br>1 = Enable read/write to the panel shadow registers                                                                                                                                   |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register is used for general LCD panel configuration. Control as implemented by the RAGE XL, and also to control the shadowed CRTC registers.

## 8.4 Dual Scan Panel Control Registers

(NOT supported in RAGE XL)

|      |     | DSTN_CONTROL          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                                             |    | Offset: 0_2A Index: 2 |    |   |   |   |   |   |   |   |   |   |   |  |  |
|------|-----|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----------------------|----|---|---|---|---|---|---|---|---|---|---|--|--|
| BITS |     | 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                     | h  | g  | f  | e  | d  | c  |    |    |    |    |    |    |    |    |    | b  | a  |                                                                                                                                                                                                                                                                                             |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |
| a    | R/W | FP_POS                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | This register defines the position of the frame pulse for the LCD panel<br>The frame pulse happens one line after vertical count hits this value<br>If top_overscan is 0, then FP_POS = 0; otherwise FP_POS = VTOTAL - top_overscan + 1 (ADD 1 in VGA mode)                                 |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |
| b    | R/W | HFB_TEST_EN           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable testing of HFB, data is from the system directly                                                                                                                                                                                                                                     |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |
| c    | R/W | LOWER_PANEL_VPOS      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | This is the line where the LCD display switches from upper panel to lower panel<br>This panel is only used when driving a split panel<br>$\text{LOWER\_PANEL\_VPOS} = \{\text{no\_of\_active\_display\_lines} + \text{no\_of\_top\_overscan} - \text{no\_of\_bottom\_overscan}\} / 2\} - 1$ |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |
| d    | R/W | AUTO_LOWER_PANEL_VPOS |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Use register value from LOWER_PANEL_VPOS<br>1 = Calculate value based on Vertical Display End                                                                                                                                                                                           |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |
| e    | R/W | USE_ADJUST0           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = LP_VPOS_ADJUST0 / 1 / 2 / 3 will be used if the value of the Vertical End register is 350/400/480/600 respectively<br>1 = Use LP_VPOS_ADJUST0                                                                                                                                           |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |
| f    | R/W | LP_VPOS_ADJUST0       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Adjust position of the vsync during ratiometric expansion<br>00 = No shift<br>01 = Shift by 1 line<br>10 = Shift by 2 lines<br>11 = Shift by 3 lines                                                                                                                                        |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |
| g    | R/W | LP_VPOS_ADJUST1       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Adjust position of the vsync during ratiometric expansion<br>00 = No shift<br>01 = Shift by 1 line<br>10 = Shift by 2 lines<br>11 = Shift by 3 lines                                                                                                                                        |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |
| h    | R/W | LP_VPOS_ADJUST2       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Adjust position of the vsync during ratiometric expansion<br>00 = No shift<br>01 = Shift by 1 line<br>10 = Shift by 2 lines<br>11 = Shift by 3 lines                                                                                                                                        |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |
| i    | R/W | LP_VPOS_ADJUST3       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Adjust position of the vsync during ratiometric expansion<br>00 = No shift<br>01 = Shift by 1 line<br>10 = Shift by 2 lines<br>11 = Shift by 3 lines                                                                                                                                        |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |

**Description**

This register configures the sync signals for dual-scan STN panels. This register has to be programmed only if dual-scan STN panel is used.

**Usage**

Dual-scan STN panel configuration should be done in the adapter BIOS only.

**See Also**

CONFIG\_PANEL (fields PANEL\_TYPE, PANEL\_FORMAT) on [\*Chapter 8\*](#):

## 8.5 Half Frame Buffer Registers

(NOT supported in RAGE XL)

|      |     | HFB_PITCH_ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                        |    |    |    | Offset: 0_2A Index: 3 |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|-----------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
|      |     |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | d                                                                                                                                                                                                      | c  |    |    |                       |    | b |   |   |   |   |   |   |   |   | a |
| a    | R/W | XBUF_BASE      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Base address of external frame buffer, bits 0XBUF_ADDRESS [22:15]<br>This will put the half frame buffer on a 32K byte boundary in the physical memory                                                 |    |    |    |                       |    |   |   |   |   |   |   |   |   |   |   |
| b    | R/W | XBUF_SIZE      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Defines the size of the half frame buffer in 32K increments<br>0000 = Size is unlimited<br>0001 - 1110 = Size in 32K blocks<br>1111 = Stop write to the half frame buffer unconditionally              |    |    |    |                       |    |   |   |   |   |   |   |   |   |   |   |
| c    | R/W | CRT_SYNC_SEL   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Defines which CRT values should be used in centering mode for CRT monitor.<br>0 = Use non-shadow values for CRT syncs in centering mode<br>1 = Use shadow (LCD) values for CRT syncs in centering mode |    |    |    |                       |    |   |   |   |   |   |   |   |   |   |   |
| d    | R/W | HFB_HW         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Half frame buffer high watermark                                                                                                                                                                       |    |    |    |                       |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register configures the external frame buffer inside LCD Engine. This register has to be programmed only if dual-scan STN panel is used.

### Usage

External frame buffer configuration should be done in the adapter BIOS only and it is used only for dual-scan STN panels. Base address of the external frame buffer should be placed somewhere in off-screen memory. The memory size used for half frame could be calculated as:

$$\text{Memory\_size [byte]} = \text{Horiz\_resolution} \times \text{Vertical\_resolution} \times 3/8$$

### See Also

CONFIG\_PANEL (fields PANEL\_TYPE, PANEL\_FORMAT) on [Chapter 8](#).

## 8.6 Horizontal and Vertical Stretching Registers

|      |     | HORZ_STRETCHING    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A Index: 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|------|-----|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |
|      |     | f                  | e  | d  | c  |    |    |    | b  |    |    |    | a  |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| a    | R/W | HORZ_STRETCH_RATIO |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Horizontal stretch ratio<br>The value in the register is shifted out serially. (the LSB first, i.e., bit [0]). If the bit that is shifted out is '0', the same pixel is duplicated. If the bit that is shifted out is '1', the next pixel is sent out. The bit [0] is looped back to either bit [9], [12], [14], or [15] depending on the value of the LOOP_STRETCH bit (bit [0] has to be programmed to zero). When HORZ_BLEND_EN is '1', HORZ_STRETCH_RATIO is used as a ratio for horizontal blender adder. In that case, only 12 least significant bits are used and the ratio should be:<br>$\text{HORZ\_STRETCH\_RATIO} = [\text{source\_width}/\text{dest\_width}] * 4096$ |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| b    | R/W | LOOP_STRETCH       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Horizontal stretching shift register loop back select<br>000 = Loop bit [0] back to bit [9]<br>001 = Loop bit [0] back to bit [11]<br>010 = Loop bit [0] back to bit [12]<br>011 = Loop bit [0] back to bit [14]<br>100 = Loop bit [0] back to bit [15]<br>All others = Reserved                                                                                                                                                                                                                                                                                                                                                                                                  |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| c    | R/W | HORZ_PANEL_SIZE    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Panel horizontal display in characters (pixels/8 -1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| d    | R/W | AUTO_HORZ_RATIO    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable the calculation of horizontal stretch ratio based on actual horizontal display and overscan instead of H_DISP_END, OVR_WID_LEFT & OVR_WID_RIGHT registers<br>0 = Disable auto horizontal stretch ratio<br>1 = Enable auto horizontal stretch ratio                                                                                                                                                                                                                                                                                                                                                                                                                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

|      |     | HORZ_STRETCHING   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A Index: 4                                                                            |    |   |   |   |   |   |   |   |   |   |   |  |
|------|-----|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|--|
| BITS |     | 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 |  |
|      |     | f                 | e  | d  |    |    |    |    | c  |    |    |    | b  |    |    |    |    |    |    |    |    |                                                                                                  |    | a |   |   |   |   |   |   |   |   |   |  |
| e    | R/W | HORZ_STRETCH_MODE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Horizontal stretch mode<br>0 = Pixel replication (use shift register)<br>1 = Horizontal blending |    |   |   |   |   |   |   |   |   |   |   |  |
| f    | R/W | HORZ_STRETCH_EN   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Horizontal stretch enable<br>1 = Enable horizontal stretching                                    |    |   |   |   |   |   |   |   |   |   |   |  |

### Description

This register defines the parameters for horizontal stretching (expansion).

### Usage

In order to support ratiometric expansion, HORZ\_STRETCHING, VERT\_STRETCHING and EXT\_VERT\_STRETCH registers have to be programmed. The values that have to be programmed in these registers depend on the panel resolution and the current graphics mode resolution. Ratiometric expansion in horizontal direction can be done in two ways—pixel replication or blending.

### See Also

VERT\_STRETCHING (next) and EXT\_VERT\_STRETCH. (after next)

|      |     | VERT_STRETCHING     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A Index: 5                                                                                          |    |   |   |   |   |   |   |   |   |   |   |  |
|------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|--|
| BITS |     | 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 |  |
|      |     | e                   | d  |    |    |    |    |    | c  |    |    |    | b  |    |    |    |    |    |    |    |    |                                                                                                                |    | a |   |   |   |   |   |   |   |   |   |  |
| a    | R/W | VERT_STRETCH_RATIO0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Vertical stretch ratio<br>VERT_STRETCH_RATIO =<br>[no_of_lines_of_source / no_of_lines_of_destination] * 1024  |    |   |   |   |   |   |   |   |   |   |   |  |
| b    | R/W | VERT_STRETCH_RATIO1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Vertical stretch ratio<br>VERT_STRETCH_RATIO =<br>[no_of_lines_of_source / no_of_lines_of_destination] * 1024  |    |   |   |   |   |   |   |   |   |   |   |  |
| c    | R/W | VERT_STRETCH_RATIO2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Vertical stretch ratio:<br>VERT_STRETCH_RATIO =<br>[no_of_lines_of_source / no_of_lines_of_destination] * 1024 |    |   |   |   |   |   |   |   |   |   |   |  |

|      |     | VERT_STRETCHING |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                |    |    |    |    |    |    |    | Offset: 0_2A Index: 5 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
|------|-----|-----------------|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|-----------------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |  |
|      |     | e               | d  | c  |    |    |    |    |    | b  |    |    |    |                                                                                                                                                                |    | a  |    |    |    |    |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| d    | R/W | USE_RATIO0      |    |    |    |    |    |    |    |    |    |    |    | 0 = VERT_STRETCH_RATIO0 / 1 / 2 / 3 will be used if the value of the vertical end register is 350/ 400/ 480 respectively.<br>1 = Always use VERT_STRETCH_RATIO |    |    |    |    |    |    |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| e    | R/W | VERT_STRETCH_EN |    |    |    |    |    |    |    |    |    |    |    | Vertical stretch enable<br>1 = Enable vertical stretching                                                                                                      |    |    |    |    |    |    |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |

### Description

This register defines the parameters for vertical stretching (expansion).

### Usage

In order to support ratiometric expansion, HORZ\_STRETCHING, VERT\_STRETCHING and EXT\_VERT\_STRETCH registers have to be programmed. The values that have to be programmed in these registers depend on the panel resolution and the current graphics mode resolution. Ratiometric expansion in the vertical direction can be done in two ways — line replication or vertical blending.

### See Also

HORZ\_STRETCHING, EXT\_VERT\_STRETCH (next)

|      |     | EXT_VERT_STRETCH    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                              |    |    |    |    |    |    |    | Offset: 0_2A Index: 6 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|-----------------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| BITS |     | 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 |  |  |  |  |
|      |     |                     |    |    |    |    | f  | e  | d  | c  |    |    |    |                                                                                                                                                                              |    | b  | a  |    |    |    |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| a    | R/W | VERT_STRETCH_RATIO3 |    |    |    |    |    |    |    |    |    |    |    | Vertical stretch ratio (for 600 non standard VGA mode)<br>VERT_STRETCH_RATIO =<br>[no_of_lines_of_source/ no_of_lines_of_destination ] * 1024                                |    |    |    |    |    |    |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| b    | R/W | VERT_STRETCH_MODE   |    |    |    |    |    |    |    |    |    |    |    | Vertical stretch mode<br>0 = line replication<br>1 = vertical blending                                                                                                       |    |    |    |    |    |    |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| c    | R/W | VERT_PANEL_SIZE     |    |    |    |    |    |    |    |    |    |    |    | Vertical panel size (line number -1)                                                                                                                                         |    |    |    |    |    |    |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| d    | R/W | AUTO_VERT_RATIO     |    |    |    |    |    |    |    |    |    |    |    | Automatically calculate vertical ratio based on vertical display end, top and bottom overscan<br>0 = Use VERT_STRETCH_RATIOX register values<br>1 = Calculate vertical ratio |    |    |    |    |    |    |    |                       |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

|      |     | EXT_VERT_STRETCH   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                          |    |    |    |    |    |   |   |   |   | Offset: 0_2A Index: 6 |   |   |   |   |   |
|------|-----|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------|----|----|----|----|----|---|---|---|---|-----------------------|---|---|---|---|---|
| BITS |     | 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 |
|      |     |                    |    |    |    |    |    |    |    | f  | e  | d  |    |    |    |    |    |                                                                                          |    |    | b  |    |    |   |   |   |   |                       |   | a |   |   |   |
| e    | R/W | USE_AUTO_FP_POS    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | NOT supported. MUST set to 0.                                                            |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |
| f    | R/W | USE_AUTO_LCD_VSYNC |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable generation of sync signal for TFT panel based on shadow sync start and end values |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |

## 8.7 LT\_GPIO and ZVGPIO Registers

|      |     | LT_GIO       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                   |    |    |    |    |    |   |   |   |   | Offset: 0_2A Index: 7 |   |   |   |   |   |   |   |   |   |   |
|------|-----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------|----|----|----|----|----|---|---|---|---|-----------------------|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |   |   |   |   |   |
|      |     | u            | t  | s  | r  |    |    |    |    |    |    |    |    | q  | p  | o  | n  | m                                 | l  | k  | j  | i  | h  |   |   |   |   |                       |   |   |   | g | f | e | d | c | b | a |
| a    | R/W | LT_GIO_0     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| b    | R/W | LT_GIO_1     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| c    | R/W | LT_GIO_2     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| d    | R/W | LT_GIO_3     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| e    | R/W | LT_GIO_4     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| f    | R/W | LT_GIO_5     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| g    | R/W | LT_GIO_6     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| h    | R/W | GPIO_14      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Write/Read (DIR14 = output/input) |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| i    | R/W | GPIO_15      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Write/Read (DIR15 = output/input) |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| j    | R/W | GPIO_16      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Write/Read (DIR16 = output/input) |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| k    | R/W | LT_GIO_DIR_0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| l    | R/W | LT_GIO_DIR_1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| m    | R/W | LT_GIO_DIR_2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| n    | R/W | LT_GIO_DIR_3 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| o    | R/W | LT_GIO_DIR_4 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| p    | R/W | LT_GIO_DIR_5 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |
| q    | R/W | LT_GIO_DIR_6 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                    |    |    |    |    |    |   |   |   |   |                       |   |   |   |   |   |   |   |   |   |   |

| Cont'd |     | LT_GIO       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A Index: 7                                                                               |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | u            | t  | s  | r  |    |    |    |    | q  | p  | o  | n  | m  | l  | k  |    | j  | i  | h  |    |                                                                                                     |    |   | g | f | e | d | c | b | a |   |   |
| r      | R/W | GPIO_DIR_14  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | GPIO_14 Direction: (default = 0)<br>0 = Input<br>1 = Output                                         |    |   |   |   |   |   |   |   |   |   |   |
| s      | R/W | GPIO_DIR_15  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | GPIO_15 Direction: (default = 0)<br>0 = Input<br>1 = Output                                         |    |   |   |   |   |   |   |   |   |   |   |
| t      | R/W | GPIO_DIR_16  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | GPIO_16 Direction: (default = 0)<br>0 = Input<br>1 = Output                                         |    |   |   |   |   |   |   |   |   |   |   |
| u      | R/W | DDC_IO_DRIVE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DDC IO output drive strength (applies to GPIO pins 14 to 16 inclusive)<br>0 = No boost<br>1 = Boost |    |   |   |   |   |   |   |   |   |   |   |

**See Also**GP\_IO on [page 4-1](#).

**Note:** Due to pin limitations, RAGE XL does **NOT** support any of the ZVGPIO bits, except PWRSEQ\_DELAY.

|      |     | ZVGPIO   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A Index: 9 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|------|-----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| BITS |     | 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 |  |  |  |
|      |     | q        |    |    |    |    | p  | o  | n  |    |    |    |    | m  | l  | k  | j  | i  |    |    |    |                       | h  | g | f | e | d | c | b | a |   |   |   |  |  |  |
| a    | R/W | ZVGPIO_0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.        |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| b    | R/W | ZVGPIO_1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.        |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| c    | R/W | ZVGPIO_2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.        |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| d    | R/W | ZVGPIO_3 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.        |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| e    | R/W | ZVGPIO_4 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.        |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| f    | R/W | ZVGPIO_5 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.        |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| g    | R/W | ZVGPIO_6 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.        |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
| h    | R/W | ZVGPIO_7 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.        |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Cont'd |     | ZVGPIO       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A Index: 9                                                                                                                                                                                                                        |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | q            |    | p  | o  | n  | m  | l  | k  | j  | i  |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                              |    | h | g | f | e | d | c | b | a |   |   |
| i      | R/W | ZVGPIO_DIR_0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                                                                                                                                                                                                                               |    |   |   |   |   |   |   |   |   |   |   |
| j      | R/W | ZVGPIO_DIR_1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                                                                                                                                                                                                                               |    |   |   |   |   |   |   |   |   |   |   |
| k      | R/W | ZVGPIO_DIR_2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                                                                                                                                                                                                                               |    |   |   |   |   |   |   |   |   |   |   |
| l      | R/W | ZVGPIO_DIR_3 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                                                                                                                                                                                                                               |    |   |   |   |   |   |   |   |   |   |   |
| m      | R/W | ZVGPIO_DIR_4 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                                                                                                                                                                                                                               |    |   |   |   |   |   |   |   |   |   |   |
| n      | R/W | ZVGPIO_DIR_5 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                                                                                                                                                                                                                               |    |   |   |   |   |   |   |   |   |   |   |
| o      | R/W | ZVGPIO_DIR_6 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                                                                                                                                                                                                                               |    |   |   |   |   |   |   |   |   |   |   |
| p      | R/W | ZVGPIO_DIR_7 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Not supported.                                                                                                                                                                                                                               |    |   |   |   |   |   |   |   |   |   |   |
| q      | R/W | PWRSEQ_DELAY |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Programmable value of panel power sequencing block<br>This value can be programmed up to 2048 ms in increments of 8 ms<br>(generated from 32kHz clock). If '0' is programmed, FP will<br>be used as clock to generate power up/down sequence |    |   |   |   |   |   |   |   |   |   |   |

## 8.8 Power Management Registers

Only RAGE XL is fully ACPI compliant of all power management modes.

|      |     | POWER_MANAGEMENT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |                                                                                                                                                                                                                                                                                                  | Offset: 0_2A Index: 8                                       |   |   |   |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|------|-----|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|---|---|---|--|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |  | q | p | o | n | m | l | k | j | i | h | g | f | e | d | c | b | a |
| a    | R/W | PWR_MGT_ON       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |                                                                                                                                                                                                                                                                                                  | 0 = Disable power management<br>1 = Enable power management |   |   |   |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| b    | R/W | PWR_MGT_MODE     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 00 = Reserved<br>01 = Register mode<br>10 = Timer mode (RAGE XL only)<br>11 = PCI configuration space register mode                                                                                                                                                                              |                                                             |   |   |   |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| c    | R/W | AUTO_PWRUP_EN    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Disable automatic power up sequence<br>1 = Enable automatic power up sequence                                                                                                                                                                                                                |                                                             |   |   |   |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| d    | R/W | SELF_REFRESH     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Enable Self-Refresh<br>1 = Disable Self-Refresh                                                                                                                                                                                                                                              |                                                             |   |   |   |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| e    | R/W | KEYBD_SNOOP      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Disable keyboard access snooping<br>1 = Enable keyboard access to exit the chip from power down modes                                                                                                                                                                                        |                                                             |   |   |   |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| f    | R/W | DONT_USE_XTALIN  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Use XTALIN pin to generate internal timing (for simulation only)<br>1 = Use divided version of PLL reference clock                                                                                                                                                                           |                                                             |   |   |   |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| g    | R/W | TRISTATE_MEM_EN  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0 = Disable tristating MA, MD and control signals to the memory during Suspend Mode<br>1 = Enable tristating signals in Suspend Mode                                                                                                                                                             |                                                             |   |   |   |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| h    | R/W | LCDENG_TEST_MODE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 0000 = Normal mode<br>Others = Set the LCD Engine into test modes (to be defined)<br>0001 = CRC for LCD datapath<br>0010 = Framemod module goes into test mode<br>0011 = Not supported<br>0100 = Not supported<br>1000 = Not supported<br>1111 = Power Management test mode<br>Others = Reserved |                                                             |   |   |   |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| i    | R/W | STANDBY_COUNT    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 4-bit Standby counter value                                                                                                                                                                                                                                                                      |                                                             |   |   |   |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| j    | R/W | SUSPEND_COUNT    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 4-bit Suspend counter value                                                                                                                                                                                                                                                                      |                                                             |   |   |   |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| k    | R/W | BIASON           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Panel bias voltage control<br>0 = Shut off bias voltage (VEE)<br>1 = Turn on bias voltage (VEE)                                                                                                                                                                                                  |                                                             |   |   |   |  |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

| Cont'd |     | POWER_MANAGEMENT   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A Index: 8                                                                                                                                           |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS   |     | 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 |
|        |     | q                  | p  | o  | n  | m  | l  | k  |    | j  |    | i  |    | h  | g  | f  | e  |    | d  |    |    |                                                                                                                                                                 | c  | b | a |   |   |   |   |   |   |   |   |
| 1      | R/W | BLON               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Backlight control<br>0 = Shut off backlight voltage (VB)<br>1 = Turn on backlight voltage (VB)                                                                  |    |   |   |   |   |   |   |   |   |   |   |
| m      | R/W | DIGON              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Panel digital power control<br>0 = Shut off digital voltage (VCC)<br>1 = Turn on digital voltage (VCC)                                                          |    |   |   |   |   |   |   |   |   |   |   |
| n      | R/W | EN_RST_D3_WAKE_UPb |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 = Generate reset when going from D3 to D0 mode<br>1 = Do NOT generate internal reset when going from D3 to D0 mode<br>(PQFP always wakes-up from D3 with RST) |    |   |   |   |   |   |   |   |   |   |   |
| o      | R/W | STANDBY_NOW        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1 = Force the chip to go into standby mode unconditionally                                                                                                      |    |   |   |   |   |   |   |   |   |   |   |
| p      | R/W | SUSPEND_NOW        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1 = Force the chip to go into suspend mode unconditionally                                                                                                      |    |   |   |   |   |   |   |   |   |   |   |
| q      | R   | PWR_MGT_STATUS     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Power management status (read only)<br>00 = On mode<br>01 = Standby mode<br>10 = Suspend mode<br>11 = Transition between Power Management modes                 |    |   |   |   |   |   |   |   |   |   |   |

### Description

This register controls the Power Management features implemented in RAGE XL.

### Usage

Three different power saving modes are supported: *On*, *Standby* and *Suspend*, with the power consumption decreasing from *On* to *Suspend* mode.

|      |     | POWER_MANAGEMENT_2   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A Index: 1D                                                                                                                                      |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
| XL   |     | u                    | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  | h  | g  | f  | e  | d  | c  | b  | a                                                                                                                                                           |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | XCLK_DISP_ALWAYS_ONb |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable stopping of primary display memory clock (XCLK_DISP):<br>(default = 0)<br>0 = XCLK_DISP is running always<br>1 = Stop XCLK_DISP when CRTC_ENABLE = 0 |    |   |   |   |   |   |   |   |   |   |   |

| Cont'd   |     | POWER_MANAGEMENT_2  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A Index: 1D                                                                                                                                                                                                                                                                                                                                                                                                              |    |   |   |   |   |   |   |   |   |   |   |
|----------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS     |     | 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 |
| XL       |     | u                   | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  | h  | g  | f  | e  | d  | c  | b  | a                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |   |   |   |   |   |   |   |   |   |   |
| <b>b</b> | R/W | XCLK_VID_ALWAYS_ONb |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable stopping of video capture and half frame buffer (HFB) memory clock (XCLK_VID): (default = 0)<br>0 = XCLK_VID is running always<br>1 = Stop XCLK_VID when (CAPTURE_EN or HFB_ACTIVE) = 0                                                                                                                                                                                                                                      |    |   |   |   |   |   |   |   |   |   |   |
| <b>c</b> | R/W | XCLK_SCL_ALWAYS_ONb |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable stopping of scaler/overlay memory clock (XCLK_SCL): (default = 0)<br>0 = XCLK_SCL is running always<br>1 = Stop XCLK_SCL when (SCALE_EN) = 0                                                                                                                                                                                                                                                                                 |    |   |   |   |   |   |   |   |   |   |   |
| <b>d</b> | R/W | XCLK_GUI_ALWAYS_ONb |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable stopping of GUI memory clock (XCLK_GUI): (default = 0)<br>0 = XCLK_GUI is running always<br>1 = Stop XCLK_GUI when 2D and 3D guien are inactive (same condition as GCP)                                                                                                                                                                                                                                                      |    |   |   |   |   |   |   |   |   |   |   |
| <b>e</b> | R/W | XCLK_SUB_ALWAYS_ONb |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable stopping of DVD subpicture memory clock (XCLK_SUB): (default = 0)<br>0 = XCLK_SUB is running always<br>1 = stop XCLK_SUB when (SUBPIC_ON) = 0                                                                                                                                                                                                                                                                                |    |   |   |   |   |   |   |   |   |   |   |
| <b>f</b> | R/W | MCLK_ALWAYS_ONb     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable stopping of MCLK: (default = 0)<br>0 = MCLK is running always<br>1 = Stop MCLK when (MPP_EN = 0, CAPTURE_EN = 0, I2C_SEL = 1, and GUI and HOST are idle)                                                                                                                                                                                                                                                                     |    |   |   |   |   |   |   |   |   |   |   |
| <b>g</b> | R/W | SS_EN               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable use of external spread spectrum chip (default=0)<br>0 = Disable external spread spectrum<br>1 = Enable external spread spectrum                                                                                                                                                                                                                                                                                              |    |   |   |   |   |   |   |   |   |   |   |
| <b>h</b> | R/W | BLON_DIGON_EN       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Controls mux for BLON (panel backlight) and DIGON (panel digital power) pins when these pins are shared with other functionality: (default=1)<br>0 = BLON and DIGON are used for other functionality<br>1 = BLON and DIGON features are enabled (see POWER_MANAGEMENT register)<br><b>Note:</b> This register bit does not currently apply to Rage XL and Mobile chips. This applies to RAGE XL and its derivatives.                |    |   |   |   |   |   |   |   |   |   |   |
| <b>i</b> | R/W | PM_DYN_XCLK_SYNC    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Synchronization condition for switching between XCLK speeds (i.e., when to make the decision for XCLK or PM_XCLK speed selection) (default = 2)<br>0 = Start of VBLANK (primary display only)<br>1 = Start of V2BLANK (secondary display only)<br>2 = Combination of VBLANK and V2BLANK (for both displays) as below:<br>(VBLANK and not VSYNC or not CRTC_ENABLE) and (V2BLANK and not V2SYNC or not CRTC2_ENABLE)<br>3 = Reserved |    |   |   |   |   |   |   |   |   |   |   |

| Cont'd | POWER_MANAGEMENT_2 |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A Index: 1D |                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |   |   |   |   |   |   |   |
|--------|--------------------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|
| BITS   | 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 |
| XL     | u                  | t                  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  | h  | g  | f  | e  | d  | c  | b  | a                      |                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |   |   |   |   |   |   |   |
| j      | R/W                | SEL_W4MS           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        | Wait 4 ms after suspend mode: (default = 1)                                                                                                                                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |
| k      | R/W                | PM_DYN_XCLK_EN     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        | Enable dynamic XCLK power saving mode: (default = 0)<br>0 = XCLK is always running at frequency defined by XCLK_SRC_SEL in CLOCK_CNTL register and corresponding PLL register settings<br>1 = XCLK dynamically changes between XCLK and PM_XCLK depending on activity. In this setting, PM_REFRESH_RATE and the power saving display settings (defined in PM_DSP_CONFIG and PM_DSP_ON_OFF) are used when running with PM_XCLK |   |   |   |   |   |   |   |   |   |   |
| l      | R/W                | PM_XCLK_ALWAYS     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        | Override forcing to use PM_XCLK rather than XCLK when PM_DYN_XCLK_EN = 1: (default = 0)<br>0 = XCLK depends on PM_DYN_XCLK_* activity registers (see below)<br>1 = XCLK = PM_XCLK always; uses slower XCLK regardless of activity                                                                                                                                                                                             |   |   |   |   |   |   |   |   |   |   |
| m      | R                  | PM_DYN_XCLK_STATUS |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        | Status of XCLK in power management mode<br>0 = Running off XCLK<br>1 = Running off PM_XCLK                                                                                                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |
| n      | R/W                | PCI_ACC_DIS        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        | When 1, disable I/O and MEM access through bus when in power management state, D1, D2 , D3                                                                                                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |   |   |
| o      | R/W                | PM_DYN_XCLK_DISP   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        | Enable slower XCLK (PM_XCLK) when primary display is active (CRTC_ENABLE = 1): (default = 0)<br>0 = Must use XCLK when active<br>1 = Can use PM_XCLK when active depending on other requesters' activity                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |   |   |
| p      | R/W                | PM_DYN_XCLK_VID    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        | Enable slower XCLK (PM_XCLK) when video is active (CAPTURE_EN = 1): (default = 0)<br>0 = Must use XCLK when active<br>1 = Can use PM_XCLK when active depending on other requesters' activity                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |   |   |
| q      | R/W                | PM_DYN_XCLK_HFB    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        | Enable slower XCLK (PM_XCLK) when half frame buffer is active (HFB_ACTIVE = 1): (default = 0)<br>0 = Must use XCLK when active<br>1 = Can use PM_XCLK when active depending on other requesters' activity                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |   |   |
| r      | R/W                | PM_DYN_XCLK_SCL    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        | Enable slower XCLK (PM_XCLK) when overlay scaler is active (SCALE_EN = 1): (default = 0)<br>0 = Must use XCLK when active<br>1 = Can use PM_XCLK when active depending on other requesters' activity                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |   |   |

| Cont'd   |     | POWER_MANAGEMENT_2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A Index: 1D                                                                                                                                                                                                                        |    |   |   |   |   |   |   |   |   |   |   |
|----------|-----|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS     |     | 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 |
| XL       |     | u                  | t  | s  | r  | q  | p  | o  | n  | m  | l  | k  | j  | i  | h  | g  | f  | e  | d  | c  | b  | a                                                                                                                                                                                                                                             |    |   |   |   |   |   |   |   |   |   |   |
| <b>s</b> | R/W | PM_DYN_XCLK_SUB    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable slower XCLK (PM_XCLK) when DVD subpicture is active (SUBPIC_ON = 1): (default = 0)<br>0 = Must use XCLK when active<br>1 = Can use PM_XCLK when active depending on other requesters' activity                                         |    |   |   |   |   |   |   |   |   |   |   |
| <b>t</b> | R/W | PM_DYN_XCLK_GUI    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable slower XCLK (PM_XCLK) when 2D/3D gui is active (same as GCP – based on gui state machine and host requests): (default = 0)<br>0 = Must use XCLK when active<br>1 = Can use PM_XCLK when active depending on other requesters' activity |    |   |   |   |   |   |   |   |   |   |   |
| <b>u</b> | R/W | PM_DYN_XCLK_HOST   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable slower XCLK (PM_XCLK) when host writes/reads are active: (default = 0)<br>0 = Must use XCLK when active<br>1 = Can use PM_XCLK when active depending on other requesters' activity                                                     |    |   |   |   |   |   |   |   |   |   |   |

## 8.9 Hardware Icon Registers

**Note:** The following Hardware Icon registers are NOT supported in RAGE XL.

(NOT supported in RAGE XL)

|      |     |                                                                                       | ICON_CLR0 |  |  |  |  |  |  |                                     |   |  |  |  |  |  |  |  |   |  |  |  | Offset: 0_2A, Index: A |  |  |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|---------------------------------------------------------------------------------------|-----------|--|--|--|--|--|--|-------------------------------------|---|--|--|--|--|--|--|--|---|--|--|--|------------------------|--|--|--|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 | XL        |  |  |  |  |  |  |                                     | c |  |  |  |  |  |  |  | b |  |  |  |                        |  |  |  | a |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | ICON_CLR0_B                                                                           |           |  |  |  |  |  |  | Blue Icon color 0, to internal DAC  |   |  |  |  |  |  |  |  |   |  |  |  |                        |  |  |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | ICON_CLR0_G                                                                           |           |  |  |  |  |  |  | Green Icon color 0, to internal DAC |   |  |  |  |  |  |  |  |   |  |  |  |                        |  |  |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | ICON_CLR0_R                                                                           |           |  |  |  |  |  |  | Red Icon color 0, to internal DAC   |   |  |  |  |  |  |  |  |   |  |  |  |                        |  |  |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

(NOT supported in RAGE XL)

|      |     |                                                                                       | ICON_CLR1 |  |  |  |  |  |  |                                     |   |  |  |  |  |  |  |  |   |  |  |  | Offset: 0_2A, Index: B |  |  |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|---------------------------------------------------------------------------------------|-----------|--|--|--|--|--|--|-------------------------------------|---|--|--|--|--|--|--|--|---|--|--|--|------------------------|--|--|--|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 | XL        |  |  |  |  |  |  |                                     | c |  |  |  |  |  |  |  | b |  |  |  |                        |  |  |  | a |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | ICON_CLR1_B                                                                           |           |  |  |  |  |  |  | Blue Icon color 0, to internal DAC  |   |  |  |  |  |  |  |  |   |  |  |  |                        |  |  |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | ICON_CLR1_G                                                                           |           |  |  |  |  |  |  | Green Icon color 0, to internal DAC |   |  |  |  |  |  |  |  |   |  |  |  |                        |  |  |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | ICON_CLR1_R                                                                           |           |  |  |  |  |  |  | Red Icon color 0, to internal DAC   |   |  |  |  |  |  |  |  |   |  |  |  |                        |  |  |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

(NOT supported in RAGE XL)

|      |     |                                                                                       | ICON_OFFSET |  |  |  |  |  |  |                                                              |   |  |  |  |  |  |  |  |   |  |  |  |  |  |  |  |  |  |  |  | Offset: 0_2A, Index: C |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|---------------------------------------------------------------------------------------|-------------|--|--|--|--|--|--|--------------------------------------------------------------|---|--|--|--|--|--|--|--|---|--|--|--|--|--|--|--|--|--|--|--|------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 | XL          |  |  |  |  |  |  |                                                              | b |  |  |  |  |  |  |  | a |  |  |  |  |  |  |  |  |  |  |  |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | ICON_OFFSET                                                                           |             |  |  |  |  |  |  | Icon address offset in terms of 64 bit words                 |   |  |  |  |  |  |  |  |   |  |  |  |  |  |  |  |  |  |  |  |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | BLANK_SCREEN1                                                                         |             |  |  |  |  |  |  | Blank the screen except for ICON on the primary display path |   |  |  |  |  |  |  |  |   |  |  |  |  |  |  |  |  |  |  |  |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

(NOT supported in RAGE XL)

|      |     |                                                                                       | ICON_HORZ_VERT_POSN |  |  |  |  |  |  |  |   |  |  |  |  |  |  |                          | Offset: 0_2A, Index: D |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|---------------------------------------------------------------------------------------|---------------------|--|--|--|--|--|--|--|---|--|--|--|--|--|--|--------------------------|------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 | b                   |  |  |  |  |  |  |  | a |  |  |  |  |  |  |                          |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XL   |     |                                                                                       |                     |  |  |  |  |  |  |  |   |  |  |  |  |  |  |                          |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | ICON_HORZ_POSN                                                                        |                     |  |  |  |  |  |  |  |   |  |  |  |  |  |  | Icon horizontal position |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | ICON_VERT_POSN                                                                        |                     |  |  |  |  |  |  |  |   |  |  |  |  |  |  | Icon vertical position   |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

(NOT supported in RAGE XL)

|      |     |                                                                                       | ICON_HORZ_VERT_OFF |  |  |  |  |  |  |  |   |  |  |  |  |  |  |                        | Offset: 0_2A, Index: E |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|---------------------------------------------------------------------------------------|--------------------|--|--|--|--|--|--|--|---|--|--|--|--|--|--|------------------------|------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 | b                  |  |  |  |  |  |  |  | a |  |  |  |  |  |  |                        |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XL   |     |                                                                                       |                    |  |  |  |  |  |  |  |   |  |  |  |  |  |  |                        |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | ICON_HORZ_OFF                                                                         |                    |  |  |  |  |  |  |  |   |  |  |  |  |  |  | Icon horizontal offset |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | ICON_VERT_OFF                                                                         |                    |  |  |  |  |  |  |  |   |  |  |  |  |  |  | Icon vertical offset   |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

(NOT supported in RAGE XL)

|      |     |                                                                                       | ICON2_CLR0 |  |  |  |  |  |  |  |   |  |  |  |  |  |  |                                     | Offset: 0_2A, Index: F |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|---------------------------------------------------------------------------------------|------------|--|--|--|--|--|--|--|---|--|--|--|--|--|--|-------------------------------------|------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 | c          |  |  |  |  |  |  |  | b |  |  |  |  |  |  |                                     | a                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XL   |     |                                                                                       |            |  |  |  |  |  |  |  |   |  |  |  |  |  |  |                                     |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | ICON2_CLR0_B                                                                          |            |  |  |  |  |  |  |  |   |  |  |  |  |  |  | Blue Icon color 0, to internal DAC  |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | ICON2_CLR0_G                                                                          |            |  |  |  |  |  |  |  |   |  |  |  |  |  |  | Green Icon color 0, to internal DAC |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | ICON2_CLR0_R                                                                          |            |  |  |  |  |  |  |  |   |  |  |  |  |  |  | Red Icon color 0, to internal DAC   |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

(NOT supported in RAGE XL)

|      |     |                                                                                       | ICON2_CLR1 |  |  |  |  |  |  |  |   |  |  |  |  |  |  |                                     | Offset: 0_2A, Index: 10 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|-----|---------------------------------------------------------------------------------------|------------|--|--|--|--|--|--|--|---|--|--|--|--|--|--|-------------------------------------|-------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 | c          |  |  |  |  |  |  |  | b |  |  |  |  |  |  |                                     | a                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XL   |     |                                                                                       |            |  |  |  |  |  |  |  |   |  |  |  |  |  |  |                                     |                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | ICON2_CLR1_B                                                                          |            |  |  |  |  |  |  |  |   |  |  |  |  |  |  | Blue Icon color 1, to internal DAC  |                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | ICON2_CLR1_G                                                                          |            |  |  |  |  |  |  |  |   |  |  |  |  |  |  | Green Icon color 1, to internal DAC |                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | ICON2_CLR1_R                                                                          |            |  |  |  |  |  |  |  |   |  |  |  |  |  |  | Red Icon color 1, to internal DAC   |                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

(NOT supported in RAGE XL)

|      |     |               | ICON2_OFFSET |    |    |    |    |    |    |    |    |                                                              |    |    |    |    |    |    | Offset: 0_2A, Index: 11 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
|------|-----|---------------|--------------|----|----|----|----|----|----|----|----|--------------------------------------------------------------|----|----|----|----|----|----|-------------------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |
| XL   |     |               |              |    |    |    |    |    |    |    |    | b                                                            |    |    |    |    |    |    |                         |    |    | a  |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| a    | R/W | ICON2_OFFSET  |              |    |    |    |    |    |    |    |    | Icon address offset in terms of 64 bit words                 |    |    |    |    |    |    |                         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| b    | R/W | BLANK_SCREEN2 |              |    |    |    |    |    |    |    |    | Blank the screen except for ICON on the primary display path |    |    |    |    |    |    |                         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |

(NOT supported in RAGE XL)

|      |     |                 | ICON2_HORZ_VERT_POSN |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    | Offset: 0_2A, Index: 12 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|------|-----|-----------------|----------------------|----|----|----|----|----|----|----|----|--------------------------|----|----|----|----|----|----|-------------------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| BITS |     | 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 |  |
| XL   |     |                 |                      |    |    |    |    |    |    |    |    | b                        |    |    |    |    |    |    |                         |    |    | a  |    |   |   |   |   |   |   |   |   |   |   |  |
| a    | R/W | ICON2_HORZ_POSN |                      |    |    |    |    |    |    |    |    | Icon horizontal position |    |    |    |    |    |    |                         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| b    | R/W | ICON2_VERT_POSN |                      |    |    |    |    |    |    |    |    | Icon vertical position   |    |    |    |    |    |    |                         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

(NOT supported in RAGE XL)

|      |     |                | ICON2_HORZ_VERT_OFF |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |    | Offset: 0_2A, Index: 13 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|------|-----|----------------|---------------------|----|----|----|----|----|----|----|----|------------------------|----|----|----|----|----|----|-------------------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| BITS |     | 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 |  |
| XL   |     |                |                     |    |    |    |    |    |    |    |    | b                      |    |    |    |    |    |    |                         |    |    | a  |    |   |   |   |   |   |   |   |   |   |   |  |
| a    | R/W | ICON2_HORZ_OFF |                     |    |    |    |    |    |    |    |    | Icon horizontal offset |    |    |    |    |    |    |                         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| b    | R/W | ICON2_VERT_OFF |                     |    |    |    |    |    |    |    |    | Icon vertical offset   |    |    |    |    |    |    |                         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Cont'd |     | LCD_MISC_CNTL      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A, Index: 14                                                                                                                                                                                                                 |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
|--------|-----|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|
| BITS   |     | 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 |  |  |  |  |  |
| XL     |     | i                  |    |    |    | h  | g  | f  | e  | d  |    | c  | b  |    |    |    |    |    | a  |                                                                                                                                                                                                                                         |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| f      | R/W | APC_EN             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable the use of APC algorithm. <b>MUST set to 0.</b>                                                                                                                                                                                  |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| g      | R/W | MONITOR_DET_EN     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable improved CRT detection circuitry<br>To be used with FORCE_DAC_SEL and FORCE_DAC_DATA                                                                                                                                             |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| h      | R/W | FORCE_DAC_DATA_SEL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Used to select which 24-bit D/A inputs will be forced with<br>FORCE_DAC_DATA value<br>00 = R = FORCE_DAC_DATA; G = B = 0<br>01 = G = FORCE_DAC_DATA; R = B = 0<br>10 = B = FORCE_DAC_DATA; R = G = 0<br>11 = R = G = B = FORCE_DAC_DATA |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| i      |     | FORCE_DAC_DATA     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Used for improved monitor detection (if MONITOR_DET_EN = 1)<br>The value written in this register will be forced directly to the input<br>of the CRT D/A converter                                                                      |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |

## 8.10 TMDS Registers

### 8.10.1 TMDS Encoder Registers

|      |     | TMDS_CNTL      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                                                                                                          | Index: 15 |   |   |   |   |   |   |
|------|-----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---|---|---|---|---|---|
| BITS |     | 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 |
| XL   |     | p              | o  | n  | m  | l  |    |    |    |    |    |    |    | k  |    |    |    |    | j  | i  | h  | g  | f  | e | d | c                                                                                                                                                                                        | b         | a |   |   |   |   |   |
| a    | R/W | PL_CTL0        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Control signal for TMDS (encoded in Green channel).                                                                                                                                      |           |   |   |   |   |   |   |
| b    | R/W | PL_CTL1        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Control signal for TMDS (encoded in Green channel).                                                                                                                                      |           |   |   |   |   |   |   |
| c    | R/W | PL_CTL2        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Control signal for TMDS (encoded in Red channel).                                                                                                                                        |           |   |   |   |   |   |   |
| d    | R/W | PL_CTL3        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Control signal for TMDS (encoded in Red channel).                                                                                                                                        |           |   |   |   |   |   |   |
| e    | R/W | PL_DEBUG_HSYNC |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Hsync signal for system debug on differential data pairs.                                                                                                                                |           |   |   |   |   |   |   |
| f    | R/W | PL_DEBUG_VSYNC |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Vsync signal for system debug on differential data pairs.                                                                                                                                |           |   |   |   |   |   |   |
| g    | R/W | PL_DEBUG_DE    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | DE signal for system debug on differential data pairs.                                                                                                                                   |           |   |   |   |   |   |   |
| h    | R/W | PL_DEBUG_EN    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | System debug enable on differential data pairs.                                                                                                                                          |           |   |   |   |   |   |   |
| i    | R/W | PL_CTL_FB_SEL  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Select input of CTL0 for TMDS:<br>00 - register value from iCTL0.<br>01 - external input.<br>10 - delayed iPLCTL0 which follows iPL_DE.<br>11 - delayed iPLCTL0 which follows iPL_VSYNC. |           |   |   |   |   |   |   |
| j    | R/W | PL_CTL_FB_DEL  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Select delay of PLCTL0 for TMDS:<br>00 - 0 clock delay.<br>01 - 1 clock delay.<br>10 - 2 clocks delay.<br>11 - 1 clock advance.                                                          |           |   |   |   |   |   |   |
| k    | R/W | SYNC_CHAR_EN   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Programmable sync characters enable. Each of the bit represents use of register defined sync characters. Bit X = 1 means iSYNC_CHARX is defined by register.                             |           |   |   |   |   |   |   |
| l    | R/W | SYNC_CONT      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | TMDS synchronization control (default 1)                                                                                                                                                 |           |   |   |   |   |   |   |
| m    | R/W | DPCUM_TST      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Dcbalancer test enable.                                                                                                                                                                  |           |   |   |   |   |   |   |
| n    | R/W | DPCUM_IN       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Dcbalancer test in.                                                                                                                                                                      |           |   |   |   |   |   |   |
| o    | R/W | PL_CRC_EN      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | TMDS CRC enable.                                                                                                                                                                         |           |   |   |   |   |   |   |
| p    | R/W | RB_SWITCH_EN   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Red and Blue data channel switch enable.                                                                                                                                                 |           |   |   |   |   |   |   |

|      |     |               | TMDS_SYNC_CHAR_SETA |    |    |    |    |    |    |    |    |    |    |                                                               |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Index: 16 |   |   |   |   |
|------|-----|---------------|---------------------|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----------|---|---|---|---|
| BITS |     | 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 |
| XL   |     | b             |                     |    |    |    |    |    |    |    |    |    |    | a                                                             |    |    |    |    |    |    |    |    |    |   |   |   |   |   |           |   |   |   |   |
| a    | R/W | PL_SYNC_CHAR0 |                     |    |    |    |    |    |    |    |    |    |    | TMDS sync character representing (00)<br>(default 1101010100) |    |    |    |    |    |    |    |    |    |   |   |   |   |   |           |   |   |   |   |
| b    | R/W | PL_SYNC_CHAR1 |                     |    |    |    |    |    |    |    |    |    |    | TMDS sync character representing (01)<br>(default 0101010100) |    |    |    |    |    |    |    |    |    |   |   |   |   |   |           |   |   |   |   |

|      |     |               | TMDS_SYNC_CHAR_SETB |    |    |    |    |    |    |    |    |    |    |                                                               |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Index: 17 |   |   |   |   |
|------|-----|---------------|---------------------|----|----|----|----|----|----|----|----|----|----|---------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----------|---|---|---|---|
| BITS |     | 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 |
| XL   |     | b             |                     |    |    |    |    |    |    |    |    |    |    | a                                                             |    |    |    |    |    |    |    |    |    |   |   |   |   |   |           |   |   |   |   |
| a    | R/W | PL_SYNC_CHAR2 |                     |    |    |    |    |    |    |    |    |    |    | TMDS sync character representing (10)<br>(default 0010101011) |    |    |    |    |    |    |    |    |    |   |   |   |   |   |           |   |   |   |   |
| b    | R/W | PL_SYNC_CHAR3 |                     |    |    |    |    |    |    |    |    |    |    | TMDS sync character representing (11)<br>(default 1010101011) |    |    |    |    |    |    |    |    |    |   |   |   |   |   |           |   |   |   |   |

|      |   |        | TMDS_SRC |    |    |    |    |    |    |    |    |    |    |                                      |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Index: 18 |   |   |   |   |
|------|---|--------|----------|----|----|----|----|----|----|----|----|----|----|--------------------------------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----------|---|---|---|---|
| BITS |   | 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 |
| XL   |   | b      |          |    |    |    |    |    |    |    |    |    |    |                                      |    |    |    |    |    |    |    |    |    |   |   |   |   |   |           |   |   |   |   |
| a    | R | CRCRGB |          |    |    |    |    |    |    |    |    |    |    | CRC block 30-bit output (read only). |    |    |    |    |    |    |    |    |    |   |   |   |   |   |           |   |   |   |   |

## 8.10.2 TMDS Testblock Registers

|      |     | PLTSTBLK_CNTL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Index: 19 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|------|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |
| XL   |     |               |    |    |    | i  |    |    |    |    |    |    |    | h  |    |    |    |    | g  | f  | e  | d         | c  | b | a |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| a    | R/W | PLTST_EN      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| b    | R/W | PLTST_STR_RST |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| c    | R/W | ERR_CHECK     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| d    | R/W | CLR_FLAGS     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| e    | R/W | ERR_HOLDb     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| f    | R/W | ODCK_SRC_SEL  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| g    | R/W | RSTCLR_PULSE  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| h    | R/W | RUN_LINE      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| i    | R/W | RUN_PIX       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

|      |     | SYNC_GEN_CNTL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Index: 1A |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|------|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |
| XL   |     | h             |    |    |    | g  |    |    |    | f  |    |    |    | e  |    |    |    |    | d  | c  | b  | a         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| a    | R/W | FST_SYNC_VAL  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| b    | R/W | SEC_SYNC_VAL  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| c    | R/W | THD_SYNC_VAL  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| d    | R/W | FOR_SYNC_VAL  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| e    | R/W | FST_SYNC_TIME |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

| Cont'd |     | SYNC_GEN_CNTL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                              |    |    |    | Index: 1A |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------------|----|----|----|-----------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS   |     | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XL     |     | h             |    |    |    | g  |    |    |    | f  |    |    |    | e  |    |    |    | d                                                                            |    | c  |    | b         |    | a |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| f      | R/W | SEC_SYNC_TIME |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Time when second sync pattern starts (second priority)<br>(default = 011100) |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| g      | R/W | THD_SYNC_TIME |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Time when third sync pattern starts (third priority)<br>(default = 101010)   |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| h      | R/W | FOR_SYNC_TIME |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Time when fourth sync pattern starts (least priority)<br>(default = 111000)  |    |    |    |           |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |

|      |     | PATTERN_GEN_SEED     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                 |    |    |    |    |    |   |   |   |   |   |   |   | Index: 1B |   |   |  |  |  |  |  |
|------|-----|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|-----------|---|---|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |
| XL   |     | XXXXXXXXXXXXXXXXXXXX |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                                                               |    |    |    |    |    |   |   |   |   |   |   |   |           |   |   |  |  |  |  |  |
| a    | R/W | PATTERN_SEED         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Pattern generator 24-bit seed value<br>001000100010001000100010 |    |    |    |    |    |   |   |   |   |   |   |   |           |   |   |  |  |  |  |  |

|      |   | PRI_ERR_PATTERN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                |    |    |    |    |    |   |   |   |   |   |   |   |           |   | Index: 1E |  |  |  |  |  |  |  |
|------|---|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|-----------|---|-----------|--|--|--|--|--|--|--|
| BITS |   | 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         |  |  |  |  |  |  |  |
| XL   |   | b               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                |    |    |    |    |    |   |   |   |   |   |   |   | Index: 1E |   |           |  |  |  |  |  |  |  |
| a    | R | PRI_ERR_PATTERN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Data pattern before error pattern (read only). |    |    |    |    |    |   |   |   |   |   |   |   |           |   |           |  |  |  |  |  |  |  |
| b    | R | SYNC_ERR_COUNT  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Sync error count (read only).                  |    |    |    |    |    |   |   |   |   |   |   |   |           |   |           |  |  |  |  |  |  |  |

|      |   | CUR_ERR_PATTERN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  |    |    |    |    |    |   |   |   |   |   |   |           |   |   | Index: 1F |  |  |  |  |  |  |  |
|------|---|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------|----|----|----|----|----|---|---|---|---|---|---|-----------|---|---|-----------|--|--|--|--|--|--|--|
| BITS |   | 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         |  |  |  |  |  |  |  |
| XL   |   | b               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  |    |    |    |    |    |   |   |   |   |   |   | Index: 1F |   |   |           |  |  |  |  |  |  |  |
| a    | R | CUR_ERR_PATTERN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Error data pattern (read only).  |    |    |    |    |    |   |   |   |   |   |   |           |   |   |           |  |  |  |  |  |  |  |
| b    | R | PAT_ERR_COUNT   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Pattern error count (read only). |    |    |    |    |    |   |   |   |   |   |   |           |   |   |           |  |  |  |  |  |  |  |

|      |   | PLTSTBLK_RPT    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Index: 20 |   |   |   |   |   |   |   |  |  |
|------|---|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----------|---|---|---|---|---|---|---|--|--|
| BITS |   | 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 |  |  |
| XL   |   | d               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |
| a    | R | SYNC_FAIL       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |
| b    | R | CRC_FAIL        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |
| c    | R | PATTERN_FAIL    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |
| d    | R | CUR_EXP_PATTERN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |

|      |   | SYNC_RPT      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Index: 21 |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|---|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |   | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XL   |   |               |    |    |    |    |    |    |    | d  |    |    |    | c  |    |    |    | b  |    |    |    | a  |    |   |   |   |           |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R | ERR_SYNC      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |           |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R | EXP_SYNC      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |           |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R | ERR_SYNC_LINE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |           |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d    | R | ERR_SYNC_PIX  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |           |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|      |   | CRC_PATTERN_RPT  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Index: 22 |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|---|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS |   | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XL   |   |                  |    | c  |    |    |    |    |    |    |    | b  |    |    |    | a  |    |    |    |    |    |    |    |   |   |   |           |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R | ERR_CRC_LINE     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |           |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R | ERR_PATTERN_LINE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |           |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R | ERR_PATTERN_PIX  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |           |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### 8.10.3 TMDS Transmitter Macro Registers

|      |     | PL_TRANSMITTER_CNTL |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                                                                                      |    |    |    |    |    |    |    |    |    |   |   | Index: 23 |   |   |   |   |   |   |   |  |  |  |  |  |  |
|------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|-----------|---|---|---|---|---|---|---|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |
| XL   |     | f                   |    |    |    |    |    |    |    |    |    |    |    | e                                                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |   |   | d         |   | c |   | b |   | a |   |  |  |  |  |  |  |
| a    | R/W | PPLLLEN             |    |    |    |    |    |    |    |    |    |    |    | TMDS PLL enable. The TMDS PLL can be powered down by holding this signal LOW. Useful when the TMDS drivers are not being used.                                                                                                       |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |  |  |  |  |
| b    | R/W | PPLL_RST            |    |    |    |    |    |    |    |    |    |    |    | TMDS PLL reset. This is the reset signal for the TMDS PLL. Holding this level-sensitive signal HIGH keeps the TMDS PLL in reset mode. The PLL will start the locking acquisition process once this signal becomes LOW (default = 1). |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |  |  |  |  |
| c    | R/W | PTSTEN              |    |    |    |    |    |    |    |    |    |    |    | Test modes enable. Holding these signals HIGH put the TMDS macro in test modes.                                                                                                                                                      |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |  |  |  |  |
| d    | R/W | REGSEL              |    |    |    |    |    |    |    |    |    |    |    | Selects outputs of PLREG:<br>00 - Outputs from channel 0.<br>01 - Outputs from channel 1.<br>10 - Outputs from channel 2.<br>11 - reserved.                                                                                          |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |  |  |  |  |
| e    | R/W | PTSTPIX             |    |    |    |    |    |    |    |    |    |    |    | Input test pixel data. These signals mux with PLPIX? [9:0] and replace them when PTSTEN [0] is being held at HIGH.                                                                                                                   |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |  |  |  |  |
| f    | R   | PLREG [R]           |    |    |    |    |    |    |    |    |    |    |    | Output of shift registers. These are the outputs of the 10 shift registers from one of the channels during test mode. (read only).                                                                                                   |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |  |  |  |  |

|      |     | PL_PLL_CNTL |    |    |    |    |    |    |    |    |    |    |    |                                                                                                |    |    |    |    |    |    |    |    |    |   |   | Index: 24 |   |   |   |   |   |   |   |  |  |  |  |  |  |
|------|-----|-------------|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---|---|-----------|---|---|---|---|---|---|---|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |
| XL   |     |             |    |    |    |    |    |    |    |    |    |    |    |                                                                                                |    |    |    |    |    |    |    |    |    |   |   |           | d |   | c |   | b |   | a |  |  |  |  |  |  |
| a    | R/W | PPPCP       |    |    |    |    |    |    |    |    |    |    |    | TMDS PLL charge-pump gain control.                                                             |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |  |  |  |  |
| b    | R/W | PPPVG       |    |    |    |    |    |    |    |    |    |    |    | TMDS PLL VCO gain control.                                                                     |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |  |  |  |  |
| c    | R/W | PPPDC       |    |    |    |    |    |    |    |    |    |    |    | TMDS PLL duty cycle control.                                                                   |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |  |  |  |  |
| d    | R/W | PPPVVS      |    |    |    |    |    |    |    |    |    |    |    | TMDS driver voltage swing control. Adjust swing amplitude from approximately 100 mV to 700 mV. |    |    |    |    |    |    |    |    |    |   |   |           |   |   |   |   |   |   |   |  |  |  |  |  |  |

**For Flat Panel DDC Support in Desktop chip only :**

|      |     | TEST_IO                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | Index: 28 |   |   |   |
|------|-----|----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----------|---|---|---|
| BITS |     | 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 |
| XL   |     |                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |           |   |   |   |
| a    | R/W | DFP_DDCCLK_DIR<br>(VIDEO_FLAG)   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |           |   |   |   |
| b    | R/W | DFP_DDCDAT_DIR<br>(VIDEO_FM_MEM) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |           |   |   |   |
| c    | R/W | DFP_DDCCLK_GPIO<br>(IN_ENAB)     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |           |   |   |   |
| d    | R/W | DFP_DDCDAT_GPIO<br>(IN_VSYNC_B)  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |           |   |   |   |

## 8.11 APC Registers

|      |     | APC_CNTL     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Offset: 0_2A, Index: 1C   |   |   |   |   |   |   |   |  |  |  |  |
|------|-----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---------------------------|---|---|---|---|---|---|---|--|--|--|--|
| BITS |     | 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 |  |  |  |  |
| XL   |     |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                           | e | d | c | b | a |   |   |  |  |  |  |
| a    | R/W | AGP_SR_CNTL  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Slew control for AGP pads |   |   |   |   |   |   |   |  |  |  |  |
| b    | R/W | EXTSENSE_AD  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | NOT supported             |   |   |   |   |   |   |   |  |  |  |  |
| c    | R/W | EXTSENSE_AO  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | NOT supported             |   |   |   |   |   |   |   |  |  |  |  |
| d    | R/W | APC_VIDEO_EN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | NOT supported             |   |   |   |   |   |   |   |  |  |  |  |
| e    | R/W | IP_MODE      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | NOT supported             |   |   |   |   |   |   |   |  |  |  |  |

**Note:** The following APC registers are NOT supported in RAGE XL.

(NOT supported in RAGE XL)

|      |     | APC_CTRL_IO   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Offset: 0_2A, Index: 27                                                                         |   |   |   |   |   |   |   |   |   |   |   |   |
|------|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |   |   |   |   |   |
| XL   |     | m             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                 | l | k | j | i | h | g | f | e | d | c | b | a |
| a    | R/W | VIRTUAL_CLOCK |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Virtual clock used to drive the apc block during the test mode                                  |   |   |   |   |   |   |   |   |   |   |   |   |
| b    | R/W | APC_IN_SEL    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Mux control signal<br>0 = APC input from normal data path<br>1 = APC input from registers       |   |   |   |   |   |   |   |   |   |   |   |   |
| c    | R/W | DP0_IN_SEL    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Mux control signal<br>0 = DP0 input from normal data path<br>1 = DP0 input from registers       |   |   |   |   |   |   |   |   |   |   |   |   |
| d    | R/W | DPBUF_IN_SEL  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Mux control signal<br>0 = DPBUF input from normal data path<br>1 = DPBUF input from registers   |   |   |   |   |   |   |   |   |   |   |   |   |
| e    | R/W | DP1_IN_SEL    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Mux control signal<br>0 = DP1 input from normal data path<br>1 = DP1 input from registers       |   |   |   |   |   |   |   |   |   |   |   |   |
| f    | R/W | OUTBUF_IN_SEL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Mux control signal<br>0 = OUTBUF input from normal data path<br>1 = OUTBUF input from registers |   |   |   |   |   |   |   |   |   |   |   |   |

| Cont'd | APC_CTRL_IO |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |                                                                                                                  |    |    |    |    |   |   | Offset: 0_2A, Index: 27 |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
|--------|-------------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------|------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|---|-------------------------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|
| BITS   | 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 |  |  |  |  |  |  |  |  |  |
| XL     | m           |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    | l k j i h g f e d c b a |                                                                                                                  |    |    |    |    |   |   |                         |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| g      | R/W         | DP0_ERR_IN_SEL      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Mux control signal<br>0 = DP0 reads the error from the line buffers<br>1 = DP0 reads the error from registers    |    |    |    |    |   |   |                         |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| h      | R/W         | DP1_ERR_IN_SEL      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Mux control signal<br>0 = DP1 reads the error from the line buffers<br>1 = DP1 reads the error from registers    |    |    |    |    |   |   |                         |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| i      | R/W         | APCSYNC_IN_SEL      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Mux control signal<br>0 = APCSYNC input from normal input<br>1 = APCSYNC input from registers                    |    |    |    |    |   |   |                         |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| j      | R/W         | TEST_MODE_MASTER    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Master control bit for the test mode<br>0 = Test mode disabled<br>1 = Test mode enabled                          |    |    |    |    |   |   |                         |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| k      | R/W         | DP1_DEBUG           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | 0 = ALL DP1 control signals comes from APC_SYNC<br>1 = ALL DP1 control signals comes from the DP1_DEBUG register |    |    |    |    |   |   |                         |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| l      | R/W         | DP0_DEBUG           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | 0 = ALL DP0 control signals comes from APC_SYNC<br>1 = ALL DP0 control signals comes from the DP0_DEBUG register |    |    |    |    |   |   |                         |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| m      | R/W         | RED_ERR_INPUT[15:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Red color of the line buffer output to DP0 or DP1 memory input                                                   |    |    |    |    |   |   |                         |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |

(NOT supported in RAGE XL)

|      | TEST_IO |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                |    |    |    |    |   |   |   | Offset: 0_2A, Index: 28 |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------|---------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------|----|----|----|----|---|---|---|-------------------------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| BITS | 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 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| XL   | h       |                     | g  |    |    |    | f  |    |    |    |    |    | e  |    | d  |    | c  |                                                | b  |    |    |    | a |   |   |                         |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| a    | R       | RED_DATA_INPUT[7:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Red color test input data                      |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| b    | R       | VIDEO_FLAG          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Video flag bit for all colors during test mode |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| c    | R       | VIDEO_FM_MEM        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Video flag to DP0 or DP1 memory input          |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| d    | R       | IN_ENAB             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Data input enable signal for APSCSYNC          |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| e    | R       | IN_VSYNC_B          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Vsync signal for APSCSYNC                      |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| f    | R       | DPBUF_OUT[6:0]      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DP buffer data output                          |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Cont'd |   | TEST_IO       |    |    |    |    |    |    |    |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Offset: 0_2A, Index: 28 |   |   |   |   |   |   |   |  |  |  |  |  |
|--------|---|---------------|----|----|----|----|----|----|----|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-------------------------|---|---|---|---|---|---|---|--|--|--|--|--|
| BITS   |   | 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 |  |  |  |  |  |
| XL     |   | h             |    | g  |    |    |    | f  |    |                           |    |    |    |    |    | e  |    | d  | c  | b  |    |    |    |   |   |                         |   | a |   |   |   |   |   |  |  |  |  |  |
| g      | R | DP1_OUT       |    |    |    |    |    |    |    | DP1 data output           |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                         |   |   |   |   |   |   |   |  |  |  |  |  |
|        |   | OBUF_OUT[3:0] |    |    |    |    |    |    |    | Output buffer data output |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                         |   |   |   |   |   |   |   |  |  |  |  |  |

|      |   | TEST_OUTPUTS        |    |    |    |    |    |    |    |                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Offset: 0_2A, Index: 28 |   |   |   |   |   |   |
|------|---|---------------------|----|----|----|----|----|----|----|-------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------------------------|---|---|---|---|---|---|
| BITS |   | 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 |
| XL   |   | g                   |    |    |    |    |    |    |    | f                                         |    |    |    |    |    |    |    | e  |    | d  | c  | b  |    |   |   |   |                         |   |   | a |   |   |   |
| a    | R | RED_INPUT[8:0]      |    |    |    |    |    |    |    | Red data going into the apc block         |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |
| b    | R | VFLAG_TO_MEM_BY_DP0 |    |    |    |    |    |    |    | Video flag value written to memory by DP0 |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |
| c    | R | VFLAG_TO_MEM_BY_DP1 |    |    |    |    |    |    |    | Video flag value written to memory by DP1 |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |
| d    | R | VFLAG_FM_MEM_TO_DP0 |    |    |    |    |    |    |    | Video flag value read from memory by DP0  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |
| e    | R | VFLAG_FM_MEM_TO_DP1 |    |    |    |    |    |    |    | Video flag value read from memory by DP1  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |
| f    | R | DP0_OUT[6:0]        |    |    |    |    |    |    |    | DP0 data output                           |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |
| g    | R | INBUF_OUT[8:0]      |    |    |    |    |    |    |    | Input buffer data output                  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |

|      |   | DP1_MEM_ACCESS    |    |    |    |    |    |    |    |                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Offset: 0_2A, Index: 2A |   |   |   |   |   |   |
|------|---|-------------------|----|----|----|----|----|----|----|-------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------------------------|---|---|---|---|---|---|
| BITS |   | 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 |
| XL   |   | b                 |    |    |    |    |    |    |    |                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | a                       |   |   |   |   |   |   |
| a    | R | DP1_MEM_IN[15:0]  |    |    |    |    |    |    |    | DP1 data input from the line buffer |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |
| b    | R | DP1_MEM_OUT[15:0] |    |    |    |    |    |    |    | DP1 data output to the line buffer  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |

|      |   | DP0_MEM_ACCESS   |    |    |    |    |    |    |    |                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | Offset: 0_2A, Index: 2B |   |   |   |   |   |   |
|------|---|------------------|----|----|----|----|----|----|----|-------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-------------------------|---|---|---|---|---|---|
| BITS |   | 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 |
| XL   |   | b                |    |    |    |    |    |    |    |                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | a                       |   |   |   |   |   |   |
| a    | R | DP0_MEM_IN[15:0] |    |    |    |    |    |    |    | DP0 data input from the line buffer |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |

| Cont'd | DP0_MEM_ACCESS |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |   |   |   | Offset: 0_2A, Index: 2B |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
|--------|----------------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------|----|----|----|----|---|---|---|-------------------------|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|
| BITS   | 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 |  |  |  |  |  |  |  |  |  |
| XL     | b              |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a  |                                    |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| b      | R              | DP0_MEM_OUT[15:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DP0 data output to the line buffer |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |

|      |     | DP0_DEBUG_A         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                        |    |    |    |    |    |   |   |   |   | Offset: 0_2A, Index: 2C |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
|------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------------------------------------------|----|----|----|----|----|---|---|---|---|-------------------------|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|
| BITS |     | 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 |  |  |  |  |  |  |  |  |  |  |
| XL   |     | l                   | k  | j  | i  | h  |    |    |    |    |    |    |    | g  | f  | e  | d  | c                                                                                                      | b  | a  |    |    |    |   |   |   |   |                         |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| a    | R/W | RANDERR_R[5:0]      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Random error: (default = 0)                                                                            |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| b    | R/W | NIBBLE_SELECT[1:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Nibble select: (default = 0)                                                                           |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| c    | R/W | RELX_QUANTPIX[1:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | X position of the input pixel: (default = 0)                                                           |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| d    | R/W | RELX_ACC_ROW[1:0]   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | X position of the input pixel: (default = 0)                                                           |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| e    | R/W | RELX_PARTERR[1:0]   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Partition error: (default = 0)                                                                         |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| f    | R/W | RELY_ACC_ROW[1:0]   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Y position of the input pixel: (default = 0)                                                           |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| g    | R/W | RELY_PARTERR[1:0]   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Y position of the input pixel: (default = 0)                                                           |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| h    | R   | PREV_PIX_EDATA[8:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Y position of the input pixel: (default = N/A)                                                         |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| i    | R/W | FIRST_ROW_DP0       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Default = 0<br>0 = Not first row<br>1 = First row                                                      |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| j    | R/W | LD_FM_MEM_DP0       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Default = 0<br>0 = Not load memory to DP0<br>1 = Load memory to DP0                                    |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| k    | R/W | LD_FM_MEM_DP0_1ST   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Default = 0<br>0 = Not first time load to DP0<br>1 = First time load to DP0                            |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| l    | R/W | DP0_MEM_SHIFT_RUN   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Default = 0<br>0 = Do not enable shifting the data registers<br>1 = Enable shifting the data registers |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |

|      |   | DP0_DEBUG_B             |    |    |    |    |    |    |    |    |    |    |    |                                     |    |    |    |    |    |    |    | Offset: 0_2A, Index: 2D |    |   |   |   |   |   |   |   |   |   |   |
|------|---|-------------------------|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------|----|----|----|----|----|----|----|-------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS |   | 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 |
| XL   |   | e                       |    |    |    |    |    |    |    | d  |    |    |    |                                     |    | c  | b  | a  |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |
| a    | R | PIXEL_TARGET_PIPE[13:0] |    |    |    |    |    |    |    |    |    |    |    | Pixel Target signal in quantpix.arc |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |
| b    | R | VFLAG_ROW               |    |    |    |    |    |    |    |    |    |    |    | Video flag for a row in dp0.arc     |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |
| c    | R | STOREEDDATA_VFLAG       |    |    |    |    |    |    |    |    |    |    |    | Stored error video flag in dp0.arc  |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |
| d    | R | ACCUM_ROW_EDATA[6:0]    |    |    |    |    |    |    |    |    |    |    |    | Accumulated Error signal in dp0.arc |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |
| e    | R | NEW_EDATA[8:0]          |    |    |    |    |    |    |    |    |    |    |    | New Error signal in dp0.arc         |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |

|      |     | DP1_DEBUG_A         |    |    |    |    |    |    |    |    |    |    |    |                                                 |    |    |    |    |    |    |    | Offset: 0_2A, Index: 2E |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|------|-----|---------------------|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------|----|----|----|----|----|----|----|-------------------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| BITS |     | 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 |  |  |  |  |
| XL   |     | j                   | i  | h  | g  | f  | e  | d  |    |    |    |    |    | c                                               | b  |    |    |    |    |    | a  |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| a    | R/W | RANDOM_PHASE[5:0]   |    |    |    |    |    |    |    |    |    |    |    | Random phase value                              |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| b    | R/W | ACCEL_FRM_CTR[5:0]  |    |    |    |    |    |    |    |    |    |    |    | Acceleration frame counter for graphics mode    |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| c    | R/W | VIDEO_FRM_CTR[3:0]  |    |    |    |    |    |    |    |    |    |    |    | Acceleration frame counter for video mode       |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| d    | R   | PH_INCR_PIPE_1[6:0] |    |    |    |    |    |    |    |    |    |    |    | Phase Increment pipeline 1 signal in bestph.arc |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| e    | R/W | LD_FROM_MEM         |    |    |    |    |    |    |    |    |    |    |    | Load CAM state value from line buffer           |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| f    | R   | PH_SPREAD_PIPE[2:0] |    |    |    |    |    |    |    |    |    |    |    | Phase Spread signal in bestph.arc               |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| g    | R/W | RESET_CAM           |    |    |    |    |    |    |    |    |    |    |    | Clear CAM state                                 |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| h    | R/W | TAIL_SHIFT_HALT     |    |    |    |    |    |    |    |    |    |    |    | Tail shift control for late writing             |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| i    | R/W | APC_RESET           |    |    |    |    |    |    |    |    |    |    |    | Reset APC                                       |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| j    | R   | ZERO_FREQ_PIPE_0    |    |    |    |    |    |    |    |    |    |    |    | Zero frequency pipeline 0 signal in bestph.arc  |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

|      |   | DP1_DEBUG_B             |    |    |    |    |    |    |    |    |    |    |    |                                          |    |    |    |    |    |    |    | Offset: 0_2A, Index: 2F |    |   |   |   |   |   |   |   |   |   |   |
|------|---|-------------------------|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------|----|----|----|----|----|----|----|-------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS |   | 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 |
| XL   |   | j                       | i  | h  | g  | f  | e  | d  |    |    |    |    |    | c                                        | b  |    |    |    |    |    | a  |                         |    |   |   |   |   |   |   |   |   |   |   |
| a    | R | BEST_PHASE_PRE_MOD[6:0] |    |    |    |    |    |    |    |    |    |    |    | Best phase pre-mode signal in bestph.arc |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |

| Cont'd | DP1_DEBUG_B |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A, Index: 2F |                                                  |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
|--------|-------------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------|--------------------------------------------------|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|
| BITS   | 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 |  |  |  |  |  |
| XL     |             | j                    | i  | h  | g  | f  | e  |    |    |    | d  | c  |    |    |    | b  | a  |    |    |    |                         |                                                  |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| b      | R           | CUR_MATCH_LOC_PIPE_0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Matched location pipeline 0 signal in bestph.arc |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| c      | R           | TIME_PHASE[6:0]      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Time phase signal in outward.arc                 |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| d      | R           | NEW_ENTRY_PIPE_0     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | New entry pipeline 0 signal in bestph.arc        |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| e      | R           | BEST_PHASE[5:0]      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Best phase signal in bestph.arc                  |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| f      | R           | ZERO_FREQ_PIPE_1     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Zero frequency pipeline 1 signal in bestph.arc   |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| g      | R           | FIX_PH_FLAG_PIPE_0   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Fixed Phase flag pipeline 0 signal in bestph.arc |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| h      | R           | KEY_COMP_PIPE_1[2:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Key component pipeline 1 signal in bestph.arc    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| i      | R           | FOUND_MATCH_PIPE_0   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Found match pipeline 0 signal in bestph.arc      |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| j      | R           | PH_NOISE_PIPE[2:0]   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Phase noise pipeline signal in bestph.arc        |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |

| Cont'd | DPCTRL_DEBUG_A |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A, Index: 30 |                                |   |   |   |   |   |   |   |   |   |   |  |
|--------|----------------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------|--------------------------------|---|---|---|---|---|---|---|---|---|---|--|
| BITS   | 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 |  |
| XL     |                | h                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |                                |   |   |   |   |   |   |   |   |   |   |  |
| a      | R              | INBUF_WRADDR_B[5:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Input buffer write address     |   |   |   |   |   |   |   |   |   |   |  |
| b      | R              | INBUF_WEN_B         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Input buffer write enable      |   |   |   |   |   |   |   |   |   |   |  |
| c      | R              | INBUF_REN_B         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Input buffer read enable       |   |   |   |   |   |   |   |   |   |   |  |
| d      | R              | INBUF_RDADDR_B[5:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Input buffer read address      |   |   |   |   |   |   |   |   |   |   |  |
| e      | R              | DPBUF_WEN_B         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Data path buffer write enable  |   |   |   |   |   |   |   |   |   |   |  |
| f      | R              | DPBUF_REN_B         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Data path buffer read enable   |   |   |   |   |   |   |   |   |   |   |  |
| g      | R              | DPBUF_WRADDR_B[4:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Data path buffer write address |   |   |   |   |   |   |   |   |   |   |  |
| h      | R              | DPBUF_RDADDR_B[4:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         | Data path buffer read address  |   |   |   |   |   |   |   |   |   |   |  |

|      |   | DPCTRL_DEBUG_B      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A, Index: 31     |    |   |   |   |   |   |   |   |   |   |   |  |
|------|---|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|---|---|---|---|---|---|---|---|---|---|--|
| BITS |   | 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 |  |
| XL   |   |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | g                           | f  | e | d |   |   |   | c | b | a |   |   |  |
| a    | R | OBUF_WRAADDR_B[5:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Output buffer write address |    |   |   |   |   |   |   |   |   |   |   |  |
| b    | R | OBUF_WEN_B          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Output buffer write enable  |    |   |   |   |   |   |   |   |   |   |   |  |
| c    | R | OBUF_REN_B          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Output buffer read enable   |    |   |   |   |   |   |   |   |   |   |   |  |
| d    | R | OBUF_RDADDR_B[5:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Output buffer read address  |    |   |   |   |   |   |   |   |   |   |   |  |
| e    | R | LD_INPUT_PIX_B      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Control signal to MEMBLK    |    |   |   |   |   |   |   |   |   |   |   |  |
| f    | R | LD_QUANT_PIX_DP1_B  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Control signal to MEMBLK    |    |   |   |   |   |   |   |   |   |   |   |  |
| g    | R | E_LD_OUTBUF_B       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Control signal to MEMBLK    |    |   |   |   |   |   |   |   |   |   |   |  |

|      |   | MEMBLK_DEBUG     |    |    |    |    |    |    |    |    |    |    |    |                                  |    |    |    |    |    |    |    | Offset: 0_2A, Index: 32 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|------|---|------------------|----|----|----|----|----|----|----|----|----|----|----|----------------------------------|----|----|----|----|----|----|----|-------------------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| BITS |   | 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 |  |  |  |  |
| XL   |   | i h g f e d c    |    |    |    |    |    |    |    |    |    |    |    | b                                |    |    |    |    |    | a  |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| a    | R | MEM0_ADDR_B[7:0] |    |    |    |    |    |    |    |    |    |    |    | Line buffer 0 address            |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| b    | R | MEM1_ADDR_B[7:0] |    |    |    |    |    |    |    |    |    |    |    | Line buffer 1 address            |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| c    | R | MEM0_CE_B        |    |    |    |    |    |    |    |    |    |    |    | Line buffer 0 chip enable        |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| d    | R | MEM1_CE_B        |    |    |    |    |    |    |    |    |    |    |    | Line buffer 1 chip enable        |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| e    | R | MEM0_RW_B        |    |    |    |    |    |    |    |    |    |    |    | Line buffer 0 read/write control |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| f    | R | MEM1_RW_B        |    |    |    |    |    |    |    |    |    |    |    | Line buffer 1 read/write control |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| g    | R | DP0_MEM_RD_B     |    |    |    |    |    |    |    |    |    |    |    | Control signal to DP0            |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| h    | R | DP0_LSTMEM_RD_B  |    |    |    |    |    |    |    |    |    |    |    | Control signal to DP0            |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
| i    | R | CAM_TAIL_SHIFT_B |    |    |    |    |    |    |    |    |    |    |    | Control signal to DP1            |    |    |    |    |    |    |    |                         |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

|      |     | SCRATCH_PAD_4 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A, Index: 33                  |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
| XL   |     |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                                        |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | SCRATCH_PAD_4 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Scratch pad register for BIOS/driver use |    |   |   |   |   |   |   |   |   |   |   |

|      |     | SCRATCH_PAD_5 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Offset: 0_2A, Index: 34                  |    |   |   |   |   |   |   |   |   |   |   |
|------|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| BITS |     | 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 |
| XL   |     |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                                        |    |   |   |   |   |   |   |   |   |   |   |
| a    | R/W | SCRATCH_PAD_5 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Scratch pad register for BIOS/driver use |    |   |   |   |   |   |   |   |   |   |   |

|      |     |               | SCRATCH_PAD_6 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          |   | Offset: 0_2A, Index: 35 |   |   |   |   |   |
|------|-----|---------------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------------------------------|---|-------------------------|---|---|---|---|---|
| BITS |     | 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 |
| XL   |     | a             |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          |   |                         |   |   |   |   |   |
| a    | R/W | SCRATCH_PAD_6 |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Scratch pad register for BIOS/driver use |   |                         |   |   |   |   |   |

|      |     |               | SCRATCH_PAD_7 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | Offset: 0_2A, Index: 36 |   |   |   |   |   |   |
|------|-----|---------------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------------------------------|-------------------------|---|---|---|---|---|---|
| BITS |     | 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 |
| XL   |     | a             |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          |                         |   |   |   |   |   |   |
| a    | R/W | SCRATCH_PAD_7 |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Scratch pad register for BIOS/driver use |                         |   |   |   |   |   |   |

|      |     |               | SCRATCH_PAD_8 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          | Offset: 0_2A, Index: 37 |   |   |   |   |   |   |
|------|-----|---------------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------------------------------|-------------------------|---|---|---|---|---|---|
| BITS |     | 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 |
| XL   |     | a             |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                          |                         |   |   |   |   |   |   |
| a    | R/W | SCRATCH_PAD_8 |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Scratch pad register for BIOS/driver use |                         |   |   |   |   |   |   |

(NOT supported in RAGE XL)

|      |     |          | APC_LUT_KL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                      |   | Offset: 0_2A, Index: 38 |   |   |   |   |   |
|------|-----|----------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------------------------------------------------------|---|-------------------------|---|---|---|---|---|
| BITS |     | 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 |
| XL   |     | b        |            |    |    |    |    |    |    |    |    |    |    | a  |    |    |    |    |    |    |    |    |    |   |   |                                                      |   |                         |   |   |   |   |   |
| a    | R/W | VIDPAT_K |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Lower 16-bit of VidPattern (11): (default = 16#7757) |   |                         |   |   |   |   |   |
| b    | R/W | VIDPAT_L |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Lower 16-bit of VidPattern (12): (default = 16#7777) |   |                         |   |   |   |   |   |

(NOT supported in RAGE XL)

|      |     |          | APC_LUT_MN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                      |    |    |    |    |    |   |   |   |   | Offset: 0_2A, Index: 39 |   |   |   |   |   |
|------|-----|----------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------------------|----|----|----|----|----|---|---|---|---|-------------------------|---|---|---|---|---|
| BITS |     | 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 |
| XL   |     | b        |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                                                    |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |
| a    | R/W | VIDPAT_M |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Lower 16-bit of VidPattern (13): (default = 16#7f77) |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |
| b    | R/W | VIDPAT_N |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Lower 16-bit of VidPattern (14): (default = 16#7f77) |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |

(NOT supported in RAGE XL)

|      |     |          | APC_LUT_OP |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                     |    |    |    |    |    |   |   |   |   | Offset: 0_2A, Index: 3A |   |   |   |   |   |
|------|-----|----------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------------------|----|----|----|----|----|---|---|---|---|-------------------------|---|---|---|---|---|
| BITS |     | 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 |
| XL   |     | b        |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | a                                                   |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |
| a    | R/W | VIDPAT_O |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Lower 16-bit of VidPattern(15): (default = 16#ff7f) |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |
| b    | R/W | VIDPAT_P |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Lower 16-bit of VidPattern(16): (default = 16#ffff) |    |    |    |    |    |   |   |   |   |                         |   |   |   |   |   |

## 8.12 Video and Graphics Alpha Blending Registers

Alpha blinder is part of the GRAPHICS data pipeline in the DAC and is sensitive to the keyer. If the keyer circuit selects GRAPHICS data, the output is from the alpha blinder. However, if the keyer circuit selects VIDEO, then the output is from the regular VIDEO data.

The alpha blinder can be turned on or off with the selection of a register bit. So if the alpha blinder is turned off, this only means the alpha blinder is bypassed and the regular GRAPHICS data goes to the keyer circuit.

|      |     |              | ALPHA BLENDING |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                    |    |    |    |    |    |   |   |   | Offset: 0_2A, Index: 25 |   |   |   |   |   |   |
|------|-----|--------------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|---|---|---|-------------------------|---|---|---|---|---|---|
| BITS |     | 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 |
| XL   |     |              |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                    |    |    |    |    |    |   |   |   | d                       |   | c | b | a |   |   |
| a    | R/W | ALPHA_BLD_EN |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Enable the alpha blending of video and graphics:<br>(default = 0)<br>0 = Disable video and graphics alpha blending<br>1 = Enable video and graphics alpha blending |    |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |
|      |     |              |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                                                                                    |    |    |    |    |    |   |   |   |                         |   |   |   |   |   |   |

| Cont'd |     | ALPHA BLENDING |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Offset: 0_2A, Index: 25                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |
|--------|-----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|
| BITS   |     | 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 |
| XL     |     |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |                                                                                                                                                                                                                                                                | d |   | c | b | a |   |   |
| b      | R/W | YCBCR_BYPASS   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Enable the RGB to YcrCb conversion: (default = 0)<br>0 = Enable RGB to YCbCr conversion<br>1 = Bypass RGB to YCbCr conversion                                                                                                                                  |   |   |   |   |   |   |   |
| c      | R/W | ALPHA_LOAD     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | This bit is to update the alpha value.<br>0 - Uses alpha value from the graphics stream (default)<br>1 - Ignores alpha value from the graphics stream and uses alpha from ALPHA_VALUE field.                                                                   |   |   |   |   |   |   |   |
| d      | R/W | ALPHA_VALUE    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | Alpha values indicate the scale of the blending of each component.<br>0 - completely video (default value)<br>15 - completely graphics<br>Note: when using alpha value from the graphics stream, alpha is taken from the upper nibble of ARGB8888 (bits 31-28) |   |   |   |   |   |   |   |

This page intentionally left blank.

# **Appendix A**

## *Revision History*

---

### **A.1 Revision 0.04 (Jun 1999)**

- Modified bit 27 of POWER\_MANAGEMENT in Chapter 8.
- Modified bit 1 and bit 31 of HW\_DEBUG in Chapter 4.
- Removed “Not supported in RAGE XL/XC” from DLL2\_CNTL in Chapter 4, i.e., this register **is** supported.

### **A.2 Revision 0.05 (Aug 1999)**

- Modified bit 9 AND 10 of CUSTOM\_MACRO\_CNTL in Chapter 4.
- Modified bit 3 and bit 30 of HW\_DEBUG in Chapter 4.
- Changed V2PLL\_CNTL to HW\_DEBUG\_EXT under PLL registers under CLOCK\_CNTL.

### **A.3 Revision 0.06 (Aug 1999)**

- Made bit 2 reserved and modified bit 4 of HW\_DEBUG\_EXT in Chapter 4.

### **A.4 Revision 0.07 (Aug 1999)**

- Modified bit 21 of HW\_DEBUG in Chapter 4.

### **A.5 Revision 0.08 (Dec 1999)**

- Section 4.1.2 Scratch Pad Registers - Bit 13 changed from DACSPEN to BUS\_PCI\_READ\_RETRY\_EN. Corresponding description modified to be:
  - Enable retry for PCI read transfers: (default = 0)
  - 0 = Normal operation (reads will hold bus until complete)
  - 1 = Enable retry cycle in PCI (reads will retry when timeout counter expires).
- Table 4-5 ASIC ID - added entries 26h and 27h.
- Section 4.1.8 Configuration Registers - for register CONFIG\_STAT\_0, Bits 21 and 23, added “Not supported”.

- Section 4.2.7 PLL Control Registers - for register HW\_DEBUG\_EXT, bit 4, changed the default value to be 0.
- Section 4.2.2 Shadowed and Second CRTC Registers - for register CRTC\_INT\_CNTL, bit 31, R and W - removed “NOT supported”.
- Chapter 6 Host Interface - First table (Descriptions for different Device IDs) - removed RAGE XC column; Table 6-1 ASIC IDs - added entries for 26h and 27h; modified 25h entry to be 25h/65h with a description of TSMC B21/B22.
- All references to XC have been removed.