

# RGB526/RGB526DB

170/220 MHz High Performance Palette DAC

# **Product Description**

The RGB526™ and RGB526DB™ High Performance Palette DACs from IBM bring high speed and advanced features for high-resolution true-color graphics subsystems to the mainstream market. The RGB526DB's double-buffered pixel modes enhance the display of 3D and digital video images. The translucent cursor clears the way to improved graphical user interface functionality. Pixel resynchronization circuitry eliminates the susceptibility to control signal timing variations. Implemented in IBM's CMOS technology with video clocks up to 220 MHz, the RGB526 and RGB526DB are pin and register compatible with the RGB524 and RGB624.

The RGB526 and RGB526DB provide vibrant color with unsurpassed image stability and bright, flicker-free display on large-screen, high-resolution monitors.

# **Functional Block Diagram**



# **Product Highlights**

- 170, 220 MHz operation
- □ RGB524 and RGB624 pin and register compatible
- ☐ 64/32-bit wide pixel data bus
- ☐ Double-buffered pixels for 3D and digital video
- □ Keyed overlays
- ☐ Fine-grained PLL programming optimizes display
- ☐ Pixel resynchroniztion ensures integrity of all display modes
- $\Box$  Display modes up to  $1600 \times 1280$
- ☐ Large Screen ISO-compliant refresh rates
- □ Packed 24-bit pixels
- □ 4/8/16/24/32-bits per pixel
- □ Direct color
- □ Gamma correction
- □ 256-shade gray scale
- ☐ Three 256x8 color palette RAMs
- ☐ Anti-sparkle circuitry
- ☐ Per-pixel palette bypass control
- □ Palette paging
- ☐ Triple monotonic 8-bit DACs
- ☐ Two on-chip clock generators
- ☐ 64x64/32x32 translucent hardware cursor
- □ 100 MHz 8-bit VGA data input
- □ 24-bit color border
- On-chip diagnostic functions
- ☐ Low-power 3.3V operation
- □ 5V-tolerant inputs
- ☐ Power-down modes
- □ 144-pin QFP package
- **O.8 μm CMOS**

# **Applications**

- □ Graphical user interfaces
- Business graphics
- ☐ 3D Games and virtual reality
- □ Digital Video
- □ CAD/CAM
- ☐ Medical Imaging
- ☐ Scientific Visualization



# **Table of Contents**

| 1.0 | Mici | roprocessor Access                  | 1  |     | 5.6 | 16 BPP Double Buffered             |    |
|-----|------|-------------------------------------|----|-----|-----|------------------------------------|----|
|     | 1.1  | VGA Access                          |    |     |     | (RGB526DB Only)                    | 13 |
|     |      | 1.1.1 Palette                       |    |     | 5.7 | 24 BPP                             | 14 |
|     |      | 1.1.2 Palette Write                 |    |     | 5.8 | 32 BPP                             |    |
|     |      | 1.1.3 Palette Read                  |    |     |     | 5.8.1 Underlay Options             |    |
|     |      | 1.1.4 6/8 Bit Palette Access        |    |     |     | 5.8.2 Overlay Options              |    |
|     |      | 1.1.5 Palette Clocking              |    |     | 5.9 | 6 Bit Linear Palette Output        |    |
|     |      | 1.1.6 Palette Access Status         |    |     | 0.0 | o Bit Emiodi i diotto Gatpat       |    |
|     |      | 1.1.7 Pixel Mask                    |    | 6.0 | Con | trols                              |    |
|     | 1.2  | Indexed Access                      |    |     | 6.1 | Blank and Border Control           | 18 |
|     | 1.2  |                                     |    |     | 6.2 | Blanking Control                   | 18 |
|     |      | 1.2.1 Cursor Array                  | s  |     | 6.3 | Vertical Blanking                  | 18 |
| 2.0 | Clo  | cking                               | 4  |     | 6.4 | Border Control                     |    |
|     | 2.1  | Clock Generators                    |    |     | 6.5 | Sync Control                       |    |
|     | 2.2  | PLL Input                           |    |     | 6.6 | Clocking and Pipeline Delay        |    |
|     |      | 2.2.1 REFCLK                        |    |     |     | 6.6.1 Horizontal Sync              |    |
|     | 2.3  | SYSCLK PLL Output                   |    |     |     | 6.6.2 Vertical Sync                |    |
|     | 2.4  | Pixel PLL Outputs                   |    |     |     | 6.6.3 Composite Sync               |    |
|     | ۷.4  | 2.4.1 SCLK                          |    |     | •   | 6.6.4 Horizontal Position Control  |    |
|     |      | 2.4.2 DDOTCLK                       |    |     | 6.7 | Additional Sync Control            |    |
|     | 2 F  |                                     |    | •   | 6.8 | 24 Bit Packed Pixel Control        |    |
|     | 2.5  | Additional Clocks                   |    | ,   | 0.0 | 24 Dit i acked i ixel Collifor     | 20 |
|     |      | 2.5.1 Load Clock                    |    | 7.0 | Cur | sor Operation                      | 20 |
|     | 0.0  | 2.5.2 Pixel Clock (Dot Clock)       | 5  |     | 7.1 | Cursor Enable                      | 20 |
|     | 2.6  | PLL Operation Compatibility with    |    |     | 7.2 | Cursor Array                       | 20 |
|     | 0.7  | RGB51x/RGB52x                       | 6  |     |     | 7.2.1 Cursor Array Access          |    |
|     | 2.7  | PLL Operation and Programming       |    |     |     | 7.2.2 Cursor Array Writes          |    |
|     |      | 2.7.1 Additional Constraints        |    |     |     | 7.2.3 Cursor Array Reads           |    |
|     |      | 2.7.2 Programming Summary           | 8  |     | 7.3 | Cursor Modes                       |    |
|     |      | 2.7.3 Glitching on Frequency Change |    |     |     | 7.3.1 Standard Cursor              |    |
|     | 2.8  | Programming Registers               |    |     |     | 7.3.2 Advanced Cursor              |    |
|     |      | 2.8.1 SYSCLK PLL                    |    |     | 7.4 | Cursor Hot Spot                    | 22 |
|     |      | 2.8.2 Pixel PLL                     |    |     | 7.5 | Cursor Position                    |    |
|     |      | 2.8.3 Diagnostic Readback           | 9  |     | 7.6 | Interlace                          |    |
|     | 2.9  | PLL Disable                         | 9  |     | 7.7 | Cursor Update and Display          |    |
| 3.0 | Mod  | los of Operation                    | 10 |     | 1.1 | 7.7.1 Position                     |    |
| 3.0 |      | les of Operation                    |    |     |     | 7.7.1 Fosition                     |    |
|     | 3.1  | Overlays and Key Operation          |    |     |     |                                    |    |
|     | 3.2  | RGB526DB Double Buffer Operation    | 10 |     |     | 7.7.3 Other                        | 24 |
| 4.0 | VGA  | \ Port                              | 10 | 8.0 | DAC | C Control                          | 24 |
|     |      |                                     |    |     | 8.1 | SOG - Composite Sync-On-Green      |    |
| 5.0 | VRA  | M Pixel Formats                     | 11 |     | 8.2 | BRB - Blank Red and Blue DACs      |    |
|     | 5.1  | Bit Ordering                        | 11 |     | 8.3 | DSR - DAC Slew Rate                |    |
|     | 5.2  | Pixel Format Tables                 | 11 |     | 8.4 | DPE - DAC Blanking Pedestal Enable |    |
|     | 5.3  | 4 BPP                               | 11 |     |     |                                    |    |
|     | 5.4  | 8 BPP                               |    | 9.0 | Pow | ver Management                     | 25 |
|     | 5.5  | 16 BPP                              |    |     | 9.1 | DAC Power                          | 25 |
|     |      | 5.5.1 555/565 Formats               |    |     | 9.2 | Driver Power                       |    |
|     |      | 5.5.2 Color Path Selection          |    |     | 9.3 | Clocking Power                     |    |
|     |      | 5.5.3 Dynamic Bypass                |    |     | 9.4 | PLL Power                          |    |
|     |      | = j = jpuoo                         |    |     |     |                                    |    |

# RGB526/RGB526DB

| 10.0 | Diagnostic Support                     | 26         | 12.2.6 SYSCLK PLL Programming -           |    |
|------|----------------------------------------|------------|-------------------------------------------|----|
|      | 10.1 Data Masks                        | 26         | Standard Mode                             | 48 |
|      | 10.2 MISR                              |            | SYSCLK N                                  | 48 |
|      | 10.3 DAC Comparators                   |            | SYSCLK M                                  | 48 |
|      | Total Brita Comparators                |            | SYSCLK P                                  |    |
| 11.0 | Internal Register - Summary            | 28         | SYSCLK C                                  |    |
| 400  | Besteten Besseletten                   | 00         | 12.2.7 System Clock Frequency Selection - |    |
| 12.0 |                                        |            | Compatibility Mode                        | 49 |
|      | 12.1 Direct Access Registers           |            | System PLL Reference Divider              |    |
|      | Palette Address (Write Mode)           |            | System PLL VCO Divider                    |    |
|      | Palette Data                           |            | 12.2.8 Cursor                             |    |
|      | Pixel Mask                             |            | Cursor Control                            |    |
|      | Palette Address (Read Mode) / P        |            | Advanced Cursor Control                   |    |
|      | Access State                           |            | Advanced Cursor Attribute                 |    |
|      | Index Low                              |            | Cursor X Low                              |    |
|      | Index High                             |            |                                           |    |
|      | Indexed Data                           |            | Cursor X High<br>Cursor Y Low             |    |
|      | Index Control                          |            | Cursor Y High                             |    |
|      | 12.2 Indexed Registers                 |            |                                           |    |
|      | 12.2.1 Miscellaneous Control           |            | Cursor Hot Spot X                         |    |
|      | Miscellaneous Control 1                |            | Cursor Hot Spot Y                         |    |
|      | Miscellaneous Control 2                | 34         | Cursor Color 1 Red                        |    |
|      | Miscellaneous Control 3                | 35         | Cursor Color 1 Green                      |    |
|      | Miscellaneous Clock Control            | 36         | Cursor Color 1 Blue                       |    |
|      | Sync Control                           | 36         | Cursor Color 2 Red                        |    |
|      | Horizontal Sync Control                | 37         | Cursor Color 2 Green                      |    |
|      | Power Management                       |            | Cursor Color 2 Blue                       |    |
|      | DAC Operation                          | 38         | Cursor Color 3 Red                        |    |
|      | Palette Control                        | 38         | Cursor Color 3 Green                      |    |
|      | System Clock Control                   | 39         | Cursor Color 3 Blue                       |    |
|      | 12.2.2 Pixel Representation            | 40         | 12.2.9 Border Color                       |    |
|      | Pixel Format                           | 40         | Border Color Red                          |    |
|      | 8 Bit Pixel Control                    |            | Border Color Green                        |    |
|      | 16 Bit Pixel Control                   | 41         | Border Color Blue                         |    |
|      | 24 Bit Packed Pixel Control            | 42         | 12.2.10Key Support                        |    |
|      | 32 Bit Pixel Control                   | 43         | Key                                       |    |
|      | 12.2.3 Pixel Clock Frequency Selection | 44         | Key Mask                                  |    |
|      | Pixel PLL Control 1                    |            | Key Control (RGB526)                      |    |
|      | Pixel PLL Control 2                    | 45         | Key Control/DB Operation (RGB526DB)       |    |
|      | 12.2.4 Pixel PLL Programming - Standa  | rd Mode 46 | 12.2.11Diagnostic Support                 |    |
|      | Pixel M0, Pixel M1, Pixel M2, Pix      | el M3 46   | Revision Level                            |    |
|      | Pixel N0, Pixel N1, Pixel N2, Pixe     |            | ID                                        |    |
|      | Pixel P0, Pixel P1, Pixel P2, Pixe     | l P3 46    | DAC Sense                                 |    |
|      | Pixel C0, Pixel C1, Pixel C2, Pixe     | el C3 46   | MISR Status                               |    |
|      | 12.2.5 Pixel PLL Programming - Compa   | tibility   | MISR Red                                  |    |
|      | Mode                                   |            | MISR Green                                |    |
|      | Fixed Pixel PLL Reference Divide       | er 47      | MISR Blue                                 |    |
|      | F0-F15: Pixel Frequency 0 to           |            | Pixel P Input                             |    |
|      | Frequency 15                           | 47         | Pixel C Input                             |    |
|      | M0-M7, N0-N7                           |            | Pixel M Input                             |    |
|      | ·                                      |            | Pixel N Input                             |    |
|      |                                        |            | PLL VCO Divider Input                     |    |
|      |                                        |            | PLL Reference Divider Input               |    |
|      |                                        |            | VRAM Mask Low                             |    |
|      |                                        |            | VRAM Mask High                            | 60 |

| 13.0       | Pin Descriptions                                                                                                                                                         | 61             |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 14.0       | Electrical and Timing Specificat                                                                                                                                         | tions 67       |
| 15.0       | Video Waveforms                                                                                                                                                          | 70             |
| 16.0       | Package Information                                                                                                                                                      | 71             |
| 17.0       | Ordering Information                                                                                                                                                     | 71             |
| 18.0       | Change Summary                                                                                                                                                           | 72             |
| Appe       | endix                                                                                                                                                                    | 73             |
| <b>A.0</b> | RGB526, RGB526DB Compariso                                                                                                                                               | on 73          |
| B.0        | B.1 ID Register                                                                                                                                                          | 74<br>74<br>74 |
| C.0        | PLL Compatibility Programming C.1 PLL Programming C.2 PLL Frequency Selection C.3 Direct Programming C.4 M/N Programming C.5 General PLL Programming C.6 Start-up Values |                |
| D.0        | Switching Into VGA Mode                                                                                                                                                  | 81             |

# **List of Tables**

| Table 1.  | I/O Addresses1                     | Table 21. | PLL Equations77                      |
|-----------|------------------------------------|-----------|--------------------------------------|
| Table 2.  | Start-up Pixel Clock Frequency4    | Table 22. | Pixel PLL Control 1 EXT/INT Freq.    |
| Table 3.  | SCLK Frequencies5                  |           | Selection                            |
| Table 4.  | Pixel PLL Bank Selection9          | Table 23. | Direct Programming Reference Divider |
| Table 5.  | Pixel Format Table -               |           | Values79                             |
|           | RGB526/RGB526DB16                  | Table 24. | PLL Direct Programming Equations 79  |
| Table 6.  | Pixel Format Table -               |           |                                      |
|           | RGB526DB Double Buffer Operation17 |           |                                      |
| Table 7.  | Standard Cursor Modes22            |           |                                      |
| Table 8.  | Advanced Cursor Colors22           |           |                                      |
| Table 9.  | Advanced Cursor Attributes22       |           |                                      |
| Table 10. | Internal Register Summary28        |           |                                      |
| Table 11. | Pin Descriptions61                 |           |                                      |
| Table 12. | Signal List by Pin Number66        |           |                                      |
| Table 13. | Recommended Operating Conditions67 |           |                                      |
| Table 14. | Absolute Maximum Ratings67         |           |                                      |
| Table 15. | DC Characteristics67               |           |                                      |
| Table 16. | AC Characteristics68               | 1         | <b>Y</b>                             |
| Table 17. | Composite Video Output Waveform70  |           |                                      |
| Table 18. | Composite Video Output Waveform70  |           |                                      |
| Table 19. | Part Numbers71                     |           |                                      |
| Table 20. | Summary of Changes72               |           |                                      |

# ∟ıst of Figures

| Figure 1. | SCLK for 24 BPP Packed                 | 5  |
|-----------|----------------------------------------|----|
| Figure 2. | PLL Simplified Diagram                 | 7  |
| Figure 3. | 24 BPP Packed Pixel Input from VRAM    |    |
| Figure 4. | Microprocessor Interface Timing        | 69 |
| Figure 5. | Pixel Data and Video Control Interface |    |
| · ·       | Timing                                 | 69 |
| Figure 6. | SCLK and LCLK Timing                   | 69 |

# 1.0 Microprocessor Access

As seen on the microprocessor bus there are eight I/O addresses, selected by RS[2:0]. Two indirect schemes are used to access all of the internal registers and arrays through these eight primary I/O addresses.

The first scheme is standard VGA, and operates when RS[2] = 0. Of the four I/O addresses then available with RS[1:0], only one address directly accesses a register, the Pixel Mask. The other three addresses are used to indirectly access the three  $256 \times 8$  palettes.

The second scheme is an indexed scheme and is used to access all of the remaining registers including the cursor array. This scheme operates when RS[2] =1. Of the four I/O addresses then available using RS[1:0], two are used to load an index register (Low and High). The third address is used to write or read the register or array position pointed to by the index register. The fourth address is used to directly access a register which controls whether the index register automatically increments following an indexed register access.

The eight I/O addresses selected by RS[2:0] are listed in Table 1 below:

| Table   | Table 1: 1/0 Addresses         |  |  |  |  |  |  |
|---------|--------------------------------|--|--|--|--|--|--|
| RS[2:0] | Register                       |  |  |  |  |  |  |
| 000     | Palette Address (Write Mode)   |  |  |  |  |  |  |
| 001     | Palette Data                   |  |  |  |  |  |  |
| 010     | Pixel Mask                     |  |  |  |  |  |  |
| 011     | Palette Address (Read Mode)    |  |  |  |  |  |  |
| 100     | Index Low                      |  |  |  |  |  |  |
| 101     | Index High                     |  |  |  |  |  |  |
| 110     | Index Data (Indexed Registers) |  |  |  |  |  |  |
| 111     | Index Control                  |  |  |  |  |  |  |

Table 1. I/O Addresses

#### 1.1 VGA Access

#### 1.1.1 Palette

Internally the three 256x8 palettes are accessed by the microprocessor as a single 256x24 palette, with all 24 bits written or read in one operation.

A single Palette Address register points to 1 of 256 locations for writing or reading the 24 bits. Two different Register Select addresses are used to access the Palette Address register.

A write to RS[2:0] = 000 (Palette Address Write Mode) initializes the palette logic for write operations. Subsequent writes to Palette Data (RS[2:0] = 001) will load internal palette color registers and cause these register contents to be written into the palettes.

A write to RS[2:0] = 011 (Palette Address Read Mode) initializes the palette logic for read operations. Data from the palettes will be loaded into internal palette color registers. Subsequent reads from Palette Data (RS[2:0] = 001) will read these palette color registers.

Every three accesses of Palette Data (RS[2:0] = 001) will cause the Palette Address register to be incremented. An increment past 0xff will "wrap around" to 0x00.

A read from either Palette Address (Write Mode) or Palette Address (Read Mode) will read the Palette Address register. The same register is used for writing and reading, thus, changing modes destroys the contents of the previous mode's palette address. For example, if some reads are performed and then Palette Address (Write mode) is written, the read address will be lost and a read of either Palette Address (Write Mode) or Palette Address (Read Mode) will produce the same result: the address that was written into Palette Address (Write Mode).

#### 1.1.2 Palette Write

Palette writes must be initialized by writing the Palette Address (Write Mode) register. This provides a starting address for writes and initializes the internal circuitry for palette write operations.

Palette writes are then performed by writing to Palette Data in a red, green, blue... sequence. These writes will load internal palette data registers in sequence. Immediately following every third write, an internal write will be triggered to the palette of the 24 bits contained in the internal palette data registers, at the address contained in the Palette Address register.

Immediately following the internal palette write triggered by the third write to Palette Data, the Palette Address register will be incremented. Thus, continuous writes to Palette Data will load the palette, stepping through the palette addresses in ascending order.



#### 1.1.3 Palette Read

Palette reads must be initialized by writing the Palette Address (Read Mode) register. This provides a starting address for reads and initializes the internal circuitry for palette read operations.

Immediately following the writing of Palette Address (Read Mode), a read of the palette will be performed at the address just written. Internal palette data registers are loaded with the read data, and the Palette Address register is incremented.

Palette reads are then performed by reading from Palette Data. Red, green, blue... data from the preloaded internal registers will be presented in sequence. Immediately following every third read, an internal read of the palette to the 24 bits contained in the internal registers will be performed at the address contained in the Palette Address register.

Immediately following the internal palette read triggered by the third read of Palette Data, the Palette Address register will be incremented. Thus, continuous reads of Palette Data will read the palette, stepping through the palette addresses in ascending order.

#### 1.1.4 6/8 Bit Palette Access

The original VGA had 6-bit DACs and 6-bit palette entries, and the low order 6 bits from/to the microprocessor port were written/read into the palette.

For the RGB526/RGB526DB, the DACs and palette entries are 8 bits. For non-VGA emulation all 8 bits are used. To emulate 6-bit VGA operation the upper 6 bits of the palette hold the VGA 6-bit color and the two low order bits are set to 00. The COL RES bit (color resolution) of the Miscellaneous Control 2 register determines if the access is 6-bit or 8-bit.

The reset condition is to emulate VGA using the 6 low order microprocessor data bits. COL RES is set to 6 bits. In this mode, for writing, microprocessor bits [7:6] are discarded, bits [5:0] are shifted to bits [7:2], and bits [1:0] are set to 00 before being written into the internal data registers. For reading, the internal data register bits [7:2] are shifted to bits [5:0], and bits [7:6] are set to 00 before being presented on the microprocessor data signals.

If COL RES is set to 8 bits then all 8 bits from/to the microprocessor will be written to and read from the color palette registers.

Note that the 6-to-8 bit translation is only done between the microprocessor port and the internal data registers. Internally, on writes, all 8 bits of the internal registers are written to the palette, and on reads, the internal registers retain all 8 bits read from the palette. Thus, if the palette is loaded with 8-bit values with COL RES set to 8 bits, and then the palette is read with COL RES set to 6 bits, the internal palette color registers will still be loaded with the 8 bits that were written into the palette. But the data read on the microprocessor data lines will be 6 bits.

#### 1.1.5 Palette Clocking

Palette accesses are synchronized internally with the pixel clock. On writes, the pixel values of the previous cycle are held and displayed during the write cycle. Both of these features minimize disturbance of displayed pixels when the palette is accessed (anti-sparkle).

The pixel clock (as selected by the PCLK SEL bits in Miscellaneous Control 2) must be running for palette access to be valid.

The timings for the microprocessor signals are specified in units of pixel clocks. These specifications are derived from the requirement for the pixel clock to be running for palette access, as well as to allow time for the Palette Accesses and Palette Address increments to occur internally following a palette access.

#### 1.1.6 Palette Access Status

The original VGA logic had an override for read accesses of the Palette Address (Read Mode) register. Instead of reading the Palette Address register, a value was returned that indicates the status of the last palette access, write or read.

The reset condition of the RGB526/RGB526DB is to return the address value for a read of Palette Address (Read Mode). The VGA logic may be emulated by setting the RADR RFMT bit in Miscellaneous Control 1. This causes the status of the last palette access to be returned.

The value of the status returned is 0x00 if the last write to Palette Address was Write Mode, and 0x03 if the last write to Palette Address was Read Mode.

#### 1.1.7 Pixel Mask

The pixel mask is an 8-bit register addressed with RS[2:0] = 010. It can be accessed at any time without disturbing a palette write or read sequence.

Accesses to the pixel mask are asynchronous to the pixel clock. Temporary color disturbances can be expected if the mask is changed while displaying pixels through the palette.

#### 1.2 Indexed Access

The cursor array and a number of control registers are addressed with an internal 11-bit index register. The microprocessor accesses this as Index High (RS[2:0] = 101) and Index Low (RS[2:0] = 100).

A write or read to Index Data (RS[2:0] = 110) actually writes or reads the register/cursor array location addressed by the Index register.

Following a write or read of Index Data, the index register will increment if the INDX CNTL bit is set. The Index Control register (RS[2:0] = 111) contains this bit. To allow for future expansion, wraparound from 0x07ff to 0x0000 is **not** supported.

In general, access of Index Low, Index High, Index Control, or any of the Indexed registers is independent of the palette access and will not disturb a palette write or read sequence. However, as described above the PADR RFMT bit in Miscellaneous Control 1, the COL RES bit in Miscellaneous Control 2, and the 6BIT ACC bit in Palette Control all affect palette access.

Also, as described above, the pixel clock must be running for valid access of the palette, and the pixel clock is affected by a number of indexed registers.

#### 1.2.1 Cursor Array

In general, the indexed registers may be written or read at any time, using the address held in Index High and Index Low. This address may be set by writing to Index High or Index Low, or the value may result from the auto-increment action of a previous access.

However, as described in section 7.2.3 Cursor Array Reads on page 21, to access the cursor array a write to Index High or Index Low must be performed first. That is, the cursor array cannot be accessed by auto-increment from address 0x00ff to 0x0100.

Also, as with the palette, the pixel clock must be running to access the cursor array.

# 2.0 Clocking

#### 2.1 Clock Generators

There are two on-board clock generators: pixel clock and system clock (SYSCLK). Each clock generator uses a separate programmable phase locked loop (PLL).

The pixel clock generator provides the fundamental "dot" timings; it serves generally as the clock both for internal chip clocking and for on-card CRT timings.

The system clock generator is provided for the convenience of the graphics subsystem design. No internal use is made of this clock; the clock generator simply drives the SYSCLK output of the chip.

## 2.2 PLL Input

#### 2.2.1 **REFCLK**

The REFCLK input is a reference clock that the PLLs use in conjunction with programming registers to produce a wide variety of frequencies.

In general, REFCLK can be any frequency from 1 MHz through 100 MHz. However, as discussed below, the two clock generators each come up at "start up" frequencies which are dependant on the REFCLK frequency. This can govern the value chosen for REFCLK, depending on the application requirements at "reset" time.

Following a reset, the PLL driving the SYSCLK output is enabled with the start-up frequency:

SYSCLK frequency =  $(33/16) \times REFCLK$  frequency

The pixel clock PLL has four start up frequencies:

F0 frequency =  $(7/4) \times REFCLK$  frequency

F1 frequency =  $(79/40) \times REFCLK$  frequency

F2 frequency = Undefined

F3 frequency = Undefined

The desired frequency is selected externally using the FS[1:0] input pins.

The start-up values are chosen for use with REFCLK = 14.31818 MHz (a common graphics adapter frequency):

SYSCLK frequency =  $(33/16) \times 14.31818 = 29.53$  MHz F0 frequency =  $(7/4) \times 14.31818 = 25.057$  MHz

F1 frequency = (79/40) × 14.31818 = 28.278 MHz

This causes the SYSCLK start up frequency to be approximately 30 MHz and the pixel clock frequencies to be approximately the standard VGA frequencies 25.175 MHz and 28.322 MHz.

With a 14.31818 MHz REFCLK the start-up pixel clock frequencies selected by FS[1:0] are:

Table 2. Start-up Pixel Clock Frequency

| FS[1:0] | Frequency<br>Selected | Value      |
|---------|-----------------------|------------|
| 00      | F0                    | 25.057 MHz |
| 01      | F1                    | 28.278 MHz |
| 10      | F2                    | Undefined  |
| 11      | F3                    | Undefined  |

# 2.3 SYSCLK PLL Output

The system clock PLL drives the SYSCLK output. This output can be 3-stated with Bit 6, SYSC DSAB, in the System Clock Control register.

The supported frequency range for SYSCLK is 8.125 MHz to 100 MHz.

## 2.4 Pixel PLL Outputs

The pixel PLL is used internally as the pixel clock. The maximum allowed generated frequency is 170/220 MHz, dependent on the product version.

The pixel PLL Output is not available directly. However, two divided versions are provided as output signals:

- □ SCLK
- □ DDOTCLK

#### 2.4.1 SCLK

SCLK (Serial Clock) is intended for clocking of the serial outputs of the VRAMs to the pixel port inputs. As such, the divide factor is a function of the VRAM pixel port width (64 or 32 bits), and the number of pixels contained in an access. For example, with a VRAM width of 64 and operating at 16 bits-per-pixel, there will be 64/16=4 pixels brought in with each VRAM access, and SCLK will operate at 1/4 the frequency of the pixel PLL output.

If the VGA port is selected SCLK will simply be the output of the pixel PLL. Table 3, "SCLK Frequencies," is a table of all the SCLK frequencies that are produced.

| Table | 3. | SCLK | Fred | uencies |
|-------|----|------|------|---------|
|-------|----|------|------|---------|

| BPP       | VRAM=32 | VRAM=64    |  |  |  |
|-----------|---------|------------|--|--|--|
| 4         | ÷ 8     | ÷ 16       |  |  |  |
| 8         | ÷ 4     | ÷ 8        |  |  |  |
| 15/16     | ÷ 2     | ÷ 4<br>÷ 2 |  |  |  |
| 15/16 DB  | ÷ 1     |            |  |  |  |
| 32        | ÷ 1     | ÷ 2        |  |  |  |
| 24 Packed | Invalid | ÷ (8/3)    |  |  |  |
| VGA       | ÷ 1     |            |  |  |  |

"24 Packed" is a special case. It is only valid with a VRAM width of 64, and it produces 3 SCLKs for every 8 internal pixel clocks as shown in Figure 1.

"15/16 DB" (double buffer) is also a special case, and is only used on the RGB526DB. When 16 BPP mode is used, and double buffer operation is enabled, 32 bits will be fetched for each pixel. SCLK will run at the same frequency as for 32 BPP mode.



Figure 1. SCLK for 24 BPP Packed

The SCLK output can be inverted with the SCLK INVT bit of the Miscellaneous Clock Control register. This allows either polarity to be used, as desired, to aid in meeting critical timings at the card level.

The SCLK DSAB bit of the Miscellaneous Clock Control register can be used to 3-state the SCLK output if desired.

#### 2.4.2 DDOTCLK

DDOTCLK (Divided Dot Clock) is simply the pixel PLL output divided by 1, 2, 4, 8 or 16 as determined by the DDOT DIV bits of the Miscellaneous Clock Control register.

Note that the maximum supported output frequency of DDOTCLK is 100 MHz, so some values of the DDOT DIV bits will become illegal when the pixel PLL is programmed to operate beyond this frequency.

When a pixel format of 24 BPP Packed is selected, the SCLK output may be driven on DDOTCLK instead of

the divided pixel PLL output, under control of the B24P DDOT bit of the Miscellaneous Clock Control register.

DDOTCLK is similar to the SYSCLK output in that it is provided for general card use and is not used internally. However, its frequency is slaved to the pixel clock, whereas SYSCLK is independent. The DDOTCLK may be 3-stated with the DDOT DSAB bit of the Miscellaneous Clock Control register if desired.

**Note:** Although DDOTCLK and SCLK are both derived from the pixel clock, there is otherwise no particular relationship between the two clocks. In particular, the two clocks do not have any associated phase relationship.

#### 2.5 Additional Clocks

#### 2.5.1 Load Clock

The LCLK input (Load Clock) is used to latch up all incoming pixel data and video controls. The maximum frequency of this input is 100 MHz.

# 2.5.2 Pixel Clock (Dot Clock)

The pixel clock, or dot clock, is the internal clock used to clock pixel data up through the DACs. It is also required to be running to access the palette and the cursor array. The maximum frequency of this clock is 170/220 MHz (depending on the product rated speed).

There are several sources of the pixel clock, as selected by the PCLK SEL bits in the Miscellaneous Control 2 register:

**LCLK input** This is the reset default. It is intended to be used when the VGA port is selected as the pixel source.

**Pixel PLL output** This is intended to be used when the VRAM pixel port is selected as the pixel source. It provides the highest pixel clock operation.

**REFCLK input** This is intended for laboratory bringup.

When LCLK is selected as the pixel clock all internal pixel operations are synchronous with LCLK. If the pixel clock is sourced by the pixel PLL output or REF-CLK, then the incoming pixels and video controls are expected to be derived from SCLK. After latching the signals with LCLK, the signals are clocked with an internal SCLK, and then clocked with the internal pixel clock.

# 2.6 PLL Operation Compatibility with RGB51x/RGB52x

Although the RGB526/RGB526DB is generally upward compatible with previous generation RGB51x and RGB52x products the method for programming the two PLLs as described in the following sections is not the same. Previous generation RGB51x and RGB52x products have restrictions on the programming values which are removed with the RGB526/RGB526DB and RGB6xx products.

For software compatibility with previous generation RGB51x and RGB52x the "restricted" programming mode used by those products is retained. This programming method is described in Appendix C.0 "PLL Compatibility Programming" on page 77.

The programming mode for the SYSCLK PLL is determined by the PROG MODE bit of the System Clock Control register (index 0x0008). This bit must be set to '1' to use the method described in the following sections. When set to '0' the compatibility mode described in Appendix C.0 is used.

The programming mode for the pixel PLL is determined by the EXT/INT bits of the Pixel PLL Control 1 register (index 0x0010). These bits when set to 100 or 101 will use the method described in the following sections. When set to 000, 001, 010, or 011 the compatibility mode described in Appendix C.0 is used.

# 2.7 PLL Operation and Programming

The two PLLs are generally identical in their operation and programming. A simplified diagram of the PLL is shown in Figure 2. The PLL takes the incoming reference clock, REFCLK, and generates the CLOCKOUT output. The frequency of CLOCKOUT is determined by three programming values contained in registers, M, N and P. A fourth value, C, is required to set the operating points of the analog circuits.

The heart of the PLL is the VCO (voltage controlled oscillator). The VCO can operate over the range of 65 MHz to 170 MHz/220 MHz (depending on the product speed chosen).

The VCO voltage input value is produced by comparing a divided version of the VCO output with a reference frequency. The value M sets the divide value for the VCO output. Values for M can be 2 through 127 (0 and 1 are illegal). '1' is added to M, to produce a divide value of 3 through 128.

The internal reference frequency ( $f_{INTREF}$ ) is produced by dividing the incoming REFCLK, with the divide

value set by N. N can range from 0 through 63, and '1' is added to this value to produce a divider value of 1 through 64.

The divided VCO output frequency is compared to the internal reference  $f_{\rm INTREF}$  by a phase comparator. The phase comparator drives a charge pump which drives a filter connected to the VCO. A capacitor in the filter develops the voltage supplied to the VCO. The voltage goes up or down depending on whether the phase comparator is driving the charge pump current up or down.

When the divided VCO frequency is equal to  $f_{\rm INTREF}$  no pump current is produced, the voltage to the VCO stays constant, and the VCO frequency stays constant. If the VCO tends to drift in frequency the phase comparator will detect the difference and will drive filter voltage, via the charge pump, in the appropriate direction. This adjusts the VCO frequency such that the frequency difference at the input to the phase comparator again becomes zero. With a constant  $f_{\rm INTREF}$  the VCO frequency will be "locked" to the internal reference.

The internal reference frequency is:

$$(1) \quad {}^{t}_{INTREF} = \frac{f_{REFCLK}}{N+1}$$

The VCO frequency is:

(2) 
$$_{VCO} = f_{INTREF} \times (M+1) = f_{REFCLK} \times \frac{M+1}{N+1}$$

The output of the VCO is divided down by 1, 2, 4, 6 or 8, depending on the P programming value, to produce the final programmed frequency. For example, a clock frequency of 28 MHz is produced by programming the VCO to oscillate at  $4 \times 28 = 112$  MHz, and then setting P to divide the VCO output by 4.

Values for P are 0 through 4 for the Pixel PLL and 1 through 4 for the SYSCLK PLL. When P is 0 the divide value is 1; when P = 1, 2, 3 or 4 the divide factor is  $2 \times P$ .

The generated CLOCK OUT frequency is:

(3a) 
$$_{CLOCKOUT} = f_{REFCLK} \times \frac{M+1}{N+1}; P=0$$
  
(3b)  $_{CLOCKOUT} = f_{REFCLK} \times \frac{M+1}{(N+1) \times 2P}; P=1, 2, 3, 4$ 

Internal to the PLL the charge pump bias current and the VCO gain must be adjusted depending on the frequency of operation. These adjustments are controlled by the C programming bits:

(4a) et 
$$C = 1$$
; when 65 MHz  $\leq f_{VCO} \leq$  128 MHz

(4b) et 
$$C = 2$$
; when  $f_{VCO} > 128 \text{ MHz}$ 

Other values of C are reserved.



Figure 2. PLL Simplified Diagram



#### 2.7.1 Additional Constraints

#### 2.7.1.1 Internal Reference

To avoid excessive jitter the internal reference frequency  $f_{\rm INTREF}$  must not be less than 1 MHz.

#### 2.7.1.2 VCO Frequency Range

The minimum VCO frequency is 65 MHz. The maximum frequency is the maximum speed rating of the product: 170 MHz / 220 MHz. (E.g., if it is desired to have a Dot Clock of 150 MHz it is not permitted to program the PLL to run at 300 MHz with a P value of 1 to divide down to 150 MHz.)

#### 2.7.1.3 PLL Interaction

The Pixel PLL and the SYSCLK PLL will interfere with each other (they will modulate the output frequency of the other PLL) if the higher frequency falls within 3 MHz of an integer multiple of the lower frequency. That is, if  $f_{higher}$  is the higher of the two frequencies and  $f_{lower}$  is the lower frequency, then the following equation must be satisfied:

 $(5a)^{+}_{higher} \neq (n \times f_{lower}) \pm 3 \text{ MHz}; n = 1,2,3...$ 

#### 2.7.2 Programming Summary

- Select M, N and P values that produce the desired frequency using equation (3a) or (3b). Note that for the SYSCLK PLL a value of '0' for P is not permitted, so equation (3a) is not valid for this PLL.
- Verify that f<sub>INTREF</sub> is not less than 1 MHz, using equation (1).
- 3. Verify that  $f_{VCO}$  is not less than 65 MHz and not greater than 170 MHz / 220 MHz, using equation (2).
- 4. Verify that the higher frequency of the 2 PLLs, plus or minus 3 MHz, is not an integral multiple of the lower frequency PLL (equation (5a)).
- 5. If all of the above conditions are met then M, N and P are valid values. Select the appropriate C value using equation (4a) or (4b).

# 2.7.3 Glitching on Frequency Change

When the operating frequency of either PLL is changed by changing one of the programming register values, the transition from the original frequency to the new frequency can either occur smoothly or can glitch, depending upon the following:

- 1. If the P bits are not changed, then changing the M and N bits will not cause a glitch.
- If the P value is changed then the PLL output can glitch. For the Pixel PLL there is no protection against this situation.
  - For the SYSCLK PLL there is additional logic (not shown) which causes the "2,4,6,8" VCO divider circuit to update synchronously with the VCO output when the P value is changed, such that changing P will not cause SYSCLK to glitch.
- 3. Caution should be used when changing the C value. Although the output will not "glitch", the frequency can change rapidly to intermediate values before settling to the new value.

The Pixel PLL has selectable banks of programming values (described below). Note that switching between banks has the same glitching considerations as changing single M, N, P or C values.

# 2.8 Programming Registers

#### 2.8.1 SYSCLK PLL

When the PROG MODE bit of the System Clock Control register (index 0x0008) is set to '1' the SYSCLK N, M, P, and C registers (indices 0x0015, 0x0016, 0x0017, 0x0018 respectively) are used to provide the SYSCLK PLL programming values.

When the PROG MODE bit is set to '0' the registers at 0x0015 and 0x0016 are used for compatibility mode programming as described in Appendix C.O, and the registers at 0x0017 and 0x0018 are ignored.

#### 2.8.2 Pixel PLL

For the Pixel PLL four banks of registers, each containing a set of M, N, P and C values are provided. The selection source of these banks, external or internal, is controlled by the EXT/INT bits of the PLL Control 1 register (index 0x0010).

When EXT/INT = '100' the selection is external, with the values on the FS[1:0] pins used to select the register bank.

When EXT/INT = '101' the selection is internal, with the value of the Pixel PLL Control 2 register used to select the register bank.

Table 4. Pixel PLL Bank Selection

| FS[1:0] or<br>PLL<br>Control 2 [1:0] | Programming<br>Registers | Register<br>Indices |
|--------------------------------------|--------------------------|---------------------|
| 00                                   | M0,N0,P0,C0              | 0x0020 - 0x0023     |
| 01                                   | M1,N1,P1,C1              | 0x0024 - 0x0027     |
| 10                                   | M2,N2,P2,C2              | 0x0028 - 0x0031     |
| 11                                   | M3,N3,P3,C3              | 0x0032 - 0x0035     |

When EXT/INT = '000' through '011' the registers at 0x0020 through 0x0035 are used for compatibility mode programming as described in Appendix C.O. A register at 0x0014, the Fixed PLL Reference Divider, is used for compatibility mode programming but is ignored when EXT/INT = '100' or '101'.

# 2.8.3 Diagnostic Readback

The read-only registers Pixel M Input (index 0x008e), Pixel N Input (index 0x008f), Pixel P Input (index 0x008c) and Pixel C Input (index 0x008d) contain the programming values actually used by the pixel PLL. These registers can be used to verify that the desired programming registers are the ones actually selected.

When compatibility mode programming is used the registers at 0x008e and 0x008f contain the Pixel PLL programming values as described in Appendix C.O., and the values in the registers at 0x008c and 0x008d are undefined.

#### 2.9 PLL Disable

Following a reset the PLLs are "enabled" and will change frequencies with changes to the programming values. Each PLL can be separately "disabled". In the disabled state the PLL does not respond to the M and N programming values. This causes the internal VCO to oscillate somewhere in the range of 20 KHz to 1 MHz.

Changing the C value may change the VCO frequency but the frequency will stay within the  $20\ \text{KHz}$  to  $1\ \text{MHz}$  range.

The VCO output continues to be affected by the P value, so the actual PLL output will be (20 KHz through 1 MHz) divided by 1, 2, 4, 6 or 8, for the Pixel PLL, and (20 KHz through 1 MHz) divided by 2, 4, 6 or 8, for the SYSCLK PLL.

The Pixel PLL is disabled by setting the PPLL ENAB in the Miscellaneous Clock Control register to 0. The SYSCLK PLL is disabled by setting the SPPL ENAB bit in the System Clock Control register to 0.



# 3.0 Modes of Operation

Pixel data can come from the VGA port or the VRAM pixel port, as selected by the PORT SEL bit of the Miscellaneous Control 2 register.

If the VRAM pixel port is selected, the pixel format can be 4 BPP (bits per pixel), 8 BPP, 15/16 BPP, 24 BPP Packed, or 32 BPP, selected by the Format bits of the Pixel Format register. Table 5, "Pixel Format Table - RGB526/RGB526DB," on page 16 shows how the input bits are selected as a function of Pixel Format.

VGA data and 4 BPP data are always used to indirectly generate 24 bits of color by indexing into the 256 entry palettes. The Pixel Mask register is used to selectively mask off the index bits as desired.

8 BPP, 15/16 BPP, 24 BPP Packed, and 32 BPP from the VRAM pixel port can either be indirect (through the palettes) or direct (bypassing the palettes).

Each of these formats has an associated control register with bits to select indirect or direct color. Additionally 15/16 BPP and 32 BPP formats allow a bit within the incoming data to dynamically select indirect or direct color.

As with VGA and 4 BPP, the Pixel Mask is used to mask off palette address bits with indirect color access for 8, 15/16, 24 Packed, and 32 BPP.

# 3.1 Overlays and Key Operation

A pixel format is supported in which two pixels, overlay and underlay, are packed together and one or the other pixel is selected by "key" matching.

Two 8-bit registers, the "Key" and the "Key Mask" are provided. In general, the contents of the Key register are considered to have a value that is "transparent", and is compared to the overlay value on a pixel by pixel basis. If the values do not match (the overlay is not transparent) then the overlay pixel is displayed. If the values match (the overlay is transparent) then the underlay pixel is displayed (it "shows through").

The Key Mask register allows bits in the Mask register to be "don't cared". Bits that are '1' in the Key Mask register will cause corresponding bits in the Mask register to be used in the compare operation with the overlay pixel. Bits that are '0' will cause the corresponding bits in the Key register to be ignored. For example, if the bits in the Key Mask register are 11110000 then only the four high order bits of the overlay layer have to match

the four high order bits of the Key register to switch to the underlay.

The key matching operation is enabled by setting the KEY ENAB bit of the Key Control operation. If the pixel format supports overlay/underlay then key matching will take place; otherwise the KEY ENAB bit has no effect.

The RGB526/RGB526DB supports key matching for the 32 BPP format. With 32 BPP the upper 8 bits can be designated as an 8-bit RGB overlay, and the Key value is considered to be a "Chroma Key". The remaining 24 bits are the underlay and are used as 24-bit RGB.

# 3.2 RGB526DB Double Buffer Operation

The RGB526DB has a "double buffer" mode of operation. The mode is valid only when the pixel format is set for 15/16 BPP, and is described further in Section 5.6 on page 13.

## 4.0 VGA Port

VGA uses 8 bits per pixel. When the VGA port is selected only indirect mode is used. The 8 bits are masked with the Pixel Mask register and presented to the red, green, and blue palettes as indices into the 256 entries of each palette. The masked data is used as the same index into each of the three color palettes.

# 5.0 VRAM Pixel Formats

# 5.1 Bit Ordering

Bit order is high-to-low. For 8 BPP, the MSB is '7' and the LSB is '0'; for 16 BPP the MSB is '15' and the LSB is '0', and so on.

When the VRAM pixel port is selected the default condition is to access the pixels from low to high. For each LCLK, the first pixel used is at the end with bit PIX[00], and the last pixel used is at the end with bit PIX[63] (bit PIX[31] for VRAM width = 32). For example, for 8 BPP, the first pixel is PIX[07:00], the second pixel is PIX[15:08], and so on.

4 BPP is a special case. Within a byte, the default condition is to select first the high nibble (e.g., PIX[07:04]), then the low nibble (PIX[03:00]). The SWAP NIB bit of the Miscellaneous Control 3 register may be used to swap the order the two nibbles are used. This swap is applied to every byte that is read in, and is only active, when set, for 4 BPP.

Independent of the VRAM pixel format, the two bytes within each pair of incoming bytes may be altered with the SWAP BYTE bits of the Miscellaneous Control 3 register. When these bits are set, PIX[15:08] are used as PIX[07:00] and PIX[07:00] are used as PIX[15:08], PIX[31:24] are used as PIX[23:16] and PIX[23:16] are used as PIX[31:24], and so on.

#### 5.2 Pixel Format Tables

Table 5 shows the bit assignments of the pixel data port for each supported pixel format. Prefixes A - P identify individual pixels, and numbers 0 - 7 identify the bit within the pixel. For 4 bit pixels, this information is the data seen by the three color palettes. For 8 bit pixels, it is the data seen by the three color palettes in indirect color mode, and it is the data seen by the three DACs in direct color mode. The suffixes (blu, grn, red) identify the data seen by each of the color palettes (indirect mode) or each of the DACs (direct mode) for 16, 24, and 32 bit RGB pixels.

Table 6 shows the bit assignments for the double buffer formats that are unique to the RGB526DB.

The effects of setting the SWAP BYTE bits of the Miscellaneous Control 3 register are not shown in Table 5 and Table 6.

#### 5.3 4 BPP

With 4 BPP format 8 pixels (32 bit VRAM width) or 16 pixels (64 bit VRAM width) are obtained for each pixel port data access. As noted above the default access of the two pixels within each byte are high-to-low:

PIX[7:4] = pixel one

PIX[3:0] = pixel two,

but this can be reversed with the SWAP NIB bit of the Miscellaneous Control 3 register.

4 BPP is only used in indirect color mode. The 4 bits are masked with the 4 low order bits [3:0] of the Pixel Mask. The resultant masked 4 bits are then used to index into each of the red, green, and blue palettes.

With 4 BPP the 256 entry palettes are divided into 16 partitions of 16 entries per partition. The upper 4 bits of the Pixel Mask register are ignored. The PARTITION bits of the Palette Control register are used as the upper 4 bits of the palette address to select the desired partition. The 4 masked pixel bits are used to index to 1-of-16 entries within the selected partition.

#### 5.4 8 BPP

With 8 BPP format 4 pixels (32 bit VRAM width) or 8 pixels (64 bit VRAM width) are obtained for each pixel port data access.

8 BPP can be indirect or direct, under control of the B8 DCOL bit of the 8 BPP Control register. If indirect, the 8 bits are masked with the Pixel Mask register and presented to the red, green, and blue palettes as indices into the 256 entries of each palette.

If direct, the 8 bits are presented to the red, green, and blue DACs. Note that since the red, green, and blue colors are identical the displayed image will be monochrome.

#### 5.5 16 BPP

With 15 BPP or 16 BPP format 2 pixels (32-bit VRAM width) or 4 pixels (64-bit VRAM width) are obtained for each pixel port data access. The 15 or 16 bits are expanded to 24 bits, under control of the 16 BPP Control register.

The 16 BPP Control register provides a number of options for using the 16 BPP format:



- 1. The incoming pixel can be 15 bits (555 format) or 16 bits (565 format).
- 2. The color path can be indirect (through the palettes) or direct (bypassing the palettes). Also, with 555 format, the 16th bit can be used to dynamically switch on a pixel-by-pixel basis between indirect and direct color.
- If indirect color is selected, the addressing of the palettes can be "sparse" (pixel bits used as high order palette address bits) or "contiguous" (pixel bits used as low order palette address bits).
- 4. If indirect color with contiguous addressing is selected, the palettes can be divided into partitions. The PARTITION bits of the Palette Control register are used to select the partition by filling in the upper palette address bits. With 555 format 8 partitions are available; with 565 format there are 4 partitions.
- 5. If direct color is used the pixel bits are sent to the DAC high order bits. The low order bits can be zero filled, or the low order bits can be filled with the high order bits of the pixel data. (See description of ZIB/LIN bit below.)

If dynamic bypass is selected the following conditions will apply:

- 1. The format will be forced to 15 bit (555), with the unused 16th bit now used to control indirect/direct color selection.
- The indirect color path will be forced to use sparse addressing of the palettes. Partitions cannot be used.
- The direct color path will force the low order bits to the DACs to be zero filled (ZIB). LIN format cannot be used.
- The Pixel Mask will mask the pixel data regardless of whether or not the palette is bypassed.

#### 5.5.1 555/565 Formats

The 555/565 bit determines if the pixel is 15 bits (5:5:5 format) or 16 bits (5:6:5 format). The format designator, 5:5:5 or 5:6:5, refer to the bit allocations, high-to-low, for red:green:blue.

With 15 BPP the high order bit of each two bytes (PIX[15], PIX[31], PIX[47], PIX[63]) is discarded unless dynamic bypass is specified (B16 DCOL bits = 01). With dynamic bypass, this bit is used for indirect/direct color selection.

As noted above setting the mode to dynamic bypass will force the format to 555 regardless of the setting of the 555/565 bit.

#### 5.5.2 Color Path Selection

The B16 DCOL bits are used to select one of:

- 1. Indirect color always (00).
- 2. Direct color always (11).
- 3. Dynamic selection of indirect or direct color (01).

The expansion to 24 bits varies depending on whether the color path is indirect or direct.

Indirect Color: The palette addressing can be sparse or contiguous and is controlled by the SPR/CNT bit. With sparse addressing the pixels will address 32 locations each for the red and blue palettes, and 32 locations for green in 555 format or 64 locations for green in 565 format. With the lower address bits set to zeroes the locations accessed will be "scattered" through the palettes, with the intermediate locations unused.

With contiguous addressing the PARTITION bits of the Palette Control register are used for the high order palette address bits, and the access within each palette is contiguous. For 555 format there are 8 partitions and 32 entries within each partition. For 565 format there are 4 partitions. All 64 entries in the green palette are addressed. Only the lower 32 entries of the red and blue palettes are used; the high 32 entries are not used.

For sparse addressing the low order bits are dependent on the ZIB/LIN bit. This bit *must* be set to 0 (ZIB). This will force the low order bits to zeros. If ZIB/LIN is 1 (LIN) then the values of the low order bits presented to the palettes are undefined.

For sparse addressing the low order Pixel Mask bits have no effect.

For contiguous addressing the high order bits are always supplied by the PARTITION bits and the high order Pixel Mask bits have no effect.

As noted above for dynamic bypass mode the format is forced to 555 mode and addressing is forced to be sparse regardless of the setting of the SPR/CNT bit.

**Direct Color:** To expand the 5 or 6 bits of color from the pixel data to 8 bits, the ZIB/LIN bit of the 16 BPP Control register specifies the generation of the low order 3 or 2 bits. If ZIB (Zero Intensity Black), the low order bits are made 0. If LIN (Linear), the low order bits are made

equal to the high order bits. This causes the 5 or 6 bits to expand to 8 bits in a linear fashion, with both zero scale and full scale values used. With Zero Intensity Black, full scale cannot be achieved.

As noted above for dynamic bypass mode the format is forced to 555 mode and the low order fill is forced as ZIB, regardless of the setting of the ZIB/LIN bit.

#### 5.5.3 Dynamic Bypass

As described above the selection of "dynamic bypass" mode forces the 555 format and uses the high order bit of the incoming 16-bit pixels as a control bit to select, on a pixel-by-pixel basis, the indirect (color lookup) or direct (lookup bypass) path.

The meaning of this bit depends on the BY16 bit in the 16 BPP Control register. When BY16 = 0 the incoming control bit forces the bypass. That is, when the control bit is 1 the palette is bypassed (direct color), and when 0 the palette is not bypassed (indirect color).

When BY16 = 1 the meaning of the incoming control bit is reversed; it now forces a lookup. That is, when the control bit is 1 the palette is used (color lookup), but when 0 the palette is bypassed (direct color).

# 5.6 16 BPP Double Buffered (RGB526DB Only)

For the RGB526DB only, a double buffer mode of operation can be set for use with 15-bit pixels. Double buffer operation is controlled by two register bits:

- ☐ The DBUF MODE (double buffer mode enable) bit. This is bit 0 in the Miscellaneous Control 3 register (index 0x0072).
- □ The SUPP BUFB (suppress buffer B) bit. This is bit 0 of the Key Control/DB Operation register (index 0x0078).

When the DBUF MODE bit is set, the VRAM inputs are treated as coming from two frame buffers, A and B.

Instead of processing 16 bits for each pixel, 32 bits from the VRAM inputs are used for each pixel. Each group of 32 input bits is considered to be:

| _ | 4 - 1 - 1 - 00 |              | (5577774 4 6 3 |             |
|---|----------------|--------------|----------------|-------------|
|   | 15-bit buffer  | A pixel data | (PIXI14:01.    | PIX146:321) |

- ☐ An unused bit (PIX[15], PIX[47])
- ☐ 15-bit buffer B pixel data (PIX[30:16], PIX[62:48])
- □ A Buffer Select bit (PIX[31], PIX[63])

The Buffer Select bit selects either buffer A data (Buffer Select bit = '0') or buffer B data (Buffer Select bit = '1') for display. Unselected buffer data is ignored. Thus, the A/B buffer selection is made on a pixel-by-pixel basis.

When the SUPP BUFB bit is set, the Buffer Select bit is ignored, and only buffer A data is displayed. The SUPP BUFB bit can be used for A/B buffer selection on a perframe basis by setting the Buffer Select bits to '1's for all pixels in any double buffered region [window] of the screen. For these pixels, if SUPP BUFB is set, then buffer A is selected, and if SUPP BUFB is reset, then buffer B is selected.

Note that bit 0 of the Key Control/DB Operation register has a dual usage. When 16 BPP double buffer operation is enabled bit 0 of the Key Control register is used as the SUPP BUFB bit as described above. For all other modes of operation this bit acts as the KEY ENAB (key enable) bit, for key matching operation.

Several restrictions apply to double buffer operation:

- 1. When the VRAM port is selected, the DBUF MODE bit should only be set when the Pixel Format register (index 0x000a) is set to 15/16 BPP (Format bits = '100'.)
- 2. In the 16 Bit Pixel Control register (index 0x000c) the 555/565 bit (bit 1) must be set to '0' for 555 operation.
- 3. Also in the 16 Bit Pixel Control register, the B16 DCOL (direct color control) bits (bits 7 and 6) must be set to either '00' (Indirect Color) or '11' (Direct Color).

If any of these three conditions is violated the resultant operation of the product is indeterminate.

As implied above, the 15 bits selected for display, either A or B, are interpreted as 555 format. As with normal 16 BPP, 555 format, the color path can be indirect (through the palettes) or direct, as set by the B16 DCOL bits. However, the "dynamic bypass" mode (B16 DCOL =  $^{\circ}$ 01") is not available.

The ZIB/LIN (bit fill selection) and SPR/CNT (palette addressing) control bits operate on the double buffer pixels the same as normal 555 pixels.

The actions of the B16 DCOL, ZIB/LIN and SPR/CNT control bits apply to all pixel data, whether from buffer A or buffer B.

As noted in section 2.4.1, when double buffer operation is enabled the outgoing SCLK is generated with the same timings as for 32 BPP.



#### 5.7 24 BPP

24 BPP Packed can only be selected when the VRAM width is 64 bits. If 24 BPP Packed format is selected with the Pixel Format register, but the VRAM SIZE bit in the Miscellaneous Control 1 register is set for 32 bits, then the product operation is undefined.

With 24 BPP Packed format each 64-bit pixel port data access contains 2+2/3 pixels. Every 3 consecutive pixel port data accesses ( $3 \times 8 = 24$  bytes) contains 8 pixels of 3 bytes each. The assignment of the bytes for each of the three accesses is shown in Figure 3 on page 14. Each byte contains 8 bits of red, green, or blue color. Color access can be indirect or direct, and is selected with the B24P DCOL bit of the 24 BPP Packed Control register.

For indirect color, the 8 bits of red, green, and blue are each masked by the Pixel mask, and then presented to the red, green, and blue palettes as indices into the 256 entries of each palette.

For direct color, the 8 bits of red, green, and blue are presented to the DACs.



Figure 3. 24 BPP Packed Pixel Input from VRAM

#### 5.8 32 BPP

With 32 BPP format 1 pixel (32-bit VRAM width) or 2 pixels (64-bit VRAM width) are obtained for each pixel port data access. Within the 32 bits there are two formats:

- High order byte unused, three low order bytes are RGB.
- 2. High order byte is 8-bit RGB, three low order bytes are RGB.

Option 1 is used when key matching is off (KEY ENAB = 0 in the Key Control register); option 2 is used when key matching is on.

# 5.8.1 Underlay Options

The color path for the three byte RGB pixel can be selected with the B32 DCOL bits:

- Indirect color (00).
- 2. Direct color (11).

In addition, if key matching is *not* selected, then a dynamic selection of indirect color or direct color on a pixel-by-pixel basis can be specified by setting the B32 DCOL bits to 01.

With dynamic selection (dynamic bypass), the "25th" bit is used as the indirect/direct control bit (PIX[24], PIX[56]) and the remaining bits of the high order byte are unused. (PIX[31:25] and PIX[63:57].) The pixel data in this mode is masked by the Pixel Mask regardless of whether or not the palette is bypassed.

For indirect color, the 8 bits of red, green, and blue are each masked by the Pixel mask, and then presented to the red, green, and blue palettes as indices into the 256 entries of each palette.

For direct color, the 8 bits of red, green, and blue are presented to the DACs.

#### 5.8.1.1 Dynamic Bypass

As described above the selection of "dynamic bypass" mode uses the "25th" bit of the incoming 32-bit pixels as a control bit to select, on a pixel-by-pixel basis, the indirect (color lookup) or direct (lookup bypass) path.

The meaning of this bit depends on the BY32 bit in the 32 BPP Control register. When BY32 = 0 the incoming control bit forces the bypass. That is, when the control bit is 1 the palette is bypassed (direct color), and when 0 the palette is not bypassed (indirect color).

When BY32 = 1 the meaning of the incoming control bit is reversed; it now forces a lookup. That is, when the control bit is 1 the palette is used (color lookup), but when 0 the palette is bypassed (direct color).

#### 5.8.2 Overlay Options

When key matching is enabled the 8 high order bits are used as the overlay pixel.

If the incoming 8-bit pixel value matches the (masked) value in the Key register the pixel selection logic will switch to the underlay layer, the high order byte will be discarded, and the three low order bytes will be used as the displayed pixel using the options described above.

If the value does not match the masked key, the high order byte will be displayed as the overlay pixel, as one of 255 values. The pixel path can be indirect or direct, under control of the B8 DCOL bit in the 32 BPP Control register.

If indirect, the 8 bits are masked with the Pixel Mask register and presented to the red, green, and blue palettes as indices into the 256 entries of each palette.

If direct, the 8 bits are presented to the red, green, and blue DACs. Note that since the red, green, and blue colors are identical the displayed image will be monochrome.

Also note that when the overlay path is indirect, the underlay probably should not use indirect color since both pixel types, 8-bit overlay and 24-bit underlay, would be trying to share the same lookup table.

#### 5.9 6 Bit Linear Palette Output

The 6BIT LIN (6 bit linear) bit of the Palette Control register affects the format of the color data read from the palettes and presented to the DACs in indirect color mode. It only has effect when the color resolution is set to 6 bits with the COL RES bit of the Miscellaneous Control 2 register and DCOL CNTL is set to indirect color.

If the palettes contain data with the two low order bits set to 00 (which will be the case when the palettes are loaded with COL RES set to 6 bits), without special processing the data values presented to the DACs will range from 0x00 through 0xfd. The maximum output of the DACs will be approximately 1.5% less than full scale (0xff). This will occur when 6BIT LIN is set to 1.

When 6BIT LIN is set to 0 (the default), then the outputs of the palettes will be modified to allow the DACs to reach full scale output. The modification consists of discarding the two low order bits from the palettes, and substituting the two high order bits for the two low order bits presented to the DACs. (i.e., the palette bits presented to a DAC will be bits 7 6 5 4 3 2 7 6).

With this bit substitution there will be a "linear" mapping of the palette data range (0x00 - 0xfd) to the DAC data range (0x00 - 0xff), and the DACs will operate over their full range.

If COL RES = 1 (8-bit color resolution) the palette outputs are presented to the DACs unchanged, and 6BIT LIN has no effect. The DACs will operate over the 8-bit range from completely off to full scale on.

Palette linear output is intended for emulation of the VGA 6-bit DACs in which the palette is loaded with 6-bit colors in the 6 high-order bits by setting COL RES to 6-bits. However, regardless of how the palette was loaded or what the pixel format is (VGA, 4, 8, 15/16, 24, 32 BPP), if enabled (DCOL = indirect, COL RES = 6 bit, 6BIT LIN = 0) the palette outputs will be affected as discussed above.

In summary, with the default conditions for VGA mode (indirect color, 6-bit color resolution, 6BIT LIN = 0), there will be a linear mapping of the 6-bit VGA palette data to the DACs, and the DACs will operate over their full range. The mapping can be turned off by setting 6BIT LIN to 1, in which case the 8 bits from the palettes are presented to the DACs unmodified. With 00 in the two low order bits of the palettes the DACs will not reach full scale output.

With 8-bit color resolution (indirect color), or with direct color, the setting of 6BIT LIN has no effect.



Table 5. Pixel Format Table - RGB526/RGB526DB

|         | 4.0          | DD1             |                |                   | 17/10          | DDD2 2             |                 |                | A DDD D        | 1              |                |                   |
|---------|--------------|-----------------|----------------|-------------------|----------------|--------------------|-----------------|----------------|----------------|----------------|----------------|-------------------|
| Pixel   | 4 B          | PP              |                |                   | 15/16          | BPP <sup>2,3</sup> |                 | 2              | 24 BPP Packe   | d              |                |                   |
| Port    | SWAP         | SWAP            | 8 BPP          | 555 Sparse        | 555 CON-       | 565 Sparse         |                 |                |                |                | 32 BPP         | RGB               |
| Bit     | NIB=0        | NIB=1           | 0 11 1         | or Direct         | TIG            | or Direct          | 565 Contig      | 1st Access     | 2nd Access     | 3rd Access     | 32 DI I        | OVL8 <sup>5</sup> |
| DIL     | NID=0        | NID=1           |                | Color             | 11G            | Color              |                 |                |                |                |                |                   |
| _       | DO.          | 4.0             | 4.0            |                   | AODITI         |                    | AODITI          | AODITI         | CODED          | EOCDN          | AODITI         | AODITI            |
| 0       | B0           | A0              | A0             | A3BLU             | A0BLU          | A3BLU              | A0BLU           | A0BLU          | C0RED          | F0GRN          | A0BLU          | A0BLU             |
| 1       | B1           | A1              | A1             | A4BLU             | A1BLU          | A4BLU              | A1BLU           | A1BLU          | C1RED          | F1GRN          | A1BLU          | A1BLU             |
| 2       | B2           | A2              | A2             | A5BLU             | A2BLU          | A5BLU              | A2BLU           | A2BLU          | C2RED          | F2GRN          | A2BLU          | A2BLU             |
| 3       | B3           | A3              | A3             | A6BLU             | A3BLU          | A6BLU              | A3BLU           | A3BLU          | C3RED          | F3GRN          | A3BLU          | A3BLU             |
| 4       | A0           | В0              | A4             | A7BLU             | A4BLU          | A7BLU              | A4BLU           | A4BLU          | C4RED          | F4GRN          | A4BLU          | A4BLU             |
| 5       | A1           | B1              | A5             | A3GRN             | A0GRN          | A2GRN              | A0GRN           | A5BLU          | C5RED          | F5GRN          | A5BLU          | A5BLU             |
| 6       | A2           | B2              | A6             | A4GRN             | A1GRN          | A3GRN              | A1GRN           | A6BLU          | C6RED          | F6GRN          | A6BLU          | A6BLU             |
| 7       | A3           | В3              | A7             | A5GRN             | A2GRN          | A4GRN              | A2GRN           | A7BLU          | C7RED          | F7GRN          | A7BLU          | A7BLU             |
| 8       | D0           | CO              | B0             | A6GRN             | A3GRN          | A5GRN              | A3GRN           | A0GRN          | D0BLU          | F0RED          | A0GRN          | A0GRN             |
| 9       | D1           | C1              | B1             | A7GRN             | A4GRN          | A6GRN              | A4GRN           | A1GRN          | D1BLU          | F1RED          | AIGRN          | A1GRN             |
| 10      | D2           | C2              | B2             | A3RED             | A0RED          | A7GRN              | A5GRN           | A2GRN          | D2BLU          | F2RED          | A2GRN          | A2GRN             |
|         |              | C2              |                |                   |                |                    |                 | A3GRN          |                |                |                |                   |
| 11      | D3           |                 | В3             | A4RED             | A1RED          | A3RED              | A0RED           |                | D3BLU          | F3RED          | A3GRN          | A3GRN             |
| 12      | C0           | D0              | B4             | A5RED             | A2RED          | A4RED              | A1RED           | A4GRN          | D4BLU          | F4RED          | A4GRN          | A4GRN             |
| 13      | C1           | D1              | B5             | A6RED             | A3RED          | A5RED              | A2RED           | A5GRN          | D5BLU          | F5RED          | A5GRN          | A5GRN             |
| 14      | C2           | D2              | B6             | A7RED             | A4RED          | A6RED              | A3RED           | A6GRN          | D6BLU          | F6RED          | A6GRN          | A6GRN             |
| 15      | C3           | D3              | B7             | (NOTE 4)          | UNUSED         | A7RED              | A4RED           | A7GRN          | D7BLU          | F7RED          | A7GRN          | A7GRN             |
| 16      | F0           | E0              | C0             | B3BLU             | B0BLU          | B3BLU              | B0BLU           | A0RED          | D0GRN          | G0BLU          | A0RED          | A0RED             |
| 17      | F1           | E1              | C1             | B4BLU             | B1BLU          | B4BLU              | B1BLU           | A1RED          | D1GRN          | G1BLU          | A1RED          | A1RED             |
| 18      | F2           | E2              | C2             | B5BLU             | B2BLU          | B5BLU              | B2BLU           | A2RED          | D2GRN          | G2BLU          | A2RED          | A2RED             |
| 19      | F3           | E3              | C3             | B6BLU             | B3BLU          | B6BLU              | B3BLU           | A3RED          | D3GRN          | G3BLU          | A3RED          | A3RED             |
| 20      | E0           | F0              | C3<br>C4       | B7BLU             | B4BLU          | B7BLU              | B4BLU           | A4RED          | D4GRN          | G4BLU          | A4RED          | A4RED             |
|         | E0<br>E1     | F1              | C*             | B3GRN             | B0GRN          | B2GRN              | B0GRN           | A4RED<br>A5RED | D4GRN<br>D5GRN | G4BLU<br>G5BLU |                |                   |
| 21      |              |                 | C5             |                   |                |                    |                 |                |                |                | A5RED          | A5RED             |
| 22      | E2           | F2              | C6             | B4GRN             | B1GRN          | B3GRN              | B1GRN           | A6RED          | D6GRN          | G6BLU          | A6RED          | A6RED             |
| 23      | E3           | F3              | C7             | B5GRN             | B2GRN          | B4GRN              | B2GRN           | A7RED          | D7GRN          | G7BLU          | A7RED          | A7RED             |
| 24      | H0           | G0              | D0             | B6GRN             | B3GRN          | B5GRN              | B3GRN           | B0BLU          | D0RED          | G0GRN          | (NOTE 4)       | A0OVL8            |
| 25      | H1           | G1              | D1             | B7GRN             | B4GRN          | B6GRN              | B4GRN           | B1BLU          | D1RED          | G1GRN          | UNUSED         | A1OVL8            |
| 26      | H2           | G2              | D2             | B3RED             | B0RED          | B7GRN              | B5GRN           | B2BLU          | D2RED          | G2GRN          | UNUSED         | A2OVL8            |
| 27      | НЗ           | G3              | D3             | B4RED             | B1RED          | B3RED              | B0RED           | B3BLU          | D3RED          | G3GRN          | UNUSED         | A3OVL8            |
| 28      | G0           | H0              | D4             | B5RED             | B2RED          | B4RED              | B1RED           | B4BLU          | D4RED          | G4GRN          | UNUSED         | A4OVL8            |
| 29      | G1           | H1              | D5             | B6RED             | B3RED          | B5RED              | B2RED           | B5BLU          | D5RED          | G5GRN          | UNUSED         | A5OVL8            |
| 30      | G2           | H2              | D6             | B7RED             | B4RED          | B6RED              | B3RED           | B6BLU          | D6RED          | G6GRN          | UNUSED         | A6OVL8            |
| 31      | G2<br>G3     | H3              | D7             | (NOTE 4)          | UNUSED         | B7RED              | B4RED           | B7BLU          | D7RED          | G7GRN          | UNUSED         | A7OVL8            |
|         | J0           | I0              |                |                   |                |                    |                 | B0GRN          |                |                |                |                   |
| 32      |              |                 | E0             | C3BLU             | C0RED          | C3BLU              | COBLU           |                | E0BLU          | G0RED          | B0BLU<br>B1BLU | B0BLU             |
| 33      | J1           | I1              | E1             | C4BLU             | C1BLU          | C4BLU              | C1BLU           | B1GRN          | E1BLU          | G1RED          | B1BLU          | B1BLU             |
| 34      | J2           | I2              | E2             | C5BLU             | C2BLU          | C5BLU              | C2BLU           | B2GRN          | E2BLU          | G2RED          | B2BLU          | B2BLU             |
| 35      | J3           | 13              | E3             | C6BLU             | C3BLU          | C6BLU              | C3BLU           | B3GRN          | E3BLU          | G3RED          | B3BLU          | B3BLU             |
| 36      | 10           | J0              | E4             | C7BLU             | C4BLU          | C7BLU              | C4BLU           | B4GRN          | E4BLU          | G4RED          | B4BLU          | B4BLU             |
| 37      | I1           | J1              | E5             | C3GRN             | COGRN          | C2GRN              | C0GRN           | B5GRN          | E5BLU          | G5RED          | B5BLU          | B5BLU             |
| 38      | 12           | J2              | E6             | C4GRN             | C1GRN          | C3GRN              | C1GRN           | B6GRN          | E6BLU          | G6RED          | B6BLU          | B6BLU             |
| 39      | 13           | J3              | E7             | C5GRN             | C2GRN          | C4GRN              | C2GRN           | B7GRN          | E7BLU          | G7RED          | B7BLU          | B7BLU             |
| 40      | L0           | K0              | F0             | C6GRN             | C3GRN          | C5GRN              | C3GRN           | B0RED          | E0GRN          | H0BLU          | B0GRN          | B0GRN             |
| 41      | L1           | K1              | F1             | C7GRN             | C4GRN          | C6GRN              | C4GRN           | B1RED          | E1GRN          | H1BLU          | B1GRN          | B1GRN             |
| 42      | L2           | K2              | F2             | C3RED             | C0RED          | C7GRN              | C5GRN           | B2RED          | E2GRN          | H2BLU          | B2GRN          | B2GRN             |
|         |              |                 | F3             |                   |                | C3RED              | CORED           | B3RED          |                |                |                |                   |
| 43      | L3           | K3              |                | C4RED             | C1RED          |                    |                 |                | E3GRN          | H3BLU          | B3GRN          | B3GRN             |
| 44      | K0           | L0              | F4             | C5RED             | C2RED          | C4RED              | C1RED           | B4RED          | E4GRN          | H4BLU          | B4GRN          | B4GRN             |
| 45      | K1           | L1              | F5             | C6RED             | C3RED          | C5RED              | C2RED           | B5RED          | E5GRN          | H5BLU          | B5GRN          | B5GRN             |
| 46      | K2           | L2              | F6             | C7RED             | C4RED          | C6RED              | C3RED           | B6RED          | E6GRN          | H6BLU          | B6GRN          | B6GRN             |
| 47      | K3           | L3              | F7             | (NOTE 4)          | UNUSED         | C7RED              | C4RED           | B7RED          | E7GRN          | H7BLU          | B7GRN          | B7GRN             |
| 48      | N0           | M0              | G0             | D3BLU             | D0BLU          | D3BLU              | D0BLU           | C0BLU          | E0RED          | H0GRN          | B0RED          | B0RED             |
| 49      | N1           | M1              | G1             | D4BLU             | D1BLU          | D4BLU              | D1BLU           | C1BLU          | E1RED          | H1GRN          | B1RED          | B1RED             |
| 50      | N2           | M2              | G2             | D5BLU             | D2BLU          | D5BLU              | D2BLU           | C2BLU          | E2RED          | H2GRN          | B2RED          | B2RED             |
| 51      | N3           | М3              | G3             | D6BLU             | D3BLU          | D6BLU              | D3BLU           | C3BLU          | E3RED          | H3GRN          | B3RED          | B3RED             |
| 52      | M0           | N0              | G4             | D7BLU             | D4BLU          | D7BLU              | D4BLU           | C4BLU          | E4RED          | H4GRN          | B4RED          | B4RED             |
| 53      | M1           | N1              | G5             | D3GRN             | D0GRN          | D2GRN              | D0GRN           | C5BLU          | E5RED          | H5GRN          | B5RED          | B5RED             |
|         | M2           | N2              | G6             | D4GRN             | DIGRN<br>DIGRN | D2GRN<br>D3GRN     | DIGRN<br>DIGRN  | C6BLU          | E6RED          |                |                |                   |
| 54      |              | l               |                |                   |                |                    |                 | l              | 1              | H6GRN          | B6RED          | B6RED             |
| 55      | M3           | N3              | G7             | D5GRN             | D2GRN          | D4GRN              | D2GRN           | C7BLU          | E7RED          | H7GRN          | B7RED          | B7RED             |
| 56      | P0           | 00              | H0             | D6GRN             | D3GRN          | D5GRN              | D3GRN           | C0GRN          | F0BLU          | H0RED          | (NOTE 4)       | B0OVL8            |
| 57      | P1           | O1              | H1             | D7GRN             | D4GRN          | D6GRN              | D4GRN           | C1GRN          | F1BLU          | H1RED          | UNUSED         | B1OVL8            |
| 58      | P2           | O2              | H2             | D3RED             | D0RED          | D7GRN              | D5GRN           | C2GRN          | F2BLU          | H2RED          | UNUSED         | B2OVL8            |
| 59      | P3           | O3              | НЗ             | D4RED             | D1RED          | D3RED              | D0RED           | C3GRN          | F3BLU          | H3RED          | UNUSED         | B3OVL8            |
| 60      | 00           | PO              | H4             | D5RED             | D2RED          | D4RED              | D1RED           | C4GRN          | F4BLU          | H4RED          | UNUSED         | B4OVL8            |
| 61      | 01           | P1              | H5             | D6RED             | D3RED          | D5RED              | D2RED           | C5GRN          | F5BLU          | H5RED          | UNUSED         | B5OVL8            |
| 62      | O2           | P2              | H6             | D7RED             | D4RED          | D6RED              | D3RED           | C6GRN          | F6BLU          | H6RED          | UNUSED         | B6OVL8            |
|         |              |                 |                | (NOTE 4)          |                |                    |                 |                |                |                |                |                   |
| 63      | O3           | P3              | H7             | ,                 | UNUSED         | D7RED              | D4RED           | C7GRN          | F7BLU          | H7RED          | UNUSED         | B7OVL8            |
| Note 1: | In 4 RPP mod | e the 4 most si | anificant hite | of each pixel con | a from the nar | tition hits of the | nalette control | ragistar       |                |                |                | _                 |

Note 1: In 4 BPP mode the 4 most significant bits of each pixel come from the partition bits of the palette control register.

Note 2: For 15/16 BPP Direct Color the low order bits for each color component are determined by the ZIB/LIN Bit of the 16 BPP Control register. For 15/16 BPP sparse format (indirect color), the ZIB/LIN bit must be set to ZIB, and the low order bits for each color component will be zeroes.

Note 3: In CONTIGUOUS format for 15/16 BPP the most significant bits of each pixel come from the partition bits of the palette control register.

Note 4: These bits are used for DYNAMIC BYPASS when that mode is enabled, otherwise they are unused.

Note 5: For 32 BPP with chroma key enabled, if the upper byte does not match the chroma key it is used as an 8 BPP indirect color overlay (OVL8). If the chroma key is matched the three lower bytes are used as 24 bit RGB (indirect or direct). Dynamic bypass is not available when chroma keying is enabled.

Table 6. Pixel Format Table - RGB526DB Double Buffer Operation

| Table 6. Pixel Format Table - RGB526DB Double Buffer Operation |  |                         |                        |                                                  |     |   |   |                                                  |  |
|----------------------------------------------------------------|--|-------------------------|------------------------|--------------------------------------------------|-----|---|---|--------------------------------------------------|--|
| Pixel                                                          |  |                         | 15/16                  | BPP <sup>2,3</sup>                               |     |   |   | _                                                |  |
| Port                                                           |  | 555 Sparse<br>or Direct | 555 CON-               |                                                  |     |   |   |                                                  |  |
| Bit                                                            |  | Color                   | TIG                    |                                                  |     |   |   |                                                  |  |
| 0                                                              |  | A - A3BLU               | A - A0BLU              | <del>                                     </del> |     |   |   | <del>                                     </del> |  |
| 1                                                              |  | A - A4BLU               | A - A1BLU              |                                                  |     |   |   |                                                  |  |
| 2                                                              |  | A - A5BLU               | A - A2BLU              |                                                  |     |   |   |                                                  |  |
| 3                                                              |  | A - A6BLU               | A - A3BLU              |                                                  |     |   |   |                                                  |  |
| 4                                                              |  | A - A7BLU               | A - A4BLU              |                                                  |     |   |   |                                                  |  |
| 5<br>6                                                         |  | A - A3GRN<br>A - A4GRN  | A - A0GRN<br>A - A1GRN |                                                  |     |   |   |                                                  |  |
| 7                                                              |  | A - A4GRN<br>A - A5GRN  | A - A2GRN              |                                                  |     |   |   |                                                  |  |
| 8                                                              |  | A - A6GRN               | A - A3GRN              |                                                  |     |   |   |                                                  |  |
| 9                                                              |  | A - A7GRN               | A - A4GRN              |                                                  |     |   |   |                                                  |  |
| 10                                                             |  | A - A3RED               | A - AORED              |                                                  |     |   |   |                                                  |  |
| 11<br>12                                                       |  | A - A4RED<br>A - A5RED  | A - A1RED<br>A - A2RED |                                                  |     |   |   |                                                  |  |
| 13                                                             |  | A - A6RED               | A - A3RED              |                                                  |     |   |   |                                                  |  |
| 14                                                             |  | A - A7RED               | A - A4RED              |                                                  |     |   |   |                                                  |  |
| 15                                                             |  | UNU                     |                        | ]                                                |     | 4 |   |                                                  |  |
| 16                                                             |  | B - A3BLU               | B - A0BLU              |                                                  |     |   |   |                                                  |  |
| 17                                                             |  | B - A4BLU<br>B - A5BLU  | B - A1BLU<br>B - A2BLU |                                                  |     |   |   |                                                  |  |
| 18<br>19                                                       |  | B - A6BLU               | B - A2BLU              |                                                  |     |   |   |                                                  |  |
| 20                                                             |  | B - A7BLU               | B - A4BLU              |                                                  |     |   | Ť |                                                  |  |
| 21                                                             |  | B - A3GRN               | B - A0GRN              |                                                  | . ` |   |   |                                                  |  |
| 22                                                             |  | B - A4GRN               | B - A1GRN              |                                                  |     |   |   |                                                  |  |
| 23<br>24                                                       |  | B - A5GRN<br>B - A6GRN  | B - A2GRN<br>B - A3GRN |                                                  |     |   |   |                                                  |  |
| 25                                                             |  | B - A7GRN               | B - A4GRN              |                                                  |     |   |   |                                                  |  |
| 26                                                             |  | B - A3RED               | B - A0RED              |                                                  |     |   |   |                                                  |  |
| 27                                                             |  | B - A4RED               | B - A1RED              |                                                  |     |   |   |                                                  |  |
| 28                                                             |  | B - A5RED               | B - A2RED              |                                                  |     |   |   |                                                  |  |
| 29<br>30                                                       |  | B - A6RED<br>B - A7RED  | B - A3RED<br>B - A4RED |                                                  | , i |   |   |                                                  |  |
| 31                                                             |  | A/B BUF SE              |                        | 6.73                                             |     |   |   |                                                  |  |
| 32                                                             |  | A - B3BLU               | A - BORED              |                                                  |     |   |   |                                                  |  |
| 33                                                             |  | A - B4BLU               | A - B1BLU              |                                                  |     |   |   |                                                  |  |
| 34                                                             |  | A - B5BLU<br>A - B6BLU  | A - B2BLU<br>A - B3BLU |                                                  |     |   |   |                                                  |  |
| 35<br>36                                                       |  | A - B0BLU<br>A - B7BLU  | A - B3BLU<br>A - B4BLU | <b>•</b>                                         |     |   |   |                                                  |  |
| 37                                                             |  | A - B3GRN               | A - BOGRN              |                                                  |     |   |   |                                                  |  |
| 38                                                             |  | A - B4GRN               | A - B1GRN              |                                                  |     |   |   |                                                  |  |
| 39                                                             |  | A - B5GRN               | A - B2GRN              |                                                  |     |   |   |                                                  |  |
| 40<br>41                                                       |  | A - B6GRN<br>A - B7GRN  | A - B3GRN<br>A - B4GRN |                                                  |     |   |   |                                                  |  |
| 42                                                             |  | A - B3RED               | A - BORED              |                                                  |     |   |   |                                                  |  |
| 43                                                             |  | A - B4RED               | A - B1RED              |                                                  |     |   |   |                                                  |  |
| 44                                                             |  | A - B5RED               | A - B2RED              |                                                  |     |   |   |                                                  |  |
| 45                                                             |  | A - B6RED<br>A - B7RED  | A - B3RED              |                                                  |     |   |   |                                                  |  |
| 46<br>47                                                       |  | A - B/RED UNUS          | A - B4RED<br>SED)      |                                                  |     |   |   |                                                  |  |
| 48                                                             |  | B - B3BLU               | B - B0BLU              | †                                                |     |   |   |                                                  |  |
| 49                                                             |  | B - B4BLU               | B - B1BLU              |                                                  |     |   |   |                                                  |  |
| 50                                                             |  | B - B5BLU               | B - B2BLU              |                                                  |     |   |   |                                                  |  |
| 51<br>52                                                       |  | B - B6BLU<br>B - B7BLU  | B - B3BLU<br>B - B4BLU |                                                  |     |   |   |                                                  |  |
| 52<br>53                                                       |  | B - B3GRN               | B - B4BLU<br>B - B0GRN |                                                  |     |   |   |                                                  |  |
| 54                                                             |  | B - B4GRN               | B - B1GRN              |                                                  |     |   |   |                                                  |  |
| 55                                                             |  | B - B5GRN               | B - B2GRN              |                                                  |     |   |   |                                                  |  |
| 56                                                             |  | B - B6GRN               | B - B3GRN              |                                                  |     |   |   |                                                  |  |
| 57                                                             |  | B - B7GRN               | B - B4GRN              |                                                  |     |   |   |                                                  |  |
| 58<br>59                                                       |  | B - B3RED<br>B - B4RED  | B - B0RED<br>B - B1RED |                                                  |     |   |   |                                                  |  |
| 60                                                             |  | B - B4RED<br>B - B5RED  | B - BIRED              |                                                  |     |   |   |                                                  |  |
| 61                                                             |  | B - B6RED               | B - B3RED              |                                                  |     |   |   |                                                  |  |
| 62                                                             |  | B - B7RED               | B - B4RED              |                                                  |     |   |   |                                                  |  |
| 63                                                             |  | A/B BUF SE              | L (NOTE 4)             |                                                  |     |   |   | I                                                |  |

Note 1: The double buffer formats in this table are only for the RGB526DB, and only when the DBUF MODE bit is set (bit 0 of the Miscellaneous Control 3 register).

Note 2: For 15/16 BPP Direct Color the low order bits for each color component are determined by the ZIB/LIN Bit of the 16 BPP Control register. For 15/16 BPP sparse format (indirect color), the ZIB/LIN bit must be set to ZIB, and the low order bits for each color component will be zeroes.

Note 3: In CONTIGUOUS format for 15/16 BPP the most significant bits of each pixel come from the partition bits of the palette control register.

Note 4: When the SUPP BUFB bit is set (bit 0 of the Key Control/DB Operation register), the A/B BUFFER SELECT bits are ignored and Buffer A pixels are selected.



#### 6.0 Controls

#### 6.1 Blank and Border Control

The  $\overline{BLANK}$  and  $\overline{BORDER}/O\overline{E}$  signals control the way in which data is presented to the DACs. These control signals are used to determine when pixel data is valid, when the border color is to be displayed, where the cursor should be located on the screen, and how the MISR will accumulate its signature.

## 6.2 Blanking Control

 $\overline{BLANK}$  is latched by the rising edge of LCLK. When  $\overline{BLANK}$  is active (low), the data presented to the DACs is forced to zeroes. When  $\overline{BLANK}$  is inactive (high), the pixel data or VGA data is considered valid (unless  $\overline{BORDER}$  is active), and the data is presented to the DACs as determined by the current mode of operation. Cursor data will override pixel data when the cursor is to be displayed.

# 6.3 Vertical Blanking

When  $\overline{BLANK}$  is active (low) an internal counter is used to determine whether or not the current blanking interval is vertical blanking. If the counter reaches its maximum count of 2048 pixels, an internal signal will become active to indicate that the end of the current frame has been reached. This internal signal will remain active until  $\overline{BLANK}$  becomes inactive (high). This vertical blanking detection is used by the cursor logic to position the cursor (if enabled) in the following frame. It is also used by the MISR (if enabled) to control the accumulation of a signature for one complete frame of pixel data.

#### 6.4 Border Control

BORDER/OE is a shared function input. It can indicate either "Border" time, for displaying a border, or "Odd/Even" for use with interlace mode. The usage of this pin is determined by the BRDR/INTL of the Miscellaneous Control 2 register. When used as a border control interlace mode is not supported with display of the hardware cursor.

When used as  $\overline{BORDER}$ , the input is latched by the rising edge of LCLK. When  $\overline{BLANK}$  is active (low),  $\overline{BOR}$ - $\overline{DER}$  must also be active (low). When  $\overline{BLANK}$  is inactive (high), the state of  $\overline{BORDER}$  will determine whether or not the color in the Border Color registers is displayed.

If  $\overline{BORDER}$  is active (low), the border color is displayed, and if  $\overline{BORDER}$  is inactive (high), the pixel data or cursor data is displayed. For cursor positioning, the active display area is considered valid when  $\overline{BORDER}$  and  $\overline{BLANK}$  are both inactive (high). The MISR signature is accumulated when  $\overline{BLANK}$  alone is inactive (high), thus the border area is included in the MISR accumulation. If no border is required, the  $\overline{BORDER}$  input should be tied to  $\overline{BLANK}$ .

The intent of the  $\overline{BORDER}$  signal is to create a "picture frame" around the active display area.  $\overline{BORDER}$  can remain active (low) for entire scan lines at the top and bottom of the active display area, or it can be active at the beginning and end of each scan line to create this effect. Other changes in the  $\overline{BORDER}$  signal within the active display area are not allowed.

If the BRDR/INTL bit in Miscellaneous Control 2 is set to "INTL" operation, no border will be displayed.

# 6.5 Sync Control

Three sync signals are brought into the device on two pins, HCSYNCIN and VSYNCIN.

Four registers control what is done with these signals:

- ☐ Sync Control (index 0x0003)
- ☐ Horizontal Sync Position (index 0x0004)
- □ DAC Operation (index 0x0006)
- ☐ Power Management (index 0x0005)
- ☐ Miscellaneous Control 1 (index 0x0070)

Horizontal sync on HCSYNCIN is processed and sent out on HSYNCOUT. Vertical sync on VSYNCIN is processed and sent out on VSYNCOUT.

The intent of processing horizontal sync is to delay it to match the delay seen by the pixel data from the inputs (VGA[7:0] or PIX[63:0]) to the DAC outputs. In addition, the signal may be inverted, forced low or high, or 3-stated.

A mismatch between pixel delay and horizontal sync delay can cause a visible effect, that is, the display may not be centered horizontally on the screen. The vertical display timings are generally such that mismatches are not visible. Vertical sync is brought in on  $\overline{VSYNCIN}$  and sent out on  $\overline{VSYNCOUT}$  to provide the same invert, force low or high, and 3-state controls as provided for horizontal sync.

Composite sync on HCSYNCIN may be injected onto the Green DAC output for composite-sync-on-green. This function is enabled by setting the SOG bit of the DAC Operation register. If this bit is off HCSYNCIN generally is not used for composite sync.

However, in lieu of providing a composite sync externally, if horizontal sync is provided on the  $\overline{HCSYNCIN}$  and vertical sync is provided on the  $\overline{VSYNCIN}$ , a "synthetic" composite sync may be generated internally by exclusive ORing these two signals. This is done by setting the XOR SYNC bit of the Miscellaneous Control 1 register.

If XOR SYNC is set and SOG is set the internally XORed sync signal will be injected onto the Green DAC output. If XOR SYNC is set but SOG is not set, then the synthetic composite sync will be presented on the HSYNCOUT output, but will not be injected on the Green DAC output.

Composite sync, whether it is the signal presented on HCSYNCIN or the synthetic internal composite sync, is delayed internally to match the pixel pipeline delay.

Since external horizontal and composite sync are shared on the same pin, only one of them should be enabled at a given time. For example, if the signal on  $\overline{HCSYNCIN}$  is horizontal sync and XOR SYNC is not being used, then the SOG bit on the DAC control register should be off. Or, if SOG is on to inject composite sync on  $\overline{HCSYNCIN}$  onto the green DAC output, some decision must be made on how to handle the  $\overline{HSYNCOUT}$  output (force low, high, 3-state, or leave unconnected).

#### 6.6 Clocking and Pipeline Delay

#### 6.6.1 Horizontal Sync

The clocking and delay of  $\overline{HCSYNCIN}$  to  $\overline{HSYNCOUT}$  depends on the DLY CNTL bit of the Sync Control register. If this bit is set to 1,  $\overline{HCSYNCIN}$  is passed directly to  $\overline{HSYNCOUT}$  without latching and without pipeline delay matching.

If DLY CNTL is set to 0 and SOG is off (no composite sync), then  $\overline{HCSYNCIN}$  is latched on the rising edge of LCLK and delayed internally to match the pixel pipeline delay before being sent out on  $\overline{HSYNCOUT}$ . Also, additional delay may be added with the Horizontal Position register (see section below).

If SOG is on (composite sync) then DLY CNTL has no effect and HCSYNCIN is passed directly to HSYNCOUT without latching and without pipeline delay matching.

(This is not a typical use for this input, it is just a byproduct of sharing horizontal sync with composite sync.)

#### 6.6.2 Vertical Sync

VSYNCIN is passed directly to VSYNCOUT without latching and without pipeline delay matching.

#### 6.6.3 Composite Sync

The HCSYNCIN input is always latched on the rising edge of LCLK for use as composite sync. When enabled with the SOG bit, it is delayed internally to match the pipeline delay of the pixel data, and then is injected onto the Green DAC output. As with horizontal sync, additional delay can be added with the Horizontal Sync Position register.

#### 6.6.4 Horizontal Position Control

Additional delay of 0 to 15 pixel clock periods may be added to the horizontal sync and composite sync signals with the Horizontal Sync Position register.

The intent of this additional delay is to provide a "fine tune" control of the horizontal screen position. Typically the incoming sync signals can only be adjusted in multiples of the pixel clock. The additional delay added with the Horizontal Position Control register adjusts the screen position with pixel increments.

The Horizontal Position register can be used on horizontal sync when DLY CNTL is set to 0 and SOG is off. The register can be used with composite sync when SOG is on.

# 6.7 Additional Sync Control

The polarity of the received HCSYNCIN input may be inverted before it is applied to the green DAC using the CSYN INVT bit of the Sync Control register.

The polarity may be inverted between  $\overline{HCSYNCIN}$  and  $\overline{HSYNCOUT}$  using the HSYN INVT bit, and the polarity may be inverted between  $\overline{VSYNCIN}$  and  $\overline{VSYNCOUT}$  using the VSYN INVT bit.

The HSYNCOUT and VSYNCOUT signals may be individually forced low, forced high, or forced to high impedance using the HSYN CNTL and VSYN CNTL bits of the Sync Control register.

As discussed in 9.3 "Clocking Power" on page 25, the clocks to the sync delay circuits can be shut off with the SYNC PWR bit of the Power Management register.

#### 6.8 24 Bit Packed Pixel Control

The 24 bit packed pixel format requires special consideration. In this mode the pixel data at the beginning of a line must be aligned on an eight pixel boundary as shown in Figure 3, "24 BPP Packed Pixel Input from VRAM" on page 14. These eight pixels correspond to three 64-bit pixel port loads or three SCLK cycles. In order to keep pixel data and control signals properly aligned, all control signals ( $\overline{BLANK}$ ,  $\overline{BORDER/OE}$  and  $\overline{HCSYNCIN}$ ) are required to change in increments of eight pixels (3 SCLKS). When either  $\overline{BLANK}$  or  $\overline{BORDER/OE}$  changes to indicate the beginning of an active display line, it is assumed that the pixel data which begins that line is aligned on the proper eight pixel boundary.



The cursor is a 32x32 or 64x64 pixel pattern that is overlaid on the display pixels just before presentation to the DACs. The cursor size, 32x32 or 64x64 is set with the CURS SIZE bit of the Cursor Control register.

Pixel columns are numbered left to right starting with 0. Pixel rows are numbered top to bottom starting with 0.

#### 7.1 Cursor Enable

The cursor is enabled when the CURSOR MODE bits of the Cursor Control register are not 00. When enabled, the cursor will display if it has not been moved offscreen. If disabled (CURSOR MODE = 00), the cursor will not be displayed.

The cursor may be used with either pixel port (VGA or PIX), with any of the pixel formats (VGA, 4, 8, 15/16, 24, 32 BPP), and with indirect or direct color.

# 7.2 Cursor Array

The cursor image is stored in the Cursor Array. The array is organized 1024x8 (1024 bytes). It is accessed as Indexed Data using index addresses 0x0100 through 0x04ff

Each pixel of the cursor uses 2 bits, thus 4 cursor pixels are stored in each byte of the array. The entire array is used to contain the  $64 \times 64$  cursor image (4 pixels/byte  $\times$  1024 bytes = 4096 pixels =  $64 \times 64$ ).

For the  $32 \times 32$  cursor only 256 bytes are required (4 pixels/byte  $\times$  256 bytes = 1024 pixels =  $32 \times 32$ .) The cursor array is divided into four contiguous slots to allow the storage of four cursor images. The SMLC SLOT bits of the Cursor Control register are used to select one of the four slots for display. The SMLC SLOT bits have no effect when the cursor size is  $64 \times 64$ .

Storage of the cursor within the array starts with the top row. For the  $64 \times 64$  cursor the first 16 bytes hold row 0, the next 16 bytes hold row 1, and so on, starting with the first byte in the array at index address  $0 \times 0100$ .

For the 32x32 cursor the first 8 bytes hold row 0, the next 8 bytes hold row 1, and so on, starting with the first byte in a slot (index addresses 0x0100, 0x0200, 0x0300 or 0x0400).

Within a row the pixels are stored left to right in groups of four. The first byte holds pixels 0, 1, 2, 3, the next byte holds pixels 4, 5, 6, 7, and so on.

Within a byte the four pixels may be stored right to left or left to right, depending on the PIX ORDR bit of the Cursor Control register. If PIX ORDR = 0 the pixels are stored right to left (3, 2, 1, 0); if PIX ORDR = 1 the pixels are stored left to right (0, 1, 2, 3).

## 7.2.1 Cursor Array Access

Cursor Array writes and reads are synchronized with the internal pixel clock, so the pixel clock must be running for microprocessor accesses to be valid. If this condition is met, the cursor array may be written or read at any time.

Microprocessor read accesses of the cursor array may disturb the cursor image if it is being displayed at that time. However, no more than one cursor pixel will be disturbed per cursor read access. Microprocessor write accesses of the cursor array will not disturb the cursor.

#### 7.2.2 Cursor Array Writes

A write to the cursor array is accomplished by writing the Index High and Index Low registers with an index address for the array (0x0100-0x04ff), followed by a write of the desired data to Index Data. If auto-increment is turned on, the entire array may be written sequentially by repeated writes to Index Data.

#### 7.2.3 Cursor Array Reads

To meet the bus timings for reads, the cursor array read data is pre-fetched. A pre-fetch is triggered by writing the Index High or Index Low register such that the resulting index address is for an entry in the array (0x0100 -- 0x04ff). At the end of the write cycle the cursor array will be read at the address held in the index address registers, and the read data will be held in an internal register. A subsequent read of Index Data will read this pre-fetched data. At the end of the read another pre-fetch will be triggered. If auto-increment is turned on, this pre-fetch will be for the next address in the array. Thus, the entire array can be read by repeated reads from Index Data.

The pre-fetching of cursor array data will stop if

- 1. The index register auto-increments beyond 0x04ff OR
- 2. A write is done to Index Data

#### 7.3 Cursor Modes

Each pixel of the cursor is specified with 2 bits. There are two fundamental ways to interpret these bits: Standard Modes and Advanced Mode.

The ACA ENAB (Advanced Cursor Attribute Enable) bit in the Advanced Cursor Control register selects either the Standard Cursor (ACA ENAB = '0') or the Advanced Cursor (ACA ENAB = '1').

For either cursor type, there are three cursor colors that may be displayed. The colors are stored in the Cursor Color 1 Red, Green, Blue, Cursor Color 2 Red, Green, Blue, and Cursor Color 3 Red, Green, Blue registers. Each red, green, and blue register is 8 bits, yielding a full 24-bit color for each of the three cursor colors. The cursor color is always 24 bits, and is not affected by the COL RES or 6BIT LIN control bits, or any of the pixel formats (VGA, 4, 8, 15/16, 24, 32 BPP).

The Advanced Cursor has an additional color, Color 0, which is always Black. That is, all 24 bits are '0's.

Both cursor types can generate three types of displayed pixels:

- Transparent the underlying pixel (the normally displayed pixel) is displayed. This pixel will either be a palette output or a formatted VRAM pixel, depending on whether the pixel format is VGA, indirect color, direct color or converted YUV.
- 2. Solid Color One of the three cursor colors is displayed (Cursor Color 1, 2 or 3). The Advanced Cursor can also display Cursor Color 0.
- Highlighted a bitwise complement of the underlying display pixel is displayed. The intent is to highlight the cursor by "reversing" the color of the background pixels.

The Advanced Cursor has an additional display type:

4. Translucent - the underlying pixel is "mixed" with one of the Cursor Colors (0, 1, 2 or 3), such that a "dimmed" version of the underlying pixel appears to "shine through" a translucent version of the Cursor Color.

This is achieved by shifting each red, green and blue component of the underlying pixel right by 1 bit (dimming the pixel by dividing by 2). The cursor color is mixed in by setting the now vacant high order bit of each component of the display pixel with the high order bit of the corresponding Cursor Color component.

#### 7.3.1 Standard Cursor

The Standard Cursor modes are used when the cursor is ON (CURSOR MODE not equal to '00'), and the Advanced Attributes are OFF (ACA ENAB = '0').

The Standard Cursor has three modes of display, specified with the remaining bit values of CURSOR MODE (CURSOR MODE = '01', '10' or '11'). The two cursor pixel bits can select one of three colors, one of two colors plus highlighting, or just two colors (where the selected cursor colors are solid colors):

**Table 7. Standard Cursor Modes** 

|                 | DISPLAY PIXEL                 |                               |                               |  |  |
|-----------------|-------------------------------|-------------------------------|-------------------------------|--|--|
| CURSOR<br>PIXEL | Mode 0<br>CURSOR<br>MODE = 01 | Mode 1<br>CURSOR<br>MODE = 10 | Mode 2<br>CURSOR<br>MODE = 11 |  |  |
| 00              | Transparent                   | Cursor Color 1                | Transparent                   |  |  |
| 01              | Cursor Color 1                | Cursor Color 2                | Transparent                   |  |  |
| 10              | Cursor Color 2                | Transparent                   | Cursor Color 1                |  |  |
| 11              | 11 Cursor Color 3             |                               | Cursor Color 2                |  |  |

#### 7.3.2 Advanced Cursor

The Advanced Cursor mode is used when the cursor is ON (CURSOR MODE not equal to '00'), and the Advanced Attributes are ON (ACA ENAB = '1').

For the Advanced Cursor, the two cursor pixel bits simply select one of four colors:

**Table 8. Advanced Cursor Colors** 

| CURSOR PIXEL | CURSOR COLOR |
|--------------|--------------|
| 00           | Color 0      |
| 01           | Color 1      |
| 10           | Color 2      |
| 11           | Color 3      |

Associated with each color is a two bit Attribute. The Attribute specifies the display of the cursor pixel:

**Table 9. Advanced Cursor Attributes** 

| ATTRIBUTE | DISPLAY PIXEL |
|-----------|---------------|
| 00        | Transparent   |
| 01        | Solid color   |
| 10        | Translucent   |
| 11        | Highlighted   |

The attribute values for each color are set in the Advanced Cursor Attribute register. This register contains a two bit attribute value for each of the four colors.

Example: Suppose a given cursor pixel value read from the cursor array is '01'. From Table 8, Cursor Color 1 will be selected.

Bits 3 and 2 of the Advanced Cursor Attribute register contain the attribute value for Color 1. Suppose these bits are '01'. This specifies a solid color, so the values in the Cursor Color 1 Red, Green and Blue registers will be displayed.

If Bits 3 and 2 of the Advanced Cursor Attribute register were '10', a translucent pixel would be selected, and the values in the Cursor Color 1 Red, Green and Blue registers would be mixed in with the underlying pixels for display.

# 7.4 Cursor Hot Spot

The hot spot is the point within the cursor that is used to locate the cursor's position on the screen. Any pixel within the cursor may be identified as the hot spot.

The Cursor Hot Spot X and Cursor Hot Spot Y registers hold the unsigned cursor pixel X (column) and Y (row) coordinates for the hot spot. The range for the X and Y values is 0 to 31 for the  $32 \times 32$  cursor and 0 to 63 for the  $64 \times 64$  cursor.

#### 7.5 Cursor Position

The Cursor X Low, Cursor X High, Cursor Y Low, and Cursor Y High registers specify the position of the cursor (the cursor hot spot) on the screen.

The X and Y positions are specified as *signed* numbers in two's complement format. The High and Low pairs yield 16-bit position registers, of which 12 bits plus a sign bit are used.

The hardware automatically extends the sign bit into the unused bit positions of the position registers. The valid X and Y ranges are -4096 to +4095.

The X and Y screen coordinates are for non-border display pixels. (0,0) is the upper left corner pixel of the screen that is not in the border area. The X value increases positively left-to-right, and the Y value increases positively top-to-bottom. Negative X values are to the left of the non-border display area and negative Y values are above the top of the non-border display area.

The cursor is clipped by the edges of the screen if there is no border, or by the border if a border is used. For example, if the hot spot is (0,0) the full cursor will be displayed in the upper left corner if the X position is +0 and the Y position is +0. If the X value is changed to -1 (0xffff) only columns 1 through 31 of the cursor will be displayed. If the X value is -31 (0xffe1) only column 31 of the cursor will be displayed. If the X value is more negative than -31 the cursor will not be displayed.

#### 7.6 Interlace

The selection of cursor rows for display is changed if interlace mode is specified. This is controlled with the INTL MODE bit of the Miscellaneous Control 2 register.

In non-interlaced mode, the cursor rows are displayed sequentially, starting with the first non-clipped row to be displayed based on the Y position and Y Hot Spot register contents.

When interlaced mode is specified, the ODD/ $\overline{EVEN}$  signal (actually  $\overline{BORDER}/O\overline{E}$ , see below) is used to determine if odd or even scan lines are being displayed. If  $\overline{ODD/EVEN}$  is low (even field), the first non-clipped cursor row that falls on an even scan line is displayed. Similarly if  $\overline{ODD/EVEN}$  is high (odd field), the first non-clipped cursor row that falls on an odd scan line is displayed. In either case, if the first cursor line displayed is an even-numbered cursor row (as determined by Y Position and Y Hot Spot) then successive even-numbered cursor rows will be displayed during that field. If the first cursor line displayed is an odd-numbered cursor row then successive odd-numbered cursor rows will be displayed during that field.

ODD/EVEN should only change during vertical blanking time for proper cursor display.

The ODD/EVEN input is actually the shared input pin BORDER/OE, where the usage of the pin is determined by the BRDR/INTL of the Miscellaneous Control 2 register. BRDR/INTL must be set to INTL for using the cursor with interlaced mode. If BRDR/INT is set as BRDR then the INTL MODE bit will be ignored (non-interlaced mode will be used).

# 7.7 Cursor Update and Display

#### 7.7.1 Position

Writing any of the Cursor X Low, Cursor X High, or Cursor Y Low registers will not affect the position of the cursor on the screen. When the Cursor Y High register is written, the X and Y positions are captured in a second set of registers.

When vertical blanking is detected (see 6.3 "Vertical Blanking" on page 18), the "captured" X and Y positions are sampled. The sampled position is saved until it is resampled on the next vertical blanking time. Between vertical blanking times the sampled position is used, along with the Cursor Hot Spot, to calculate which pixels of the cursor are used and where they are displayed on the screen.

When INTL MODE is set the ODD/EVEN signal is examined at the end of vertical blanking to determine if only even or only odd rows will be displayed.



#### 7.7.2 Controls

When vertical blanking is detected the Cursor Control register is sampled along with the X and Y position registers. This allows the cursor to be toggled on and off on a frame-by-frame basis with the CURSOR MODE bits, and if the cursor is 32x32, it allows toggling among the four slots on a frame-by-frame basis using the SMLC SLOT bits.

Note that in interlace mode the sampling is on a fieldby-field basis. Also, since the PIX ORDER and CURS SIZE bits are also sampled these functions will only change when vertical blanking is detected.

#### 7.7.3 Other

Changes to the Cursor Color registers and the Cursor X and Y Hot Spot registers are propagated to the cursor logic as soon as they are made, so if they are updated while the cursor is being displayed the cursor image will be disturbed.

Changes to the cursor array are also propagated to the cursor logic as soon as they are made. Also, as noted above, microprocessor read accesses of the cursor array may interfere with the cursor display logic. For example, with a 32 x 32 cursor being displayed from slot 0, microprocessor read accesses to slot 1 may cause the display of the slot 0 cursor to be disturbed.

It is recommended that Cursor Array Reads and changes to the Cursor Color registers and the Cursor X and Y Hot Spot registers be made only when the cursor is disabled, off screen, or during vertical blanking time.

# 8.0 DAC Control

Several miscellaneous features of the DACs are controlled by the DAC Operation register.

# 8.1 SOG - Composite Sync-On-Green

When the SOG bit is set, composite sync will be merged with the pixel data on the green DAC.

The source of the composite sync can be the signal on the  $\overline{HCSYNCIN}$  input, or an internally generated (synthetic) sync signal formed by the XOR of the signals on the  $\overline{HCSYNCIN}$  and  $\overline{VSYNCIN}$  inputs. The incoming  $\overline{HCSYNCIN}$  signal may be inverted and/or delayed before presentation at the DAC. See sections 6.5 through 6.7 for more details.

#### 8.2 BRB - Blank Red and Blue DACs

When this is set the red and blue DACs are set to the blanking level. This is intended for use when a monochrome display is driven by the green DAC.

#### 8.3 DSR - DAC Slew Rate

This bit affects the rise and fall times of the DAC analog outputs (slew rate). The default value (on) uses a "slow" rate, typically 5 ns. When the bit is set to "off", the slew rate will be "fast", typically 2 ns. The rise and fall times are measured using the 10% point and 90% point.

The faster slew rate will yield the sharpest pixels if the monitor can support that rate. For some monitors it may be desirable to set the DACs to the slower slew rate.

**Note:** The default value of "on" is new to the RGB6xx and RGB526RGB526DB products. For most of the RGB51x and RGB52x products the default value is "off".

## 8.4 DPE - DAC Blanking Pedestal Enable

When off, the DAC pedestal is disabled (blanking level = 0 IRE). When on, the pedestal is enabled (7.5 IRE).

# 9.0 Power Management

The following registers are used to control power dissipation:

- ☐ Power Management (index 0x0005)
- ☐ Miscellaneous Clock Control (index 0x0002)
- ☐ Sync Control (index 0x0003)
- ☐ Miscellaneous Control 1 (index 0x0070)

#### 9.1 DAC Power

The analog portion of the DACs can be shut down with the DAC PWR bit of the Power Management register. A small amount of current (approximately 100  $\mu A)$  will continue to be drawn through the VREFIN input. This can be eliminated if the voltage on VREFIN is reduced to 0 V.

#### 9.2 Driver Power

The power dissipated by the logic output signals can be reduced by 3-stating the drivers. This is done for the SCLK driver by setting the SCLK DSAB bit of the Miscellaneous Clock Control register. The DDOTCLK driver can also be 3-stated by setting the DDOT DSAB bit of the Miscellaneous Clock Control register. HSYNCOUT and VSYNCOUT are 3-stated by setting HSYN CNTL and VSYN CNTL bits of the Sync Control register. The SENSE output is 3-stated by setting the SENS DSAB bit of the Miscellaneous Control 1 register.

The remaining drivers are the microprocessor D[7:0] signals. These are normally 3-stated and will not dissipate power unless a microprocessor read is performed.

# 9.3 Clocking Power

Most of the digital logic power dissipation occurs as a result of clocking. The ICLK PWR, SCLK PWR, DDOT PWR, and SYNC PWR bits of the Power Management register are used to inhibit the digital logic clocking.

The ICLK PWR bit, when set, inhibits all internal clocking except for the following:

- ☐ The PLL.
- ☐ The palette arrays and the cursor array control logic. The clocks to the internal logic are left running because this is required for microprocessor access.
- □ SCLK and DDOTCLK The circuitry that generates these clocks is left running in case external components need to run off these clocks.
- ☐ The horizontal and vertical sync delay circuits. These circuits are left running to allow sync signals to propagate to the display monitor.

When the ICLK PWR bit is set the DAC outputs will remain stuck at whatever was last clocked into the DACs, unless the DACs are shut down with DAC PWR.

The SCLK PWR bit may be set to disable the clocking to the SCLK generator. The resultant static SCLK output may be left at either the low or high state. As noted above, the SCLK output may be 3-stated with the SCLK DSAB bit of the Miscellaneous Clock Control register.

The DDOT PWR bit may be set to disable the clocking to the DDOTCLK generator. The resultant static DDOT-CLK output may be left at either the low or high state. As noted above, the DDOTCLK output may be 3-stated with the DDOT DSAB bit of the Miscellaneous Clock Control register.

The SYNC PWR bit may be set to disable the clocking to the horizontal and vertical sync circuits. These outputs may be left at either the low or high state. (But note that the outputs can be forced high or low or 3-stated with the HSYN CNTL and VSYN CNTL bits of the Sync Control register.)

The starting and stopping of clocks with the SCLK PWR, DDOT PWR, and SYNC PWR bits is asynchronous. Thus, "chopped" pulses may be produced on the SCLK, DDOTCLK, HSYNCOUT and VSYNCOUT outputs when these bits are changed.

Similarly, changing the ICLK PWR bit can disturb the stopping and starting of the internal clocks such that the display is disturbed for a frame. It is recommended

that the DACs be blanked with the BLANK CNTL bit of the Miscellaneous Control 2 register before shutting off the clocks, and that a frame be run by after turning on the clocks before the DACs are unblanked again with BLANK CNTL.

#### 9.4 PLL Power

The PLL uses approximately 3 mW of power. It can be shut off with the PLL ENAB bit of the Miscellaneous Clock Control register. This, in conjunction with turning off the DACs and 3-stating the drivers, produces the lowest power consumption.

Note that in general the PLL drives SCLK, and the incoming LCLK is generally derived externally from SCLK. If the PLL is disabled, SCLK will stop running regardless of the setting of SCLK PWR, DDOTCLK will stop running regardless of the setting of DDOT PWR, internal clocking will stop regardless of the setting of ICLK PWR, sync signal clocking will stop regardless of the setting of SYNC PWR, and external circuitry running off SCLK and/or DDOTCLK will stop running.

If EXTCLK is used instead of the PLL the same effect can be achieved by stopping EXTCLK.

# 10.0 Diagnostic Support

#### 10.1 Data Masks

The Pixel data inputs may be masked by the VRAM Mask registers to diagnose frame buffer problems. Each active bit in the VRAM Mask register controls four bits of the pixel port. Masked bytes introduce zeroes into the data path.

# 10.2 MISR

The MISR (Multiple Input Signature Register) consists of three registers, MISR Red, MISR Green and MISR Blue. Together the three registers form a 24-bit shift register with feedback to accumulate a signature of the data presented to the DACs during one screen frame. In interlace mode accumulation of a frame starts with an ODD field followed by an EVEN field.

Signature accumulation is controlled by the MISR CNTL bit in the Miscellaneous Control 1 register, and detection of vertical blanking. The MISR DONE bit in the MISR Status register indicates when a signature has been accumulated.

Signature accumulation uses the following sequence:

- Write the Miscellaneous Control 1 register to change the MISR CNTL bit from '0' to '1'.
- 2. The next detection of vertical blanking (as defined in section 6.3) will "arm" the MISR circuits.
- 3. The start of the next frame (in non-interlace mode when the  $\overline{BLANK}$  input goes from low to high; in interlace mode when the  $\overline{BLANK}$  input goes from low to high and the  $\overline{BORDER}/O\overline{E}$  input is high to indicate an ODD field) resets the three MISR registers, resets the MISR DONE bit, and starts the accumulation of the signature.
- A signature is accumulated for all pixel data presented to the DACs in a frame. Note that this includes border pixels and cursor pixels if they are displayed.
- 5. Signature accumulation stops with the next detection of vertical blanking, for non-interlace mode, or the detection of vertical blanking at the end of an EVEN field in interlace mode. At this point the three MISR registers are frozen and the MISR DONE bit changes from '0' to '1'.

The accumulated signature can now be read from the MISR Red, MISR Green and MISR Blue registers.

When the MISR CNTL bit is changed from '0' to '1' it must stay at '1' throughout the signature accumulation, until the MISR DONE bit changes to '1'. At this point, leaving the MISR CNTL bit at '1', or changing it back to '0', will perform no action. The MISR DONE bit will remain at '1' and the three MISR registers will retain their contents.

To accumulate another signature the MISR CNTL bit must be reset to '0' and then set to '1'. A new signature will be accumulated using the sequence listed above.

# 10.3 DAC Comparators

Each DAC output is connected to a comparator. Both latched and unlatched copies of the comparator outputs can be read from the DAC Sense register. The logical AND of either the latched or unlatched comparator bits is presented on the  $\overline{SENSE}$  output. The reference inputs of the comparators are connected to the chip CVREF pin. With the internally applied reference voltage of 0.35 V, the corresponding Sense bit will be '1'b when the DAC output is 0 to 0.28 V or '0'b when it is 0.42 V to 0.70 V. These values apply when the DAC is doubly terminated in 75  $\Omega$ , RREF=698  $\Omega$ , and no sync or blank is present.

# 11.0 Internal Register - Summary

Table 10 is a summary of the internal registers. Detailed descriptions are given in Section 12.0.

For correct operation, and to preserve upward compatibility, the registers listed as "Reserved" must not be written to. Within a register, individual bits listed as "Reserved" must be set to '0's.

Table 10. Internal Register Summary

| 000         -         ✓         U         Palette Ad Mode)           001         -         ✓         U         Palette Da           010         -         ✓         U         Pixel Masl | k<br>Idress (Read |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| Mode)   001                                                                                                                                                                              | k<br>Idress (Read |
| 010 - ✓ U Pixel Masl                                                                                                                                                                     | k<br>Idress (Read |
| 1 1101 11105                                                                                                                                                                             | ldress (Read      |
| 011 - ✓ U Palette Δd                                                                                                                                                                     |                   |
| Mode)                                                                                                                                                                                    | 7                 |
| 100 - ✓ U Index Low                                                                                                                                                                      |                   |
| 101 - ✓ U Index High                                                                                                                                                                     | h                 |
| 110 - ✓ U Index Data<br>Registers)                                                                                                                                                       | a (Indexed        |
| 111 - ✓ U Index Con                                                                                                                                                                      | trol              |
| 110 0x0000 RO Rev Revision L                                                                                                                                                             | Level             |
| 110 0x0001 RO 0x02 ID                                                                                                                                                                    |                   |
| 110 0x0002 ✓ 0x01 Miscellane Control                                                                                                                                                     | eous Clock        |
| 110 0x0003 ✓ 0x00 Sync Cont                                                                                                                                                              | rol               |
| 110 0x0004 ✓ 0x00 Horizontal Position                                                                                                                                                    | l Sync            |
| 110 0x0005 ✓ 0x00 Power Ma                                                                                                                                                               | nagement          |
| 110 0x0006 ✓ 0x02 DAC Oper                                                                                                                                                               | ation             |
| 110 0x0007 ✓ 0x00 Palette Co                                                                                                                                                             | ntrol             |
| 110 0x0008 ✓ 0x01 System Cl                                                                                                                                                              | ock Control       |
| 110 0x0009 (Reserved)                                                                                                                                                                    | )                 |
| 110 0x000a ✓ U Pixel Form                                                                                                                                                                | nat               |
| 110 0x000b ✓ U 8 BPP Cor                                                                                                                                                                 | ntrol             |
| 110 0x000c ✓ U 16 BPP Co                                                                                                                                                                 | ontrol            |
| 110 0x000d   U 24 BPP Pa Control                                                                                                                                                         | ncked             |
| 110 0x000e ✓ U 32 BPP Co                                                                                                                                                                 | ontrol            |
| 110 0x000f (Reserved)                                                                                                                                                                    | )                 |
| 110 0x0010 ✓ 0x00 Pixel PLL                                                                                                                                                              | Control 1         |
| 110 0x0011 ✓ 0x00 Pixel PLL                                                                                                                                                              | Control 2         |
| 110 0x0012 (Reserved)                                                                                                                                                                    | )                 |
| 110 0x0014 ✓ 0x05 (Fixed Pix Reference                                                                                                                                                   |                   |

Table 10. Internal Register Summary (Continued)

| RS[2:0] Index R/W        | Reset<br>Value | Register Name                |
|--------------------------|----------------|------------------------------|
| 110 0,0015 /             |                |                              |
| 110 0x0015 V             | 0x08           | SYSCLK N<br>(System PLL      |
|                          |                | Reference Divider)           |
| 110 0x0016 ✓             | 0x41           | SYSCLK M                     |
|                          |                | (System PLL VCO<br>Divider)  |
| 110 0x0017 ✓             | U              | SYSCLK P                     |
| 110 0x0018 ✓             | U              | SYSCLK C                     |
| 0x0019 - 0x001f          | -              | (Reserved)                   |
| 110 0x0020 ✓             | 0x05           | Pixel M0 (F0/M0)             |
| 110 0x0021 🗸             | 0x0e           | Pixel N0 (F1/N0)             |
| 110 0x0022 ✓             | 0x00           | Pixel P0 (F2/M1)             |
| 110 0x0023 ✓             | 0x00           | Pixel C0 (F3/N1)             |
| 110 0x0024 ✓             | 0x00           | Pixel M1 (F4/M2)             |
| 110 0x0025 ✓             | 0x00           | Pixel N1 (F5/N2)             |
| 110 0x0026 ✓             | 0x00           | Pixel P1 (F6/M3)             |
| 110 0x0027 ✓             | 0x00           | Pixel C1 (F7/N3)             |
| 110 0x0028 ✓             | 0x00           | Pixel M2 (F8/M4)             |
| 110 0x0029 ✓             | 0x00           | Pixel N2 (F9/N4)             |
| 110 0x002a ✓             | 0x00           | Pixel P2 (F10/M5)            |
| 110 0x002b ✓             | 0x00           | Pixel C2 (F11/N5)            |
| 110 0x002c ✓             | 0x00           | Pixel M3 (F12/M6)            |
| 110 0x002d ✓             | 0x00           | Pixel N3 (F13/N6)            |
| 110 0x002e ✓             | 0x00           | Pixel P3 (F14/M7)            |
| 110 0x002f ✓             | 0x00           | Pixel C3 (F15/N7)            |
| 110 0x0030 ✓             | 0x00           | Cursor Control               |
| 110 0x0031 ✓             | U              | Cursor X Low                 |
| 110 0x0032 ✓             | U              | Cursor X High                |
| 110 0x0033 ✓             | U              | Cursor Y Low                 |
| 110 0x0034 ✓             | U              | Cursor Y High                |
| 110 0x0035 ✓             | U              | Cursor Hot Spot X            |
| 110 0x0036 ✓             | U              | Cursor Hot Spot Y            |
| 110 0x0037 🗸             | 0x00           | Advanced Cursor<br>Control   |
| 110 0x0038 ✓             | U              | Advanced Cursor<br>Attribute |
| 110 0x0039 -<br>0x003f - | -              | (Reserved)                   |
| 110 0x0040 ✓             | U              | Cursor Color 1 Red           |
| 110 0x0041 ✓             | U              | Cursor Color 1 Green         |
| 110 0x0042 ✓             | U              | Cursor Color 1 Blue          |

Table 10. Internal Register Summary (Continued)

|         | 10. 111101         | nai itogi | otor our       | illiary (Continueu)         |
|---------|--------------------|-----------|----------------|-----------------------------|
| RS[2:0] | Index              | R/W       | Reset<br>Value | Register Name               |
| 110     | 0x0043             | 1         | U              | Cursor Color 2 Red          |
| 110     | 0x0044             | 1         | U              | Cursor Color 2 Green        |
| 110     | 0x0045             | 1         | U              | Cursor Color 2 Blue         |
| 110     | 0x0046             | 1         | U              | Cursor Color 3 Red          |
| 110     | 0x0047             | 1         | U              | Cursor Color 3 Green        |
| 110     | 0x0048             | 1         | U              | Cursor Color 3 Blue         |
| 110     | 0x0049 -<br>0x005f | -         | -              | (Reserved)                  |
| 110     | 0x0060             | 1         | U              | Border Color Red            |
| 110     | 0x0061             | 1         | U              | Border Color Green          |
| 110     | 0x0062             | 1         | U              | Border Color Blue           |
| 110     | 0x0063 -<br>0x0067 | -         | -              | (Reserved)                  |
| 110     | 0x0068             | ✓         | U              | Key                         |
| 110     | 0x0069 -<br>0x006b | -         | -              | (Reserved)                  |
| 110     | 0х006с             | 1         | U              | Key Mask                    |
| 110     | 0x006d -<br>0x006f | -         | -              | (Reserved)                  |
| 110     | 0x0070             | 1         | 0x00           | Miscellaneous<br>Control 1  |
| 110     | 0x0071             | 1         | 0x00           | Miscellaneous<br>Control 2  |
| 110     | 0x0072             | 1         | 0x00           | Miscellaneous<br>Control 3  |
| 110     | 0x0073 -<br>0x0077 | -         |                | (Reserved)                  |
| 110     | 0x0078             | <b>*</b>  | 0x00           | Key Control/DB<br>Operation |
| 110     | 0x0079 -<br>0x0081 | -         |                | (Reserved)                  |
| 110     | 0x0082             | RO        | U              | DAC Sense                   |
| 110     | 0x0083             | RO        | 0x00           | MISR Status                 |
| 110     | 0x0084             | RO        | U              | MISR Red                    |
| 110     | 0x0085             | -         | -              | (Reserved)                  |
| 110     | 0x0086             | RO        | U              | MISR Green                  |
| 110     | 0x0087             | -         | -              | (Reserved)                  |
| 110     | 0x0088             | RO        | U              | MISR Blue                   |
| 110     | 0x0089 -<br>0x008b | -         | -              | (Reserved)                  |

Table 10. Internal Register Summary (Continued)

| RS[2:0] | Index              | R/W      | Reset<br>Value                                                                      | Register Name                                           |
|---------|--------------------|----------|-------------------------------------------------------------------------------------|---------------------------------------------------------|
| 110     | 0x008c             | RO       | U                                                                                   | Pixel P Input                                           |
| 110     | 0x008d             | RO       | U                                                                                   | Pixel C Input                                           |
| 110     | 0x008e             | RO       | 0x05<br>(FS[1:0] = 00)<br>0x0e<br>(FS[1:0] = 01)<br>0x00<br>(FS[1:0] = 10 or<br>11) | Pixel M Input<br>(Pixel PLL VCO<br>Divider Input)       |
| 110     | 0x008f             | RO       | 0x05                                                                                | Pixel N Input<br>(Pixel PLL Reference<br>Divider Input) |
| 110     | 0x0090             | 1        | U                                                                                   | VRAM Mask Low                                           |
| 110     | 0x0091             | ✓        | U                                                                                   | VRAM Mask High                                          |
| 110     | 0x0092 -<br>0x00ff | -        | -                                                                                   | (Reserved)                                              |
| 110     | 0x0100 -<br>0x04ff | 1        | U                                                                                   | Cursor Array                                            |
| 110     | 0x0500<br>0x07ff   | -        | -                                                                                   | (Reserved)                                              |
| RO=Rea  | d Only, U=         | Undefine | d, Rev=Re                                                                           | evision Level                                           |



# 12.0 Register Descriptions

# 12.1 Direct Access Registers

The direct access registers are addressed using RS[2:0] inputs.

#### Palette Address (Write Mode)



**RS[2:0]**: 000

Access: Read/Write
Power on Value: Undefined

Bits 7 - 0 WRITE Address - Palette address in

write mode.

Operation of this register is discussed in 1.0 "Microprocessor Access" on page 1.

#### **Palette Data**



**RS[2:0]**: 001

Access: Read/Write Power on Value: Undefined

The format of the palette data depends on the color resolution, 6 or 8 bit.

#### 6 bit color resolution

Miscellaneous Control 2 COL RES = 0

**Bits 7 - 6** 00

Bits 5 - 0 6 bit palette data

On WRITEs bits 7:6 from the microprocessor are discarded, bits 5:0 are written to bits 7:2 internally, and internal bits 1:0 are set to '00'. On reads internal bits 7:2 are read as bits 5:0, an bits 7:6 are returned as '00'.

#### 8 bit color resolution

Miscellaneous Control 2 COL RES = 1

**Bits 7-0** 8 bit palette data. Bits 7:0 are writ-

ten/read internally as bits 7:0

Operation of this register is discussed in 1.0 "Microprocessor Access" on page 1.

#### **Pixel Mask**



**RS[2:0]**: 010

Access: Read/Write
Power on Value: Undefined
Bits 7 - 0 Pixel Mask

In indirect color modes this register masks the pixel values used to index into the palettes. Each bit is ANDed with its corresponding pixel bit. A value of 0xff is required to pass the pixel values to the palettes unchanged

The same mask is applied to each of the red, green, and blue pixel addresses into the palettes.

## Palette Address (Read Mode) / Palette Access State



RS[2:0]: 011
Access: Write
Power on Value: -

Bits 7 - 0 READ Address - Palette address in

read mode.



RS[2:0]: 011
Access: Read
Power on Value: Undefined

**PADR RFMT**: 0

Bits 7 - 0 READ Address - Palette address in

read mode.



RS[2:0]: 011
Access: Read
Power on Value: Undefined

PADR RFMT: 1

Bits 7 - 2 Reserved

Bits 1 - 0 ACC STATE - Palette Access State.

Reports which mode was used on last write of Palette Address Register.

00 Write Mode11 Read Mode

Note that the palette address to be read is written into this register, but the contents that are read depends on the PADR RFMT bit in the Miscellaneous Control 1 register. Operation of these registers is discussed in 1.0

"Microprocessor Access" on page 1.

#### **Index Low**



**RS[2:0]**: 100

Access: Read/Write
Power on Value: Undefined
Bits 7 - 0 Index Low

This register, together with Index High, forms the internal index register. It selects the register that will be accessed when the Indexed Data register is written or read.

## Index High



**RS[2:0]**: 101

Access: Read/Write
Power on Value: Undefined
Bits 7 - 3 Reserved
Bits 2 - 1 Index High

This register provides the high-order bits of the internal index register.

If auto-increment is turned on, the resulting index is not defined if an increment past the maximum index value occurs.

## **Indexed Data**



**RS[2:0]**: 110

Access: Read/Write
Power on Value: Undefined
Bits 7 - 0 Indexed Data

A write or read to this register will write or read the register addressed by the internal index register (Index High and Index Low).

Following a write or read to Indexed Data, the index register will be incremented if auto-increment is turned on (INDX CNTL bit of the Index Control register).



#### **Index Control**

Bit 0



**RS[2:0]**: 111

Access: Read/Write
Power on Value: Undefined
Bits 7 - 1 Reserved

INDX CNTL - Index Control. Con-

trols auto-increment of the index reg-

ister.

0 Off - no auto-increment.

 On - the index register (Index High and Index Low) will increment by one following a write or read to Indexed Data.

## 12.2 Indexed Registers

The indexed registers are accessed by setting the desired address into the internal index register (Index High and Index Low) and writing or reading the Indexed Data register.



#### 12.2.1 **Miscellaneous Control**

#### **Miscellaneous Control 1**



Index: 0x0070 Access: Read/Write

Power on Value: 0x00

MISR CNTL Bit 7

> Off. If the MISR is running, it will stop at the beginning of the

next frame.

On. The MISR will start accumulating a signature at the start of the next frame (end of

vertical blanking).

Bit 6 VMSK CNTL - VRAM Mask Control

No VRAM masking.

The VRAM inputs on the 1 PIX[63:00] inputs will be masked under control of the VRAM Mask High and VRAM Mask Low registers.

This bit has no effect when the VGA

port is selected.

PADR RFMT - Palette Address Reg-Bit 5

ister (Read Mode) Format. Specifies the contents returned from the Palette Address register, read mode

(RS[2:0] = 011)

Return the eight bits of the read address

1 Return the palette access state in the two low order bits

SENS DSAB -SENSE Driver Disable Bit 4

SENSE driver enabled

SENSE driver disabled (3-1 stated)

Bit 3

SENS SEL - Sense Select. Selects which bit of the DAC Sense register is presented on the  $\overline{SENSE}$  driver.

0 Bit 3 - Unlatched Sense

1 Bit 7 - Latched Sense Bit 2 XOR SYNC - Composite Sync Source. Selects source of composite sync.

> Composite sync taken from HCSYNCIN input.

1 Composite sync generated internally from XOR of HCSYNCIN input and VSYN-

CIN input. RSVD - Reserved

Bit 1 Bit 0 VRAM SIZE - VRAM interface width

> 32 bits. PIX[31:0] used, PIX[63:32] ignored.

64 bits. PIX[63:00] used.

(This bit has no effect when the VGA port is selected.)

### **Miscellaneous Control 2**

0x0071 Index: Read/Write Access: Power on Value: 0x00

Bits 7 - 6 PCLK SEL - Pixel Clock Select. Spec-

ifies the source of the internal pixel

clock.

00 LCLK input

01 Internal PLL output

**REFCLK** input 10

11 Reserved

Note: A selection of 00 (LCLK input) for the pixel clock is required and only valid when PORT SEL = 0 (VGA data inputs), or 32 BPP is selected with a VRAM

width of 32.

Bit 5 INTL MODE - Interlace Mode. Controls effect of BORDER/OE input on

cursor when this input is used as the ODD/EVEN interlace control.

Non-interlaced. The BOR- $\overline{DER}/O\overline{E}$  input is ignored.

Interlaced. If the cursor is turned on, the  $\overline{BORDER}/O\overline{E}$ input will be used to select display of the odd or even cursor

rows.

This bit has no effect when BRDR/INTL (bit 1) is set '0' (BOR-

Bit 4 **BLANK CNTL - Blanking Control** 

data is presented on the DACs, but all other operations remain normal, including the collection of a signature if the MISR is turned on.

Bit 3 Bit 2

Bit

Bit 0

RSVD - Reserved

**COL RES - Color Resolution** 

6-bit 0

8-bit

With 6-bit color resolution only 6 bits of microprocessor data are loaded into the palettes. Microprocessor data bits D[5:0] are written to/read from palette bits [7:2]. Internally 00 is written to palette bits [1:0], and on

reads D[7:6] are forced to 00.

Also with 6-bit color resolution the two low order bits presented from the palettes to the DACs are controlled by Palette Control bit 6BIT LIN.

With 8-bit color resolution all 8 bits from/to the microprocessor are written/read to the palette, and the 8 bits presented to the DACs are unmodified. The 6BIT LIN bit has no effect. BRDR/INTL - Border/Interlace. Con-

trols usage of  $\overline{BORDER}/O\overline{E}$  input. BORDER/OE input used to

indicate "BORDER". (Interlace operation is not supported.)

BORDER/OE input used to 1 indicate "ODD/EVEN". (Border operation is not supported.)

PORT SEL - Port Select

0 VGA Data inputs.

VRAM pixel port inputs.

DER/OE used as BORDER input).

Normal operation. 0

DACs are blanked. No pixel

## **Miscellaneous Control 3**

 7
 6
 5
 4
 3
 2
 1
 0

 SWAP RB
 Reserved RB
 SWAP BYTE
 SWAP BYTE
 NIB MODE

Index: 0x0072
Access: Read/Write
Power on Value: 0x00

Bit 7 SWAP RB - Swap Red and Blue pixel

components. In 16, 24, and 32 BPP, this bit causes the red and blue components of the pixels to be swapped. In indirect mode, the swapping takes place before the Palette.

0 Normal operation.

1 Swap Red and Blue components of the pixel. This bit only has an effect in 16, 24, and 32 BPP.

Bits 6 - 4 Reserved

Bit 1

**Bits 3 - 2** SWAP BYTE - Controls swapping of the incoming bytes on the PIX[63:00]

inputs.

00 Normal operation.

01 Reserved

10 Reserved

11 For each pair of bytes on the PIX[63:00] inputs, swap the incoming bytes.

When byte swapping is enabled the swapping is in effect and is identical for all VRAM pixel formats (4, 8 16, 24 or 32 BPP).

SWAP NIB - Swap nibbles within bytes. Used with 4 BPP.

0 Use high nibble (e.g., PIX[07:04]) for first pixel, use low nibble (e.g., PIX[03:00]) for next pixel.

1 Use low nibble (e.g., PIX[03:00]) for first pixel, use high nibble (e.g., PIX[07:04]) for next pixel.

The same nibble order is applied to each of the incoming bytes. This bit has no effect if the pixel format is not 4 BPP.

Bit 0 DBUF MODE - Double Buffer Mode Enable. Used with 16 BPP.

This register has no effect when the VGA port is selected.

HSYN CNTL

## **Miscellaneous Clock Control**

| Index:         | 0x0002                                                                                                                          | Index:                | 0x0003                                                                                                                                                                         |
|----------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Access:        | Read/Write                                                                                                                      | Access:               | Read/Write                                                                                                                                                                     |
| Power on Value | : 0x01                                                                                                                          | <b>Power on Value</b> | : 0x00                                                                                                                                                                         |
| Bit 7          | DDOT DSAB - DDOTCLK driver disable  DDOTCLK driver enabled  DDOTCLK driver enabled  DDOTCLK driver disabled (3-stated)          | Bit 7                 | DLY CNTL - Sync Delay Control. Specifies whether delay matching the pixel pipeline delay should be added to the horizontal sync signal.  O Add matching delay Do not add delay |
| Bit 6          | SCLK DSAB - SCLK driver disable  O SCLK driver enabled  SCLK driver disabled (3-stated)                                         |                       | This bit only has effect when the SOG bit of the DAC Operation register is off. If SOG is on (composite sync enabled) then matching pipeline                                   |
| Bit 5          | B24P DDOT - Selects which clock is driven on DDOTCLK when 24 Bit Packed Pixel format is selected.  Use divided Pixel PLL output | Bit 6                 | delay is not added to horizontal sync.  CSYN INVT - Invert incoming  HCSYNCIN when used as Composite  Sync                                                                     |
|                | under control of DDOT DIV bits.  1 Output the same signal as                                                                    |                       | $\begin{array}{cc} 0 & \text{Do not invert incoming} \\ \hline HCSYNCIN \end{array}$                                                                                           |
|                | SCLK.                                                                                                                           | <b>7.</b>             | 1 Invert incoming HCSYNCIN                                                                                                                                                     |
|                | When a format other than 24 BPP                                                                                                 | Bit 5                 | VSYN INVT - Vertical Sync Invert                                                                                                                                               |
|                | Packed is selected, the B24P DDOT                                                                                               |                       | 0 Do not invert incoming<br>VSYNCIN                                                                                                                                            |
|                | bit has no effect and the divided                                                                                               |                       | 1 Invert incoming VSYNCIN                                                                                                                                                      |
| Bit 4          | Pixel PLL output is used.  SCLK INVT - Inverts the SCLK output.                                                                 | Bit 4                 | HSYN INVT - Invert incoming HCSYNCIN when used as Horizon-                                                                                                                     |
| Bits 3 - 1     | DDOT DIV - DDOTCLK divide fac-                                                                                                  |                       | tal Sync                                                                                                                                                                       |
|                | tor. Specifies the divide factor applied                                                                                        |                       | 0 Do not invert incoming HCSYNCIN                                                                                                                                              |
|                | to the internal Pixel PLL output to produce the DDOTCLK output sig-                                                             |                       | 1 Invert incoming HCSYNCIN                                                                                                                                                     |
|                | nal.                                                                                                                            | Bits 3 - 2            | VSYN CNTL - Vertical Sync Output                                                                                                                                               |
|                | 000 Pixel PLL out/1                                                                                                             |                       | Control                                                                                                                                                                        |
|                | 001 Pixel PLL out/2                                                                                                             |                       | 00 Normal output                                                                                                                                                               |
|                | 010 Pixel PLL out/4                                                                                                             |                       | 01 VSYNCOUT forced high                                                                                                                                                        |
|                | 011 Pixel PLL out/8                                                                                                             |                       | 10 VSYNCOUT forced low                                                                                                                                                         |
|                | 100 Pixel PLL out/16                                                                                                            |                       | 11 VSYNCOUT disabled (3-                                                                                                                                                       |
|                | 101 Reserved                                                                                                                    |                       | stated)                                                                                                                                                                        |
|                | <ul><li>110 Reserved</li><li>111 Reserved</li></ul>                                                                             | Bits 1 - 0            | HSYN CNTL - Horizontal Sync Output Control                                                                                                                                     |
| Bit 0          | PPLL ENAB - Pixel PLL Enable                                                                                                    |                       | 00 Normal output                                                                                                                                                               |
|                | 0 Pixel PLL programming                                                                                                         |                       | 01 HSYNCOUT forced high                                                                                                                                                        |
|                | disabled.                                                                                                                       |                       | 10 HSYNCOUT forced low                                                                                                                                                         |
|                | <ol> <li>Pixel PLL programming enabled.</li> </ol>                                                                              |                       | 11 HSYNCOUT disabled (3-stated)                                                                                                                                                |

**Sync Control** 

## **Horizontal Sync Control**

| /            | 7 | 6     | 5   | 4 | 3            | 2   | 1   | 0             |
|--------------|---|-------|-----|---|--------------|-----|-----|---------------|
|              | F | Reser | ved |   | Н            | SYN | POS |               |
| $\leftarrow$ |   |       |     |   | $\leftarrow$ |     |     | $\overline{}$ |

Index:0x0004Access:Read/Write

**Power on Value**: 0x00 **Bits 7 - 4** Reserved

Bits 3 - 0 HSYN POS - Horizontal Sync Posi-

tion. Specifies number of additional pixel delays to add to the horizontal sync signal and the composite sync

signal.

1001 9 pixels 1010 10 pixels 1011 11 pixels 1100 12 pixels 1101 13 pixels

1110 14 pixels 1111 15 pixels

If the SOG bit of the DAC Operation register is on, the additional pixel delays are added to composite sync. If SOG is off, then the delays are added to horizontal sync, under the control of the DLY CNTL bit of the Sync Control register. (The additional delay specified by the Horizontal Position register will only be added if DLY CNTL is set to 0.)

## **Power Management**



Index:0x0005Access:Read/Write

**Power on Value**: 0x00 **Bits 7 - 5** Reserved

Bit 4 SCLK PWR - SCLK Power Control

0 Normal Operation

1 Disable clocks to SCLK genera-

tor

Bit 3 DDOT PWR - DDOTCLK Power Con-

trol

0 Normal Operation

1 Disable clocks to DDOTCLK

generator

Bit 2 SYNC PWR - Sync Power Control

0 Normal Operation

1 Disable clocks to horizontal and

vertical sync circuits

Bit 1 ICLK PWR - Internal Clock Power

Control

0 Normal Operation

 Disable all internal clocks except those for the SCLK generator, DDOTCLK generator, and horizontal and vertical sync

circuits.

A clock is left running to allow microprocessor access of the palette and cursor array, but otherwise the palette and cursor RAMs will not be clocked. The two RAMs will retain their contents.

Bit 0 DAC PWR - DAC Analog Power Con-

trol

0 Normal Operation

1 Disable analog power to the DACs

## **DAC Operation**



Index: 0x0006
Access: Read/Write
Power on Value: 0x02

Bits 7 - 4 Reserved

Bit 3 SOG - Composite Sync-On-Green

Sync is disabled on Green DAC.Sync is enabled on Green DAC.

BRB - Blank Red and Blue DACs

0 Red and Blue DACs have nor-

mal function.

1 Red and Blue DACs are always

blanked.

Bit 1 DSR - DAC Slew Rate

0 Fast - typically 2 ns

1 Slow - typically 5 ns

Bit 0 DPE - DAC blanking Pedestal

**Enable** 

0 Blanking pedestal disabled (0 IRE)

1 Blanking pedestal enabled (7.5 IRE)

#### **Palette Control**



Index: 0x0007
Access: Read/Write

**Power on Value**: 0x00

Bit 7 6BIT LIN - 6 Bit Linear Color

Apply linear palette outputDo not apply linear palette out-

Do not apply linear palette out-

This bit only has effect with indirect color modes, and when Color Resolution is set to 6 bits (Miscellaneous Control 2 COL RES bit = 0). For the 8 bits of palette output for each color, the high order two bits 7 and 6 will be substituted for the two low order

bits 1 and 0.

Bits 6 - 4 Reserved.
Bits 3 - 0 PALETTE

PALETTE PARTITION - Selects which partition to use within the palettes when the pixel format is either 4 BPP, 15 BPP indirect color, or 16 BPP indirect color.

With 4 BPP the palettes are divided into 16 partitions. Each partition contains 16 entries. Bits 3 - 0 select 1 of the 16 partitions.

With 15 BPP (555) indirect color, the palettes are divided into 8 partitions. Each partition contains 32 entries. Bits 3 - 1 select 1 of the 8 partitions and bit 0 is not used.

With 16 BPP (565) indirect color, the palettes are divided into 4 partitions. Each partition contains 64 entries. All 64 entries of the Green palette are used in each partition. For the Red and Blue palettes only the first 32 entries of each partition are used. Bits 3 - 2 select 1 of the 4 partitions and bits 1 and 0 are not used.

The PARTITION bits have no effect when the pixel format is not 4 BPP, 15 BPP, or 16 BPP. Also, with 15 BPP and 16 BPP the PARTITION bits have no effect unless

- Indirect color is chosen (16 BPP Control register bits B16 DCOL = 00), AND
- 2. Contiguous addressing is chosen (16 BPP Control register bit SPR/CNT = 1)

## **System Clock Control**

| , | 7    | 6             | 5             | 4     | 3 | 2             | 1             | 0             | 7 |
|---|------|---------------|---------------|-------|---|---------------|---------------|---------------|---|
|   | RSVD | SYSC<br>DSAB  |               | eserv |   | PROG<br>MODE  | RSVD          | SPLL<br>ENAB  |   |
| ٦ |      | $\overline{}$ | $\overline{}$ |       |   | $\overline{}$ | $\overline{}$ | $\overline{}$ | \ |

Index: 0x0008
Access: Read/Write

Power on Value: 0x01

Bit 7 RSVD - Reserved

Bit 6 SYSC DSAB - SYSCLK driver dis-

able

0 SYSCLK driver enabled

SYSCLK driver disabled (3stated)

Bits 5 - 3 Reserved

Bit 2 PROG MODE - SYSCLK PLL programming mode

O Compatibility mode - program with registers at 0x0015 and 0x0016 as described in Appendix C.0

1 Standard mode - program with N, M, P and C (registers at 0x0016, 0x0017, 0x0018, 0x0019) as described in Section

2.7

Bit 1 Reserved

Bit 0 SPLL ENAB - System PLL enable

 SYSCLK PLL programming disabled

1 SYSCLK PLL programming enabled



## 12.2.2 Pixel Representation

#### **Pixel Format**



Index: 0x000a
Access: Read/Write
Power on Value: Undefined
Bits 7 - 3 Reserved
Bits 2 - 0 Pixel Format
000 Reserved
001 Reserved
010 4 BPP
011 8 BPP

100 15/16 BPP101 24 BPP Packed110 32 BPP

111 Reserved

This register has no effect when the VGA port is selected.

The 24 BPP Packed format requires the VRAM SIZE (Miscellaneous Control 1 register bit 0) to be set for 64 bits. If VRAM SIZE is set to 32 bits, the product operation will be undefined if the 24 BPP Packed format is selected.

#### **8 Bit Pixel Control**



Index: 0x000b
Access: Read/Write
Power on Value: Undefined
Bits 7 - 1 Reserved

Bit 0 B8 DCOL - 8 BPP Direct Color Con-

trol

Indirect Color (through the pal-

Direct Color (palette bypass).
Since the same 8-bit value will be applied to each of the Red,
Green, and Blue DACs a monochrome image will be displayed.

This register only affects 8 BPP mode.

#### 16 Bit Pixel Control



Index:0x000cAccess:Read/WritePower on Value:Undefined

Bits 7 - 6 B16 DCOL - 16 BPP Direct Color

Control

00 Indirect Color (always goes through the palette). Either the 555 or 565 format can be selected. The SPR/CNT bit determines if the access of the palettes is sparse or contiguous. If CNT (contiguous), then the PARTITION bits of the Palette Control register determine which partition of the palettes is used. If SPR (Sparse) the ZIB/LIN bit must be set to 0 (ZIB).

- 01 Dynamic Bypass. The high order bit of each 16-bit pixel (PIX[15], PIX[31], PIX[47], PIX[63]) is used to select on a pixel-by-pixel basis to either go through the palette (indirect color) or bypass the palette (direct color). When this mode is selected the following conditions apply:
  - 1. The 555/565 bit has no effect. Internally, the pixel format is forced to 5 bits per color (555).
  - 2. The SPR/CNT bit has no effect. Internally, sparse addressing (SPR) is forced for palette access.
  - 3. The ZIB/LIN bit has no effect. Internally, the low order bits for each color are forced to '0's (ZIB) for both access of the palette (indirect color) and palette bypass (direct color).
  - 4. The Pixel Mask is applied to the pixel data regardless of whether or not the palette is bypassed.

Note: For the RGB526DB

Dynamic Bypass is not a valid option when double buffer operation is enabled.

- 10 Reserved
- 11 Direct Color (always bypasses the palette). Either the 555 or 565 format can be selected. The ZIB/LIN bit determines the expansion to 24 bits (low order bit fill). The SPR/CNT bit has no effect.

BY16 POL - Bypass control bit polarity. Determines the meaning of the dynamic bypass control bit (PIX[15], PIX[31]).

Control Bit Forces Bypass

## Control BitPixel Path

- 0 Through Palette (Indirect Color)
- 1 Bypass Palette (Direct Color)
- 1 Control Bit Forces Lookup

## Control BitPixel Path

- 0 Bypass Palette (Direct Color)
- 1 Through Palette (Indirect Color)

The BY16 POL bit has no effect unless the B16 DCOL bits are set to 01.

#### Reserved

ZIB/LIN - Bit fill selection. For direct color this bit specifies how the low order bits of each color, R,G,B are filled when 555 or 565 formats are expanded to 24 bits.

- O ZIB Zero Intensity Black. Low order bits are set to 0.
- LIN Linear. The low order bits are set to the values of the high order bits.

For indirect color if CNT (contiguous) addressing is selected, then ZIB/LIN has no effect. If SPR (sparse) addressing is selected then ZIB/LIN **must** be set to 0 (ZIB). The palette addressing is undefined if LIN bit fill is selected with sparse addressing.

Bits 4 - 3 Bit 2

Bit 5

**Bit 1** 555/565 - Selects 5 bits per color

(555) or 5 red, 6 green, 5 blue (565).

0 555 1 565

**Note**: for the RGB526DB this bit must be set for 555 format, when double buffer operation is enabled.

Bit 0 SPR/CNT - Sparse/Continuous. In

indirect mode, selects whether index into palette is sparse or contiguous.

0 Sparse1 Contiguous

This register only affects 15/16 BPP mode.

#### 24 Bit Packed Pixel Control



Index: 0x000d
Access: Read/Write
Power on Value: Undefined
Bits 7 - 1 Reserved

Bit 0 B24P DCOL - 24 BPP Packed Direct

**Color Control** 

0 Indirect Color (through the pal-

ette).

1 Direct Color (palette bypass).

This register only affects 24 BPP Packed mode.

#### 32 Bit Pixel Control



Index:0x000eAccess:Read/WritePower on Value:UndefinedBit 7Reserved

**Bit 6** B8 DCOL - When key matching is

enabled this bit determines the path of the 8 bit overlay pixel to the DACs:

0 Indirect (color lookup through

the palette).

Direct (the 8 bits are sent to each of the red, green and blue DACs to yield grey scale).

If key matching is not enabled then

Bit 6 has no effect.

### Bits 5 - 3 Reserved

Bit 2

BY32 POL - Bypass control bit polarity. Determines the meaning of the dynamic bypass control bit (PIX[24], PIX[56]).

0 Control Bit Forces Bypass

#### Control BitPixel Path

- 0 Through Palette (Indirect Color)
- 1 Bypass Palette (Direct Color)
- 1 Control Bit Forces Lookup

## Control BitPixel Path

- 0 Bypass Palette (Direct Color)
- 1 Through Palette (Indirect Color)

The BY32 POL bit has no effect unless the B32 DCOL bits are set to 01

Bits 1 - 0 B32 DCOL - 32 BPP Direct Color Control.

00 Indirect Color (always goes through the palette). 24 bits (8 bits each for Red, Green, Blue) are used to index into the palettes. The 8 high order bits (PIX[31:24], PIX[63:56]) are not used.

01 Dynamic Bypass (Key Match not enabled).

A control bit in the high order byte (PIX[24], PIX[56]) is used to select on a pixel-by-pixel basis to either go through the palette (indirect color) or bypass the palette (direct color). The remaining bits in the high order byte (PIX[31:25], PIX[63:57]) are not used. In this mode, the Pixel Mask is applied to the pixel data regardless of whether or not the palette is bypassed.

01 Reserved (Key Match enabled).

10 Reserved

11 Direct Color (always bypasses the palette). 24 bits (8 bits each for Red, Green, Blue) are presented to the DACs. The 8 high order bits (PIX[31:24], PIX[63:56] are not used.

This register only affects 32 BPP mode.

## 12.2.3 Pixel Clock Frequency Selection

#### **Pixel PLL Control 1**



Index: 0x0010
Access: Read/Write

Power on Value: 0x00
Bits 7 - 3 Reserved
Bits 2 - 0 EXT/INT

Determines the programing mode (standard or compatibility), and the source and selection for the Pixel PLL programming registers.

000 Compatibility mode: External FS[1:0] inputs

One of the F0 - F3 registers is selected with external signals FS[1:0]. The selected register provides the Pixel PLL VCO divider value. The Fixed Pixel PLL Reference Divider register is used to pre-scale the PLL reference clock.

001 Compatibility mode:
External FS[1:0] inputs (4 value M/N programming)
One of four pairs of registers M0/N0, M1/N1, M2/N2, M3/N3 are selected with external sig-

are selected with external signals FS[1:0] to provide the VCO divider/reference divider inputs to the Pixel PLL.

The Fixed PLL Reference Divider register is not used.

010 Compatibility mode:
Pixel PLL Control 2 register
bits [3:0] (16 value direct programming)

One of the F0 - F15 registers is selected with Pixel PLL Control 2 register bits [3:0]. The selected register provides the Pixel PLL VCO divider value. The Fixed Pixel PLL Reference Divider register is used to prescale the Pixel PLL reference clock.

011 Compatibility mode:
Pixel PLL Control 2 register
bits [2:0] (8 value M/N direct
programming)
One of eight pairs of registers
M0/N0, M1/N1, M2/N2, M3/N3,
M4/N4, M5/N5, M6/N6, M7/N7
is selected with Pixel PLL Control 2 register bits [2:0] to provide the VCO divider/reference
divider inputs to the Pixel PLL.
The Fixed Pixel PLL Reference
Divider register is not used.
Pixel PLL Control 2 register bit

100 Standard mode:
External FS[1:0] inputs
One of four sets of registers
M0/N0/P0/C0, M1/N1/P1/C1,
M2/N2/P2/C2, M3/N3/P3/C3 is
selected with external signals
FS[1:0] to provide the M, N, P
and C programming values to

3 has no effect.

the Pixel PLL.

101 Standard mode:
 Pixel PLL Control 2 register
 bits [1:0]
 One of four sets of registers
 M0/N0/P0/C0, M1/N1/P1/C1,
 M2/N2/P2/C2, M3/N3/P3/C3 is
 selected with Pixel PLL Control
 2 register bits [1:0] to provide
 the M, N, P and C programming
 values to the Pixel PLL.
 Pixel PLL Control 2 register

bits [3:2] have no effect.

110 Reserved111 Reserved

The Pixel PLL frequency is programmed using several values. Multiple sets of these values may be stored in registers sets. The desired set of values can be selected using external signals (the FS[1:0] inputs) or by using the internal FS[3:0] bits of the PLL Control 2 register.

When the standard programming method is used then EXT/INT is set to 100 or 101 to use external selection or internal selection of frequency values.

When one of the two compatibility methods is used then EXT/INT is set to 000 or 001 for external selection, and 010 or 011 for internal selection.

## **Pixel PLL Control 2**



**Index**: 0x0011 **Access**: Read/Write

**Power on Value**: 0x00 **Bits 7 - 3** Reserved

Bits 3 - 0 INT FS - Internal Frequency Selec-

tion. Identifies which Pixel PLL programming registers to use when Pixel PLL Control 1 register bits EXT/INT specify internal frequency selection (EXT/INT = 010, 011 or

101).

| EXT/INT = 100       | EXT/INT<br>= 101 | Standard Programming<br>Method |
|---------------------|------------------|--------------------------------|
| External<br>FS[1:0] | INT<br>FS[1:0]   | Selected Registers             |
| 00                  | 00               | M0,N0,P0,C0                    |
| 01                  | 01               | M1,N1,P1,C1                    |
| 10                  | 10               | M2,N2,P2,C2                    |
| 11                  | 11               | M3,N3,P3,C3                    |

**Note**: External FS[1:0] are the chip inputs FS[1:0]. INT FS[1:0] are Pixel PLL Control 2 register bits [1:0].

When EXT/INT = 100 Pixel PLL Control 2 register is not used.

When EXT/INT = 101 Pixel PLL Control 2 register bits [3:2] are not used and have no effect.

| EXT/IN              | T = 000              | EXT/IN              | T = 001               |
|---------------------|----------------------|---------------------|-----------------------|
| External<br>FS[1:0] | Selected<br>Register | External<br>FS[1:0] | Selected<br>Registers |
| 00                  | F0                   | 00                  | M0, N0                |
| 01                  | F1                   | 01                  | M1, N1                |
| 10                  | F2                   | 10                  | M2, N2                |
| 11                  | F3                   | 11                  | M3, N3                |

**Note**: External FS[1:0] are the chip inputs FS[1:0]. Pixel PLL Control 2 register is not used when Pixel PLL Control 1 register bits EXT/INT = 000 or 001.

| EXT/IN         | T = 010              | EXT/IN                        | T = 011               |
|----------------|----------------------|-------------------------------|-----------------------|
| INT<br>FS[3:0] | Selected<br>Register | INT<br>FS[2:0]                | Selected<br>Registers |
| 0000           | F0                   | 000                           | M0, N0                |
| 0001           | F1                   | 001                           | M1, N1                |
| 0010           | F2                   | 010                           | M2, N2                |
| 0011           | F3                   | 011                           | M3, N3                |
| 0100           | F4                   | 100                           | M4, N4                |
| 0101           | F5                   | 101                           | M5, N5                |
| 0110           | F6                   | 110                           | M6, N6                |
| 0111           | F7                   | 111                           | M7, N7                |
| 1000           | F8                   |                               |                       |
| 1001           | F9                   | Note: When                    |                       |
| 1010           | F10                  | Control 1 EX<br>010 or 011, P |                       |
| 1011           | F11                  | · ·                           | s INT FS[3:0]         |
| 1100           | F12                  | select the fre                | 1 3                   |
| 1101           | F13                  | register(s). F                | or EXT/INT =          |
| 1110           | F14                  | used and has                  |                       |
| 1111           | F15                  | ]                             |                       |



## 12.2.4 Pixel PLL Programming - Standard Mode

## Pixel M0, Pixel M1, Pixel M2, Pixel M3

| 7        | 6            | 5 | 4 | 3 | 2 | 1 | 0 / |
|----------|--------------|---|---|---|---|---|-----|
| RSVD     |              |   |   | М |   |   |     |
| $\vdash$ | $\leftarrow$ |   |   |   |   |   | -   |

**Index**: 0x0020, 0x0024, 0x0028, 0x002c

Access: Read/Write

Power on Value: 0x05 (index 0x0020)

0x00 (others)

Bits 7 - 6 Reserved

Bits 5 - 0 M

## Pixel N0, Pixel N1, Pixel N2, Pixel N3

|   | 7  | 6  | 5             | 4 | 3 | 2 | 1 | 0 /           |
|---|----|----|---------------|---|---|---|---|---------------|
|   | RS | VD |               |   |   | N |   |               |
| ١ |    |    | $\overline{}$ |   |   |   |   | $\overline{}$ |

**Index**: 0x0021, 0x0025, 0x0029, 0x002d

Access: Read/Write

**Power on Value**: 0x0e (index 0x0021)

0x00 (others)

Bit 7 Reserved

**Bits 6 - 0** N

## Pixel P0, Pixel P1, Pixel P2, Pixel P3



**Index**: 0x0022, 0x0026, 0x002a, 0x002e

Access: Read/Write
Power on Value: 0x00 (all)
Bits 7 - 3 Reserved
Bits 2 - 0 P

Dits 2 - U

### Pixel C0, Pixel C1, Pixel C2, Pixel C3



**Index**: 0x0023, 0x0027, 0x002b, 0x002f

Access: Read/Write
Power on Value: 0x00 (all)
Bits 7 - 2 Reserved

Bits 1- 0 C

When the standard programming method is chosen for the Pixel PLL (Pixel PLL Control 1 register, EXT/INT bits = '100' or '101'), the registers at 0x0020 - 0x002f provide the N, M, P and C programming values.

The valid ranges of these bits and their use are described in Sections 2.6 through 2.9.

There are four sets of M, N, P and C values. One of four sets is chosen under control of the PLL Control 1 and PLL Control 2 registers.

Note that, following a reset, the Pixel PLL is set to use compatibility programming using power on values appropriate for that mode (in registers at 0x0020 and 0x0021). Thus, when switched to standard programming, the power on values found in those registers are actually "left over" values that are not intended for use with the standard programming method.

# 12.2.5 Pixel PLL Programming - Compatibility Mode

## **Fixed Pixel PLL Reference Divider**



Index: 0x0014
Access: Read/Write

**Power on Value**: 0x05 **Bits 7 - 5** Reserved

Bits 4 - 0 REF DIV COUNT - Reference Divide

Count

### F0-F15: Pixel Frequency 0 to Frequency 15

| , | 7 | 6 | 5            | 4  | 3    | 2    | 1   | 0 | 7  |
|---|---|---|--------------|----|------|------|-----|---|----|
| ſ | D | F |              | VC | O DI | v cc | UNT |   |    |
| Ĺ |   |   | $\leftarrow$ |    |      |      |     |   | IJ |

Index: 0x0020 - 0x002f Access: Read/Write

Power on Value: 0x05 (index 0x0020)

0x0e (index 0x0021) 0x00 (others)

Bits 7 - 6 DF - Desired Frequency

Bits 5 - 0 VCO DIV COUNT - VCO Divide

Count

When the compatibility programming method is chosen for the Pixel PLL (Pixel PLL Control 1 register, EXT/INT bits = '000' through '011'), the registers at 0x0014 and 0x0020 - 0x002f provide the "Reference Divider", "VCO Divider" and DF programming values.programming values.

The above register diagram shows the format for the 16 pixel frequency registers F0 - F15. This format is selected when the EXT/INT bits (Pixel PLL Control 1 register, bits 2:0) = 000 or 010. The selected F0-F15 register provides the Pixel PLL with the DF value and the VCO divide count. All 16 frequency registers work with the same reference divide count, provided by the Fixed Pixel PLL Reference Divider register.

These 16 registers have a different format (M, N) (shown next), when EXT/INT = 001 or 011.

#### M0-M7. N0-N7



**Index**: 0x0020, 0x0022, 0x0024, 0x0026,

0x0028, 0x002A, 0x002C, 0x002E

Access: Read/Write

Power on Value: 0x05 (index 0x0020)

0x00 (others)

**Bits 7 - 6** DF - Desired Frequency

Bits 5 - 0 VCO DIV COUNT - VCO Divide

Count



**Index**: 0x0021, 0x0023, 0x0025, 0x0027,

0x0029, 0x002B, 0x002D, 0x002F

Access: Read/Write

Power on Value: 0x0e (index 0x0021)

0x00 (others)

Bits 7 - 5 Reserved

**Bits 4 - 0** REF DIV COUNT - Reference Divide

Count

The above diagrams show the formats for the 8 'M' and 8 "N" pixel frequency registers. These formats are selected when the EXT/INT bits (Pixel PLL Control 1 Register, bits 2:0) = 001 or 011.

The 8 registers are grouped into four pairs, M0/N0, M1/N1, M2/N2, M3/N3. For a given pair, the "M" register provides the Pixel PLL with the DF value and the VCO divide count, and the "N" register provides the Pixel PLL with the reference divide count.

As described above these 16 registers have a different format (F) when EXT/INT = 000 or 010.

Further discussion of these registers and their use are given in Appendix C.0.



## 12.2.6 SYSCLK PLL Programming - Standard Mode

## SYSCLK N



Index: 0x0015 Access: Read/Write

 Power on Value:
 0x08

 Bits 7 - 6
 Reserved

 Bits 5 - 0
 N

#### SYSCLK M



Index: 0x0016
Access: Read/Write

 Power on Value:
 0x41

 Bit 7
 Reserved

 Bits 6 - 0
 M

## SYSCLK P



Index: 0x0017
Access: Read/Write
Power on Value: Undefined
Bits 7 - 3 Reserved

Bits 2 - 0 P

#### SYSCLK C



Index: 0x0018
Access: Read/Write
Power on Value: Undefined
Bits 7 - 2 Reserved

Bits 1- 0 C

When the standard programming method is chosen for the SYSCLK PLL (System Clock Control register, PROG MODE bit = '1'), the registers at 0x0015 - 0x0018 provide the N, M, P and C programming values.

The valid ranges of these bits and their use are described in Sections 2.6 through 2.9.

Note that, following a reset, the SYSCLK PLL is set to use compatibility programming using power on values appropriate for that mode. Thus, when switched to standard programming, the power on values found in the SYSCLK N and SYSCLK M registers are actually "left over" values that are not intended for use with the standard programming method.

# 12.2.7 System Clock Frequency Selection - Compatibility Mode

## System PLL Reference Divider



Index: 0x0015 Access: Read/Write

**Power on Value**: 0x08 **Bits 7 - 5** Reserved

Bits 4 - 0 REF DIV COUNT - Reference Divide

Count

## System PLL VCO Divider



Index: 0x0016
Access: Read/Write

Power on Value: 0x41

Bits 7 - 6 DF - Desired Frequency

Bits 5 - 0 VCO DIV COUNT - VCO Divide

Count

When the compatibility programming method is chosen for the SYSCLK PLL (System Clock Control register, PROG MODE bit = '0'), the registers at 0x0015 - 0x0016 provide the "Reference Divider", "VCO Divider" and DF programming values.

The valid ranges of these bits and their use are described in Appendix C.0.

The registers at 0x0017 and 0x0018 are not used.

Compatibility programming is the default mode when the product is reset. The power on values will cause the PLL to produce a SYSCLK frequency of approximately 30 MHz (29.53 MHz) if the incoming REFCLK is the commonly available 14.31818 MHz frequency.

### 12.2.8 Cursor

#### **Cursor Control**



**Index**: 0x0030 **Access**: Read/Write

**Power on Value**: 0x00

Bits 7 - 6 SMLC PART - Small Cursor Partition. Selects 1 of 4 partitions within the cursor array to use for the 32x32

cursor:

00 0x0100 - 0x01ff 01 0x0200 - 0x02ff 10 0x0300 - 0x03ff 11 0x0400 - 0x04ff

These bits have no effect when the

cursor size is 64x64.

Bit 5 PIX ORDR - Pixel Order. Specifies ordering of pixel bits in the bytes of the cursor array.

0 Right-to-left



1 Left-to-right

| / 7 6 | 5 | 4  | 3 | 2   | 1 | 0 / |
|-------|---|----|---|-----|---|-----|
| n+0   | n | +1 |   | 1+2 | n | +3  |

Bit 4 LOC READ - Location Read-back
Value. Specifies the value obtained
by microprocessor reads of the Cursor X Low, Cursor X High, Cursor Y

Low, and Cursor Y High registers.

- 0 Written Value the value last written.
- 1 Actual Location the location presently used for display. This will be different than the written value if a location register has been written but the location has not yet been updated. Following a cursor location update the "Written Value" and the "Actual Location" will be the same.

Bit 3

Bit 2

Bits 1

UPDT CNTL - Cursor Location Update Control. Controls when Cursor Location registers are sampled to change the cursor position.

- Delayed A write to the Cursor Y High register arms the circuitry for the update. The position is then updated (the cursor moves to the new location) when a vertical blanking period is detected.
- Immediate Move the cursor immediately following a write to any of the Cursor X Low, Cursor X High, Cursor Y Low, or Cursor Y High registers.

Cursor Size 0 32x32 1 64x64

Cursor Mode

Standard Cursor (ACA ENAB = '0' in Advanced Cursor Control register):

00 OFF

01 ON - Mode 0 (3 colors)

10 ON - Mode 1 (2 colors and highlighting)

11 ON - Mode 2 (2 colors)

Advanced Cursor (ACA ENAB = '1' in Advanced Cursor Control register):

00 OFF

01 ON

10 ON

11 ON

When the Advanced Cursor is enabled the cursor display modes are set in the Advanced Cursor Attribute register.

50

#### **Advanced Cursor Control**



Index: 0x0037
Access: Read/Write
Power on Value: 0x00

Bits 7 - 1 Reserved

Bit 0 ACA ENAB - Advanced Cursor

Attribute Enable. When the cursor is ON, determines how the cursor bits in the cursor array are interpreted.

O Standard Cursor - use Cursor Mode bits in Cursor Control

register.

1 Advanced Cursor - use

Advanced Cursor Attribute reg-

ister

This register has no effect when the cursor is OFF (Cursor Mode = '00').

#### **Advanced Cursor Attribute**



Index:0x0038Access:Read/WritePower on Value:Undefined

Bits 7 - 6 COL3 ATRB - Cursor Color 3

Attribute

Bits 5 - 4 COL2 ATRB - Cursor Color 2

Attribute

Bits 3 - 2 COL1 ATRB - Cursor Color 1

Attribute

Bits 1 - 0 COLO ATRB - Cursor Color 0

Attribute

When the cursor is ON (Cursor Control register, Cursor Mode is not '00'), and the Advanced Cursor is enabled (Advanced Cursor Control register, ACA ENAB = '1'), then the attributes in this register control the interpretation of the cursor pixel bits in the cursor array. The interpretations specified by the Cursor Mode bits ('01', '10', and '11') are ignored.

For each of the four colors that can be selected by the cursor pixel bits (Color 3, Color 2, Color 1, Color 0), the COLx ATRB bits specify the display of that color as follows:

00 Transparent01 Solid Color10 Translucent11 Highlighted

When the ACA ENAB bit is off this register has no effect.



#### **Cursor X Low**



Index:0x0031Access:Read/WritePower on Value:Undefined

Bits 7 - 0 Cursor X Low. The low order bits of

the cursor X (horizontal) position.

A write to this register will update the cursor position:

- 1. When both the Cursor Y High register is written and vertical blanking is detected, OR
- 2. Immediately

under control of the UPDT CNTL bit of the Cursor Control register.

The value read back:

- 1. Written Value, or
- 2. Actual Location

is controlled by the LOC READ bit of the Cursor Control register:

#### **Cursor X High**



Index:0x0032Access:Read/WritePower on Value:UndefinedBit 7Sign

Bits 6 - 4 SIGN EXTND - Sign Extended.

These bits are always the same as bit
7. On a write these bits are discarded and replaced with the value written

the same value as bit 7.

to bit 7. On a read they will return

**Bits 3 - 0** Cursor X High. The high order bits of the cursor X (horizontal) position.

Cursor X High and Cursor X Low form a combined register that holds a signed cursor X position in two's complement form. The X position range is -4096 to +4095.

A write to this register will update the cursor position:

- 1. When both the Cursor Y High register is written and vertical blanking is detected, OR
- 2. Immediately

under control of the UPDT CNTL bit of the Cursor Control register

The value read back:

- 1. Written Value, or
- 2. Actual Location

is controlled by the LOC READ bit of the Cursor Control register.

#### **Cursor Y Low**



Index:0x0033Access:Read/WritePower on Value:Undefined

**Bits 7 - 0** Cursor Y Low. The low order bits of the cursor Y (vertical) position.

A write to this register will update the cursor position:

1. When both the Cursor Y High register is written and vertical blanking is detected, or

2. Immediately

under control of the UPDT CNTL bit of the Cursor Control register.

The value read back:

- 1. Written Value, or
- 2. Actual Location

is controlled by the LOC READ bit of the Cursor Control register.

## **Cursor Y High**



Index:0x0034Access:Read/WritePower on Value:UndefinedBit 7Sign

Bits 6 - 4 SIGN EXTND - Sign Extended.

These bits are always the same as bit 7. On a write these bits are discarded and replaced with the value written to bit 7. On a read they will return

the same value as bit 7.

Bits 3 - 0 Cursor Y High. The high order bits of the cursor Y (vertical) position.

h and Cursor Y Low form a combined reg

Cursor Y High and Cursor Y Low form a combined register that holds a signed cursor Y position in two's complement form. The Y position range is -4096 to +4095.

A write to this register will update the cursor position:

- 1. When vertical blanking is detected, or
- 2. Immediately

under control of the UPDT CNTL bit of the Cursor Control register.

The value read back:

- 1. Written Value, or
- 2. Actual Location

is controlled by the LOC READ bit of the Cursor Control register.



## **Cursor Hot Spot X**



Index:0x0035Access:Read/WritePower on Value:Undefined

32x32 Cursor

Bits 7 - 5 Reserved

Bits 4 - 0 HOT SPOT X. Specifies which pixel

in a cursor row is the X position

pixel.

64x64 Cursor

Bits 7 - 6 Reserved

Bits 5 - 0 HOT SPOT X. Specifies which pixel

in a cursor row is the X position

pixel.

### **Cursor Hot Spot Y**



Index: 0x0036
Access: Read/Write
Power on Value: Undefined

32x32 Cursor

Bits 7 - 5 Reserved

Bits 4 - 0 HOT SPOT Y. Specifies which pixel

in a cursor column is the Y position

pixel.

64x64 Cursor

Bits 7 - 6 Reserved

**Bits 5 - 0** HOT SPOT Y. Specifies which pixel

in a cursor column is the Y position

pixel.

#### **Cursor Color 1 Red**



Index:0x0040Access:Read/WritePower on Value:Undefined

Bits 7 - 0 Cursor Color 1 Red

### **Cursor Color 1 Green**



Index: 0x0041
Access: Read/Write
Power on Value: Undefined

Bits 7 - 0 Cursor Color 1 Green

## **Cursor Color 1 Blue**



Index: 0x0042
Access: Read/Write
Power on Value: Undefined

Bits 7 - 0 Cursor Color 1 Blue

## **Cursor Color 2 Red**



Index:0x0043Access:Read/WritePower on Value:Undefined

Bits 7 - 0 Cursor Color 2 Red

## **Cursor Color 2 Green**



Index:0x0044Access:Read/WritePower on Value:Undefined

Bits 7 - 0 Cursor Color 2 Green

### **Cursor Color 2 Blue**



Index:0x0045Access:Read/WritePower on Value:Undefined

Bits 7 - 0 Cursor Color 2 Blue

## **Cursor Color 3 Red**



Index:0x0046Access:Read/WritePower on Value:Undefined

Bits 7 - 0 Cursor Color 3 Red

## **Cursor Color 3 Green**



Index:0x0047Access:Read/WritePower on Value:Undefined

Bits 7 - 0 Cursor Color 3 Green

## **Cursor Color 3 Blue**



Index:0x0048Access:Read/WritePower on Value:Undefined

Bits 7 - 0 Cursor Color 3 Blue

### 12.2.9 Border Color

#### **Border Color Red**



Index:0x0060Access:Read/WritePower on Value:Undefined

Bits 7 - 0 Border Color Red

## **Border Color Green**



Index: 0x0061
Access: Read/Write
Power on Value: Undefined

Bits 7 - 0 Border Color Green

#### **Border Color Blue**



Index:0x0062Access:Read/WritePower on Value:Undefined

Bits 7 - 0 Border Color Blue



## 12.2.10 Key Support

## Key



Index: 0x0068 Read/Write Access: Power on Value: Undefined Bits 7 - 0 Key

## **Key Mask**



Index: 0x006c Access: Read/Write Power on Value: Undefined Bits 7 - 0 **Key Mask** 

The Key and Key Mask registers are used for Chroma Key matching. The Key Mask is ANDed with the Key.

## **Key Control (RGB526)**



0x0078 Index: Read/Write Access: Power on Value: 0x00 Bits 7 - 1 Reserved

Bit 0 KEY ENAB - Key Match Enable

Key matching not enabled.

1 Chroma Key matching enabled.

This register has no effect for modes which do not support key operation. For 32 BPP, which does support key matching, this register determines if key matching is in effect

## **Key Control/DB Operation (RGB526DB)**



Index: 0x0078 Access: Read/Write

Power on Value: 0x00 Bits 7 - 1 Reserved

Bit 0 KEY ENAB - Key Match Enable

Key matching not enabled.

1 Chroma Key matching enabled.

Bit 0 SUPP BUFB - Suppress Buffer B

Normal double buffer operation.

Buffer A only; Buffer B sup-

pressed.

For the RGB526DB the use of Bit 0 depends upon the mode of operation:

For 32 BPP, which supports key matching, Bit 0 is used as the KEY ENAB bit to determine if key matching is enabled, the same as the RGB526.

For 16 BPP, which supports the double buffer operation, Bit 0 is used to suppress the display of the B buffer.

This register has no effect for modes which do not support key operation or double buffer operation.

## 12.2.11 Diagnostic Support

#### **Revision Level**



Index: 0x0000
Access: Read Only
Power on Value: Revision Level

Bits 7 - 0 Product Revision Level

The value in this register indicates the revision level of the product.

ID



Index:0x0001Access:Read OnlyPower on Value:0x02

Bits 7 - 0 Product Identification Code

This register distinguishes among the various members of the IBM Microelectronics Palette DAC family. The value of 0x02 indicates that this product is one of several that have two clock generators.

#### **DAC Sense**



Index:0x0082Access:Read OnlyPower on Value:Undefined

Bit 7 LSNS - Latched Sense

Bit 6 LBLU COMP - Latched Blue DAC

Comparator Output

Bit 5 LGRN COMP - Latched Green DAC

**Comparator Output** 

Bit 4 LRED COMP - Latched Red DAC

**Comparator Output** 

Bit 3 SENS - Sense

Bit 2 BLU COMP - Blue DAC Comparator

Output

Bit 1 GRN COMP - Green DAC Compara-

tor Output

Bit 0 RED COMP - Red DAC Comparator

Output

Bits 2,1,0 are the outputs of the three DAC reference comparators. The DAC output voltages are compared against the 0.35 V internal reference voltage (presented on COMPVREF). These bits are the "raw" outputs of the comparators.

Bits 6,5,4 are latched copies of bits 2,1,0. The latches are clocked during active line time (when  $\overline{BLANK}$  [and  $\overline{BORDER}$ , when a border is used] are both high).

Bit 3 (Sense) represents the combined status of bits 2,1,0. If any of these bits is 0, bit 3 will be 0.

Bit 7 (Latched Sense) represents the combined status of bits 6,5,4. If any of these bits is 0, bit 7 will be 0.

Either bit 3 or bit 7 will be presented on the SENSE output, depending on the SENS SEL bit of the Miscellaneous Control 1 register.

If the selected bit is 0,  $\overline{SENSE}$  will be low. If the selected bit is 1,  $\overline{SENSE}$  will be high.



#### **MISR Status**



 Index:
 0x0083

 Access:
 Read Only

 Power on Value:
 0x00

 Bits 7 - 1
 Reserved

Bit 0 MISR DONE - Indicates the status of

the diagnostic signature accumulation in the MISR Red, MISR Green and MISR Blue registers

Not done - the MISR is not running or has not finished accumulating a signature.

 Done - The signature accumulation has completed and the contents of the three MISR registers are valid.

#### MISR Red



Index:0x0084Access:Read OnlyPower on Value:Undefined

Bits 7 - 0 Multiple Input Signature Register

Red

This register along with MISR GREEN and MISR BLUE is used to accumulate a diagnostic signature on the values presented to the DACs. The input to the Red DAC is the parallel data input to this portion of the MISR.

#### **MISR Green**



Index:0x0086Access:Read OnlyPower on Value:Undefined

Bits 7 - 0 Multiple Input Signature Register

Green

This register along with MISR RED and MISR BLUE is used to accumulate a diagnostic signature on the values presented to the DACs. The input to the Green DAC is the parallel data input to this portion of the MISR.

#### **MISR Blue**



Index: 0x0088
Access: Read Only
Power on Value: Undefined

Bits 7 - 0 Multiple Input Signature Register

Blue

This register along with MISR RED and MISR GREEN is used to accumulate a diagnostic signature on the values presented to the DACs. The input to the Blue DAC is the parallel data input to this portion of the MISR.

.Note: The reset, accumulation, and hold function of the MISR, and the meaning of the MISR DONE bit, is controlled by the MISR CNTL bit of the Miscellaneous Control 1 register, and the  $\overline{BLANK}$  input (and the  $\overline{BORDER}/OE$  input, in interlace mode). See 10.0 "Diagnostic Support" on page 26 for more information.

## **Pixel P Input**



Index:0x008cAccess:Read OnlyPower on Value:UndefinedBits 7 - 3ReservedBits 2 - 0P

## **Pixel C Input**



Index:0x008dAccess:Read OnlyPower on Value:UndefinedBits 7 - 2ReservedBits 1-0C

## **Pixel M Input**



Index:0x008eAccess:Read Only

**Power on Value**: 0x05 (FS[1:0] = 00)

0x0e (FS[1:0] = 01)

0x00 (FS[1:0] = 10 or 11)

Bit 7 Reserved

Bits 6 - 0 M

## **Pixel N Input**



Index:0x008fAccess:Read OnlyPower on Value:0x05Bits 7 - 6Reserved

Bits 5 - 0 N

These four registers allow readback of the selected programming values presented to the Pixel PLL. When the standard programming method is used (Pixel PLL Control 1 register, EXT/INT bits = '100' or '101') the above representations are valid.

When compatibility programming is used (EXT/INT bits = '000' through '011') the contents of registers at 0x008c and 0x008d are undefined, and the representation of the registers at 0x008e and 0x008f are given in the next two register descriptions.

## **PLL VCO Divider Input**



Index: 0x008e Access: Read Only

**Power on Value**: 0x05 (FS[1:0] = 00)

0x0e (FS[1:0] = 01)

0x00 (FS[1:0] = 10 or 11)

**Bits 7 - 6** DF - Desired Frequency

Bits 5 - 0 VCO DIV COUNT - VCO Divide

Count

This register allows readback of the selected PLL VCO divider input. It is one of these registers:

Georgia F0, F1, F2, F3, F4, F5, F6, F7, F8, F9, F10, F11, F12, F13, F14, F15

□ M0, M1, M2, M3, M4, M5, M6, M7

as determined by the PLL Control 1 EXT/INT bits (2:0), the inputs FS[3:0], and PLL Control 2 INT FS bits (3:0).

## **PLL Reference Divider Input**



 Index:
 0x008f

 Access:
 Read Only

 Power on Value:
 0x05

 Bits 7 - 5
 Reserved

Bits 4 - 0 REF DIV COUNT - Reference Divide

Count

This register allows readback of the input to the PLL reference divider.

☐ Fixed PLL Reference Divider

□ N0, N1, N2, N3, N4, N5, N6, N7

as determined by the PLL Control 1 EXT/INT bits (2:0), the inputs FS[3:0], and PLL Control 2 INT FS bits (3:0).

The above register contents are valid when the compatibility programming mode is used (Pixel PLL Control 1 register, EXT/INT bits = '000' through '011').

#### **VRAM Mask Low**



Index:0x0090Access:Read/WritePower on Value:Undefined

Mask VRAM PIX inputs 31:28 Bit 7 Mask VRAM PIX inputs 27:24 Bit 6 Mask VRAM PIX inputs 23:20 Bit 5 Bit 4 Mask VRAM PIX inputs 19:16 Bit 3 Mask VRAM PIX inputs 15:12 Bit 2 Mask VRAM PIX inputs 11:08 Mask VRAM PIX inputs 07:04 Bit 1 Bit 0 Mask VRAM PIX inputs 03:00

A value of 1 on any of the bits in this register masks (forces to 0) the corresponding received VRAM pixel port inputs. This register has no effect on the inputs unless enabled with the VMSK CNTL bit of the Miscellaneous Control 1 register.

## VRAM Mask High



Index: 0x0091
Access: Read/Write
Power on Value: Undefined

Rit 7 Mask VRAM PIX inputs 63:60 Bit 6 Mask VRAM PIX inputs 59:56 Mask VRAM PIX inputs 55:52 Bit 5 Bit 4 Mask VRAM PIX inputs 51:48 Bit 3 Mask VRAM PIX inputs 47:44 Bit 2 Mask VRAM PIX inputs 43:40 Bit 1 Mask VRAM PIX inputs 39:36 Bit 0 Mask VRAM PIX inputs 35:32

A value of 1 on any of the bits in this register masks (forces to 0) the corresponding received VRAM pixel port inputs. This register has no effect on the inputs unless enabled with the VMSK CNTL bit of the Miscellaneous Control 1 register.

**Note:** The mask function is intended to be used with the MISR for diagnostics. See 10.0 "Diagnostic Support" on page 26 for more details.

## 13.0 Pin Descriptions

Table 11. Pin Descriptions

| Signal                    | Typ<br>e | Pin(s)                                                                                                                                                                                                                  | Description                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|---------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Clocks and Clock Controls |          |                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| REFCLK                    | I        | 80                                                                                                                                                                                                                      | Reference Clock. A fixed frequency of 2 MHz to 100 MHz applied to this pin provides the reference clock for the programmable pixel and system clock PLLs. When the Direct Programming method is used the REFCLK frequency range is 4 MHz to 62 MHz on 2 MHz boundaries.                                                                                                                     |  |  |  |  |
| FS[1:0]                   | I        | 96,83                                                                                                                                                                                                                   | Frequency Select. These two inputs select one of four sets of registers containing the programming values for the pixel PLL.                                                                                                                                                                                                                                                                |  |  |  |  |
| DDOTCLK                   | 0        | 116                                                                                                                                                                                                                     | Divided Dot Clock. The output of the pixel PLL, divided by 1, 2, 4, 8 or 16. The divide factor is under register control. In 24 BPP Packed pixel mode the SCLK signal can be selected for this output instead of the divided pixel PLL output, under register control.  This output can be 3-stated under register control.                                                                 |  |  |  |  |
| SCLK                      | 0        | 113                                                                                                                                                                                                                     | Serial Clock. A divided version of the pixel PLL, where the divide ratio is determined by the required bandwidth of the incoming pixels. When the PIX port is selected, the SCLK frequency is a function of the VRAM width and the pixel format (bits per pixel). SCLK is equal to the pixel PLL output when the VGA port is selected.  This output can be 3-stated under register control. |  |  |  |  |
| LCLK                      | I        | 109                                                                                                                                                                                                                     | Load Clock. Latches data from the PIX port, the VGA port, and the video control inputs.                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| SYSCLK                    | 0        | 75                                                                                                                                                                                                                      | System Clock. The output of the SYSCLK programmable PLL.<br>This output can be 3-stated under register control.                                                                                                                                                                                                                                                                             |  |  |  |  |
|                           | •        |                                                                                                                                                                                                                         | Video Data Inputs                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| PIX[63:0]                 | I        | 10,9,8,7,67,66,65,64,<br>123,122,121,120.119,118,<br>117,140,139,138,137,136,<br>135,134,133,74,71,70,69,<br>68,6,5,4,3,2,1,144,143,<br>131,130,129,128,127,126,<br>125,124,56,55,54,53,52,<br>50,63,48,47,62,46,61,60, | Pixel data in from VRAMs.  Pixel data in can be selected as 64 or 32 bits using the VRAM SIZE bit of the Miscellaneous Control 1 register. For 32 bit use inputs PIX[63:32] are not used.  Latched on rising edge of LCLK.                                                                                                                                                                  |  |  |  |  |
|                           |          | 59,58,45,44,57,49,43                                                                                                                                                                                                    | VGA data in. Latched on rising edge of LCLK.                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |



**Table 11. Pin Descriptions (Continued)** 

|                      |          | Table 11.                | Pin Descriptions (Continued)                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|----------------------|----------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Signal               | Typ<br>e | Pin(s)                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| Video Control Inputs |          |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| BLANK                | I        | 78                       | A low level indicates blanking time; a high level indicates active picture time (pixel data, cursor, or border displayed).  Latched on rising edge of LCLK.                                                                                                                                                                                                                                                                                                                    |  |  |  |
| BORDER/OE            | I        | 79                       | This is a shared input. It may be used either as a border indicator, or as an interlace control. Within this document, this input may be referred to as BORDER or ODD/EVEN, depending on usage.                                                                                                                                                                                                                                                                                |  |  |  |
|                      |          |                          | When used as $\overline{BORDER}$ : When $\overline{BLANK}$ is high (picture time), a low level on $\overline{BORDER}$ indicates the contents of the border registers should be displayed, and a high level indicates that pixel data or cursor should be displayed. When $\overline{BLANK}$ is low (blanking time) $\overline{BORDER}$ must be low. If no border is to be displayed $\overline{BORDER}$ should be tied to $\overline{BLANK}$ . Latched on rising edge of LCLK. |  |  |  |
|                      |          |                          | When used as O/E (ODD/EVEN): Used in interlace mode to identify a field as odd or even; determines which row of cursor RAM to display if the cursor is enabled.  In this usage the input should only change during vertical blanking.                                                                                                                                                                                                                                          |  |  |  |
| HCSYNCIN             | I        | 77                       | This is a shared input. It may be used either as horizontal sync in or composite sync in.                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|                      |          |                          | When used as Horizontal Sync In, a delayed copy of this signal is presented on HSYNCOUT to align the timing of horizontal sync to the pixel data at the DACs. The incoming polarity can be inverted under register control. Latched on rising edge of LCLK.                                                                                                                                                                                                                    |  |  |  |
|                      |          | O.S.                     | When used as Composite Sync In, when enabled, this signal is presented on the Green DAC with the video data. The signal is delayed to match the delay of the pixel data. The incoming polarity can be inverted under register control.  Latched on rising edge of LCLK                                                                                                                                                                                                         |  |  |  |
| VSYNCIN              | I        | 76                       | Vertical Sync In. A copy of this signal is presented on VSYNCOUT. The incoming polarity can be inverted under register control.                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|                      | -        | V                        | /ideo Control Outputs                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| HSYNCOUT             | 0        | 32                       | Horizontal Sync Out. This is a copy of HCSYNCIN (or inverted HCSYNCIN), delayed by the same number of pixel clocks as seen by the pixel data at the input to the DACs. It can be forced to a high or low level or 3-stated under register control. The amount of delay may also be adjusted with the Horizontal Sync Position register.                                                                                                                                        |  |  |  |
| VSYNCOUT             | О        | 12                       | Vertical Sync Out. This is a copy of $\overline{VSYNCIN}$ (or inverted $\overline{VSYNCIN}$ ). It can be forced to a high or low level or 3-stated under register control.                                                                                                                                                                                                                                                                                                     |  |  |  |
| Type: I = Input,     | O = Ou   | tput, B = Bidirectional, | C = Component                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |

**Table 11. Pin Descriptions (Continued)** 

| Table 11. Pin Descriptions (Continued)                        |                          |                                     |                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|---------------------------------------------------------------|--------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Signal                                                        | Typ<br>e                 | Pin(s)                              | Description                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| Microprocessor Interface                                      |                          |                                     |                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| WR                                                            | I                        | 103                                 | Write strobe. Writes data into the register selected by RS[2:0] The leading edge samples RS[2:0]. The trailing edge clocks the data on D[7:0] into the selected register.                                                                                                                                                                                                           |  |  |  |  |  |
| RD                                                            | I                        | 102                                 | Read strobe. Drives the register contents selected by RS[2:0] onto D[7:0]. The leading edge samples RS[2:0]. When $\overline{RD}$ is low the D[7:0] drivers are enabled.                                                                                                                                                                                                            |  |  |  |  |  |
| RS[2:0]                                                       | I                        | 101,100,99                          | Register selects. Sampled on the leading edge of WR and RD and used to select one of the direct access registers. See Direct Access Registers for more details.                                                                                                                                                                                                                     |  |  |  |  |  |
| D[7:0]                                                        | В                        | 112,111,110,108,<br>107,106,105,104 | Bidirectional data bus for internal register write and read data. The drivers are enabled when $\overline{RD}$ is low, otherwise they are 3-stated.                                                                                                                                                                                                                                 |  |  |  |  |  |
|                                                               |                          |                                     | Miscellaneous                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| RESET                                                         | I                        | 81                                  | Internal register and PLL reset. Resets bits of certain registers to a given state. (Generally set to VGA operation. See register descriptions for details.) Also initializes PLL circuits. A reset is <b>required</b> following power on to guarantee proper PLL operation.                                                                                                        |  |  |  |  |  |
| VGAMODE                                                       | О                        | 98                                  | Indicates the VGA port is the selected pixel port. This output is the inverted state of Miscellaneous Control 2 register bit 0 (PORT SEL).                                                                                                                                                                                                                                          |  |  |  |  |  |
| SENSE                                                         | O                        | 11                                  | DAC sense comparator output. Goes low when one or more of the three DAC outputs is above the comparator voltage reference. The three individual comparator outputs are also available as register bits. Either unlatched or latched comparator outputs may be selected for generating the SENSE output, under register control. This output can be 3-stated under register control. |  |  |  |  |  |
| Video Outputs                                                 |                          |                                     |                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| RED                                                           | 0                        | 20                                  | RED video out.                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| GREEN                                                         | 0                        | 28                                  | GREEN video out.                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| BLUE                                                          | LUE O 30 BLUE video out. |                                     |                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| Type: I = Input, O = Output, B = Bidirectional, C = Component |                          |                                     |                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |



Table 11. Pin Descriptions (Continued)

| Signal         | Typ<br>e  | Pin(s)                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|----------------|-----------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| DAC Support    |           |                          |                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| VREFIN         | С         | 18                       | Voltage Reference In for the DACs. Connect 1.235 V to this pin and decou<br>it with a 10 nF ceramic capacitor to DACGND.                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| RREF           | С         | 26                       | Resistor Reference. Connect a resistor from this pin to DACGND. This pin connects to an internal op amp which compares the voltage on this pin to that of VREFIN, and adjusts the current flowing out of the RREF pin such that the voltage developed across the reference resistor matches VREFIN. The value of the resistor determines the full scale output current of the DACs. A value of 698 $\Omega$ is recommended. |  |  |  |  |  |
| CVREF          | С         | 15                       | Comparator Voltage Reference. An internal voltage divider between VREFIN and DACGND sets this pin to 0.35V. It is used internally by comparators to sense the values of the DAC outputs. Decouple this pin to DACGND with a 1nF ceramic capacitor.                                                                                                                                                                          |  |  |  |  |  |
| GREF           | С         | 14                       | DAC Gate Reference. Output of DAC op amp and input to gates of devices connecting DACVDD to the DAC current switches. Decouple this pin to DACVDD with a 1 nF ceramic capacitor.                                                                                                                                                                                                                                            |  |  |  |  |  |
|                | ·         |                          | PLL Support                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| RCI0           | С         | 92                       | Pixel PLL Loop filter. Connect to parallel 1.3 K $\Omega$ resistor and 680 pF capacitor. Return parallel resistor and capacitor to RCRET0 through 8.2 nF capacitor.                                                                                                                                                                                                                                                         |  |  |  |  |  |
| RCRET0         | С         | 91                       | Pixel PLL Loop filter return. Connect as described above under RCIO.                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| RCI1           | С         | 87                       | SYSCLK PLL Loop filter. Connect to parallel 1.3 K $\Omega$ resistor and 680 pF capacitor. Return parallel resistor and capacitor to RCRET1 through 8.2 nF capacitor.                                                                                                                                                                                                                                                        |  |  |  |  |  |
| RCRET1         | С         | 86                       | SYSCLK PLL Loop filter return. Connect as described above under RCI1.                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| Type: I = Inni | ıt O = Ou | tput. B = Bidirectional. | C = Component                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |

Type: I = Input, O = Output, B = Bidirectional, C = Component

**Table 11. Pin Descriptions (Continued)** 

| Signal                                                        | Typ<br>e         | Pin(s)                            | Description                                                                                                                             |  |  |  |  |  |
|---------------------------------------------------------------|------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Manufacturing Test                                            |                  |                                   |                                                                                                                                         |  |  |  |  |  |
| TESTMODE                                                      | I                | 94                                | This input must be low for functional use. Leave it unconnected. An internal pulldown resistor causes this input to be at ground level. |  |  |  |  |  |
| DI1                                                           | I                | 84                                | This input must be high for functional use.                                                                                             |  |  |  |  |  |
| DI2                                                           | I                | 85                                | This input must be high for functional use.                                                                                             |  |  |  |  |  |
| RI                                                            | I                | 95                                | This input must be high for functional use. An external 1 $K\Omega$ resistor to VDD is recommended.                                     |  |  |  |  |  |
|                                                               | Power and Ground |                                   |                                                                                                                                         |  |  |  |  |  |
| VDD                                                           |                  | 34,73,115,142                     | Logic Power (3.3 V)                                                                                                                     |  |  |  |  |  |
| GND                                                           |                  | 17,33,51,72,82,97,114,<br>132,141 | Logic Ground                                                                                                                            |  |  |  |  |  |
| DACVDD                                                        |                  | 13,19,21,24,27,29                 | DAC Power (3.3 V)                                                                                                                       |  |  |  |  |  |
| DACGND                                                        |                  | 16,22,23,25,31                    | DAC Ground                                                                                                                              |  |  |  |  |  |
| PLLVDD                                                        |                  | 90,93                             | PLL Power (3.3 V)                                                                                                                       |  |  |  |  |  |
| PLLGND                                                        |                  | 88,89                             | PLL Ground                                                                                                                              |  |  |  |  |  |
| Type: I = Input, O = Output, B = Bidirectional, C = Component |                  |                                   |                                                                                                                                         |  |  |  |  |  |



Table 12. Signal List by Pin Number

| ъ.  | Signal Description Din Signal Description |                      |     |         |               |     |           |                         |     | n       |                       |
|-----|-------------------------------------------|----------------------|-----|---------|---------------|-----|-----------|-------------------------|-----|---------|-----------------------|
| Pin | Signal                                    | Description          | Pin | Signal  | Description   | Pin | Signal    | Description             | Pin | Signal  | Description           |
| 001 | PIX[30]                                   | Pixel Data In        | 037 | VGA[2]  | VGA Data In   | 073 | VDD       | Logic Power (+3.3 V)    | 109 | LCLK    | Load Clock In         |
| 002 | PIX[31]                                   | Pixel Data In        | 038 | VGA[3]  | VGA Data In   | 074 | PIX[40]   | Pixel Data In           | 110 | D[5]    | Microprocessor Data   |
| 003 | PIX[32]                                   | Pixel Data In        | 039 | VGA[4]  | VGA Data In   | 075 | SYSCLK    | System Clock Out        | 111 | D[6]    | Microprocessor Data   |
| 004 | PIX[33]                                   | Pixel Data In        | 040 | VGA[5]  | VGA Data In   | 076 | VSYNCIN   | Vertical Sync In        | 112 | D[7]    | Microprocessor Data   |
| 005 | PIX[34]                                   | Pixel Data In        | 041 | VGA[6]  | VGA Data In   | 077 | HCSYNCIN  | Hor/Comp Sync In        | 113 | SCLK    | Serial Clock Out      |
| 006 | PIX[35]                                   | Pixel Data In        | 042 | VGA[7]  | VGA Data In   | 078 | BLANK     | Blank In                | 114 | GND     | Logic Ground          |
| 007 | PIX[60]                                   | Pixel Data In        | 043 | PIX[0]  | Pixel Data In | 079 | BORDER/OE | Border/Interlace In     | 115 | VDD     | Logic Power (+3.3 V)  |
| 800 | PIX[61]                                   | Pixel Data In        | 044 | PIX[3]  | Pixel Data In | 080 | REFCLK    | PLL Ref. Clock In       | 116 | DDOTCLK | Divided Dot Clock Out |
| 009 | PIX[62]                                   | Pixel Data In        | 045 | PIX[4]  | Pixel Data In | 081 | RESET     | Reset                   | 117 | PIX[49] | Pixel Data In         |
| 010 | PIX[63]                                   | Pixel Data In        | 046 | PIX[9]  | Pixel Data In | 082 | GND       | Logic Ground            | 118 | PIX[50] | Pixel Data In         |
| 011 | SENSE                                     | DAC Sense            | 047 | PIX[11] | Pixel Data In | 083 | FS[0]     | Frequency Select        | 119 | PIX[51] | Pixel Data In         |
| 012 | VSYNCOUT                                  | Vertical Sync Out    | 048 | PIX[12] | Pixel Data In | 084 | DI1       | Driver Inhibit 1 (Test) | 120 | PIX[52] | Pixel Data In         |
| 013 | DACVDD                                    | DAC Power (+3.3V)    | 049 | PIX[1]  | Pixel Data In | 085 | DI2       | Driver Inhibit 2 (Test) | 121 | PIX[53] | Pixel Data In         |
| 014 | GREF                                      | DAC Gate Ref         | 050 | PIX[14] | Pixel Data In | 086 | RCRET1    | Sys Loop Filter Rtrn    | 122 | PIX[54] | Pixel Data In         |
| 015 | CVREF                                     | DAC Comp. VREF       | 051 | GND     | Logic Ground  | 087 | RCI1      | Sys Loop Filter         | 123 | PIX[55] | Pixel Data In         |
| 016 | DACGND                                    | DAC Ground           | 052 | PIX[15] | Pixel Data In | 088 | PLLGND    | PLL Ground              | 124 | PIX[20] | Pixel Data In         |
| 017 | GND                                       | Logic Ground         | 053 | PIX[16] | Pixel Data In | 089 | PLLGND    | PLL Ground              | 125 | PIX[21] | Pixel Data In         |
| 018 | VREFIN                                    | DAC Voltage Ref      | 054 | PIX[17] | Pixel Data In | 090 | PLLVDD    | PLL Power (+3.3V)       | 126 | PIX[22] | Pixel Data In         |
| 019 | DACVDD                                    | DAC Power (+3.3V)    | 055 | PIX[18] | Pixel Data In | 091 | RCRET0    | Pix Loop Filter Rtrn    | 127 | PIX[23] | Pixel Data In         |
| 020 | RED                                       | + Red Output         | 056 | PIX[19] | Pixel Data In | 092 | RCI0      | Pix Loop Filter         | 128 | PIX[24] | Pixel Data In         |
| 021 | DACVDD                                    | DAC Power (+3.3V)    | 057 | PIX[2]  | Pixel Data In | 093 | PLLVDD    | PLL Power (+3.3V)       | 129 | PIX[25] | Pixel Data In         |
| 022 | DACGND                                    | DAC Ground           | 058 | PIX[5]  | Pixel Data In | 094 | TESTMODE  | Test Mode (Test)        | 130 | PIX[26] | Pixel Data In         |
| 023 | DACGND                                    | DAC Ground           | 059 | PIX[6]  | Pixel Data In | 095 | RĪ        | Receiver Inhibit (Test) | 131 | PIX[27] | Pixel Data In         |
| 024 | DACVDD                                    | DAC Power (+3.3V)    | 060 | PIX[7]  | Pixel Data In | 096 | FS[1]     | Frequency Select        | 132 | GND     | Logic Ground          |
| 025 | DACGND                                    | DAC Ground           | 061 | PIX[8]  | Pixel Data In | 097 | GND       | Logic Ground            | 133 | PIX[41] | Pixel Data In         |
| 026 | RREF                                      | DAC Resistor Ref     | 062 | PIX[10] | Pixel Data In | 098 | VGAMODE   | VGA Mode Out            | 134 | PIX[42] | Pixel Data In         |
| 027 | DACVDD                                    | DAC Power (+3.3V)    | 063 | PIX[13] | Pixel Data In | 099 | RS[0]     | Register Select [0]     | 135 | PIX[43] | Pixel Data In         |
| 028 | GREEN                                     | + Green Output       | 064 | PIX[56] | Pixel Data In | 100 | RS[1]     | Register Select [1]     | 136 | PIX[44] | Pixel Data In         |
| 029 | DACVDD                                    | DAC Power (+3.3V)    | 065 | PIX[57] | Pixel Data In | 101 | RS[2]     | Register Select [2]     | 137 | PIX[45] | Pixel Data In         |
| 030 | BLUE                                      | + Blue Output        | 066 | PIX[58] | Pixel Data In | 102 | RD        | Microprocessor Read     | 138 | PIX[46] | Pixel Data In         |
| 031 | DACGND                                    | DAC Ground           | 067 | PIX[59] | Pixel Data In | 103 | WR        | Microprocessor Write    | 139 | PIX[47] | Pixel Data In         |
| 032 | HSYNCOUT                                  | Horizontal Sync Out  | 068 | PIX[36] | Pixel Data In | 104 | D[0]      | Microprocessor Data     | 140 | PIX[48] | Pixel Data In         |
| 033 | GND                                       | Logic Ground         | 069 | PIX[37] | Pixel Data In | 105 | D[1]      | Microprocessor Data     | 141 | GND     | Logic Ground          |
| 034 | VDD                                       | Logic Power (+3.3 V) | 070 | PIX[38] | Pixel Data In | 106 | D[2]      | Microprocessor Data     | 142 | VDD     | Logic Power (+3.3 V)  |
| 035 | VGA[0]                                    | VGA Data In          | 071 | PIX[39] | Pixel Data In | 107 | D[3]      | Microprocessor Data     | 143 | PIX[28] | Pixel Data In         |
| 036 | VGA[1]                                    | VGA Data In          | 072 | GND     | Logic Ground  | 108 | D[4]      | Microprocessor Data     | 144 | PIX[29] | Pixel Data In         |
|     |                                           |                      |     |         |               |     |           |                         |     |         |                       |

## 14.0 Electrical and Timing Specifications

**Table 13. Recommended Operating Conditions** 

| Parameter         | Parameter Symbol       |       | MHz   | 220   | Units |       |
|-------------------|------------------------|-------|-------|-------|-------|-------|
| 1 at afficter     | Symbol                 | Min.  | Max.  | Min.  | Max.  | Onits |
| Power Supply      | VDD, DACVDD,<br>PLLVDD | 3.0   | 3.6   | 3.0   | 3.6   | Volts |
| Case Temperature  | T <sub>C</sub>         | 0     | 100   | 0     | 100   | °C    |
| DAC Output Load   | $R_{L}$                | 37.5  | 50    | 37.5  | 50    | W     |
| Reference Voltage | $V_{ m REF}$           | 1.204 | 1.266 | 1.204 | 1.266 | Volts |

**Table 14. Absolute Maximum Ratings** 

| Parameter                                             | Symbol              | Min. | Max. | Units   |
|-------------------------------------------------------|---------------------|------|------|---------|
| Power Supply                                          | VDD, DACVDD, PLLVDD | -0.5 | 3.8  | Volts   |
| Signal Pin Voltage                                    |                     | -0.5 | 5.5  | Volts   |
| DAC Output Short Circuit Duration                     | T <sub>SC</sub>     |      | ∞    | seconds |
| Case Temperature                                      | $T_{\rm C}$         | 0    | 145  | °C      |
| Soldering Temperature (5 seconds, 0.25 in. from case) | $T_{SOL}$           |      | 260  | °C      |
| Vapor Phase Soldering Temperature (1 minute)          | $T_{V,SOL}$         |      | 220  | °C      |

#### Table 15. DC Characteristics

| Parameter                                          | Symbol            | Min.       | Typical    | Max.       | Units        |
|----------------------------------------------------|-------------------|------------|------------|------------|--------------|
| DAC Outputs                                        |                   |            |            |            |              |
| Resolution                                         |                   | 8          | 8          | 8          | Bits         |
| Integral Linearity Error                           | ILE               |            |            | 3/4        | LSB          |
| Differential Linearity Error                       | DLE               |            |            | 3/4        | LSB          |
| Grey Scale Error                                   |                   |            |            | 5          | % Grey Scale |
| Monotonicity                                       |                   | Guaranteed | Guaranteed | Guaranteed |              |
| Coding                                             |                   |            |            |            | Binary       |
| CMOS Digital Inputs                                |                   |            |            |            |              |
| Input High Voltage (V <sub>DD</sub> = 3.3 V)       | $V_{\mathrm{IH}}$ | 2.0        |            | 5.5        | Volts        |
| Input Low Voltage                                  | $ m V_{IL}$       | -0.5       |            | 0.8        | Volts        |
| Input High Current (V <sub>IH</sub> = 2.4V)        | $I_{IH}$          |            |            | 20         | μΑ           |
| Input Low Current ( $V_{IL} = 0.0V$ )              | ${ m I}_{ m IL}$  | -20        |            |            | μΑ           |
| Input Capacitance (f=1 MHz, V <sub>IN</sub> =2.4V) | $C_{IN}$          |            | 4          | 8          | pF           |
| Digital Outputs                                    |                   |            |            |            |              |
| Output High Voltage (I <sub>OH</sub> = -12 mA)     | $V_{\mathrm{OH}}$ | 2.4        |            |            | Volts        |
| Output Low Voltage (I <sub>OL</sub> = 6 mA)        | $V_{ m OL}$       |            |            | 0.4        | Volts        |
| Hi-Z Current $(0 \le V \le 3.6 \text{ V})$         | $I_{OZ}$          | -20        |            | 20         | μΑ           |
| Analog Outputs                                     |                   |            |            |            |              |
| DAC Inaccuracy                                     |                   |            |            | 7          | %            |
| DAC-to-DAC Mismatch                                |                   |            |            | 5          | %            |
| Output Compliance                                  | V <sub>OC</sub>   | -0.5       |            | 1.2        | Volts        |

**Table 16. AC Characteristics** 

| Parameter                                                                                 | Symbol          | Spec.  | 170 MHz  | 220 MHz  | Units |
|-------------------------------------------------------------------------------------------|-----------------|--------|----------|----------|-------|
| RS[2:0] Setup                                                                             | t <sub>1</sub>  | min    | 10       | 10       | ns    |
| RS[2:0] Hold                                                                              | $t_1$           | min    | 10       | 10       | ns    |
| RD, WR Low                                                                                |                 | min    | 50       | 50       |       |
| RD, WR Low<br>RD, WR High                                                                 | t <sub>3</sub>  | min    | 6 × pclk | 6 × pclk | ns    |
|                                                                                           | t <sub>4</sub>  | 111111 | -        | o × pcik | ns    |
| RD Low to Data Bus Driven                                                                 | $t_5$           | min    | 2        | 2        | ns    |
| RD Low to Data Bus Valid                                                                  | t <sub>6</sub>  | max    | 40       | 40       | ns    |
| RD High to Data Bus 3-Stated                                                              | t <sub>7</sub>  | max    | 20       | 20       | ns    |
| Data Bus Hold from RD High                                                                | t <sub>8</sub>  | min    | 2        | 2        | ns    |
| Write Data Setup                                                                          | t <sub>9</sub>  | min    | 10       | 10       | ns    |
| Write Data Hold                                                                           | t <sub>10</sub> | min    | 10       | 10       | ns    |
| LCLK, SCLK Low                                                                            | t <sub>11</sub> | min    | 4        | 4        | ns    |
| LCLK, SCLK High                                                                           | t <sub>12</sub> | min    | 4        | 4        | ns    |
| LCLK, SCLK Cycle                                                                          | t <sub>13</sub> |        |          |          |       |
| 16:1 MUX Mode                                                                             |                 | max    | 10.6     | 13.75    | MHz   |
| 8:1 MUX Mode                                                                              |                 | max    | 21.25    | 27.5     | MHz   |
| 4:1 MUX Mode                                                                              |                 | max    | 42.5     | 55       | MHz   |
| 2:1 MUX Mode                                                                              |                 | max    | 85       | 100      | MHz   |
| 1:1 MUX Mode                                                                              |                 | max    | 100      | 100      | MHz   |
| 16:1 MUX Mode                                                                             |                 | min    | 94.12    | 72.7     | ns    |
| 8:1 MUX Mode                                                                              |                 | min    | 47.06    | 36.4     | ns    |
| 4:1 MUX Mode                                                                              |                 | min    | 23.53    | 18.2     | ns    |
| 2:1 MUX Mode                                                                              |                 | min    | 11.77    | 10       | ns    |
| 1:1 MUX Mode                                                                              |                 | min    | 10       | 10       | ns    |
| PIX[63:0] Setup                                                                           | t <sub>14</sub> | min    | 1        | 1        | ns    |
| PIX[63:0] Hold                                                                            | t <sub>15</sub> |        |          |          |       |
| 1:1 MUX Mode                                                                              |                 | min    | 4        | 4        | ns    |
| Not 1:1 MUX Mode                                                                          |                 | min    | 2        | 2        | ns    |
| VGA[7:0], $\overline{\text{BLANK}}$ , $\overline{\text{BORDER}}$ / $\overline{\text{OE}}$ | t <sub>16</sub> | min    | 3        | 3        | ns    |
| HCSYNCIN, Setup(1)                                                                        |                 |        |          |          |       |
| VGA[7:0], $\overline{\text{BLANK}}$ , $\overline{\text{BORDER}}$ / $\overline{\text{OE}}$ | t <sub>17</sub> | min    | 3        | 3        | ns    |
| HCSYNCIN, Hold(1)                                                                         |                 |        |          |          |       |
| SCLK to LCLK skew                                                                         | t <sub>18</sub> | min    | Any      | Any      | ns    |
| (T=SCLK cycle time)                                                                       |                 | max    | Any      | Any      | ns    |
| Supply Current (1)                                                                        |                 | typ(2) | 450      | 650      | mA    |
|                                                                                           |                 | max(3) | 716      | 890      | mA    |

#### Notes:

<sup>1.</sup> Supply current is the total of  $I_{\text{VDD}}\text{, }I_{\text{VDDDAC}}$  and  $I_{\text{VDDPLL}}\text{.}$ 

<sup>2.</sup> Typical power dissipation is for VDD, VDDDAC, VDDPLL = 3.3 V, TA = 20 °C, with typical pixel patterns such as displayed with graphical user interfaces, and

 $<sup>170\ \</sup>text{MHz}$  part running at  $135\ \text{MHz}$  (e.g., for  $1280\ x\ 1024\ \text{screen})$ 

<sup>220</sup> MHz part running at 216 MHz (e.g., for 1600 x 1280 screen)

<sup>3.</sup> Maximum power dissipation is for VDD, VDDDAC, VDDPLL = 3.6 V, TA = 0 °C, with alternating full black/full white pixels running at the maximum specified frequency (170/220 MHz)



Figure 4. Microprocessor Interface Timing



Figure 5. Pixel Data and Video Control Interface Timing



Figure 6. SCLK and LCLK Timing



### 15.0 Video Waveforms



Table 17. Composite Video Output Waveform

|             |           | Doubly terminated 75 ohms, RREF=698 ohms |          |        |           |         |     |       |      |      |       |       |
|-------------|-----------|------------------------------------------|----------|--------|-----------|---------|-----|-------|------|------|-------|-------|
| Sync        |           | No                                       |          |        | No        |         |     | Yes   |      |      | Yes   |       |
| Pedestal    |           | No                                       |          |        | Yes       |         |     | No    |      | 4    | Yes   |       |
| Value       | IRE       | mA                                       | V        | IRE    | mA        | V       | IRE | mA    | V    | IRE  | mA    | V     |
| WHITE       | 100       | 18.65                                    | 0.70     | 92.5   | 19.05     | 0.714   | 100 | 26.67 | 1.00 | 92.5 | 26.67 | 1.00  |
|             | 100       |                                          |          | 92.5   |           |         | 100 |       |      | 92.5 |       |       |
| BLACK       |           | 0                                        | 0        | 7.5    | 1.43      | 0.054   |     | 8.02  | 0.30 | 7.5  | 9.05  | 0.340 |
| BLANK       |           |                                          |          | 7.0    | 0         | 0       | -30 |       |      | 7.5  | 7.62  | 0.286 |
|             |           |                                          |          |        |           |         | 00  |       |      | -40  |       |       |
| SYNC        |           |                                          |          |        |           |         |     | 0     | 0    |      | 0     | 0     |
| Note: RS-34 | 3A level: | s and to                                 | lerances | assume | ed on all | levels. |     |       |      |      |       |       |

Table 18. Composite Video Output Waveform

|          | Doubly terminated 100 ohms, RREF=927 ohms |       |      |      |       |       |     |       |      |      |       |       |
|----------|-------------------------------------------|-------|------|------|-------|-------|-----|-------|------|------|-------|-------|
| Sync     |                                           | No    |      |      | No    |       |     | Yes   |      |      | Yes   |       |
| Pedestal |                                           | No    |      |      | Yes   |       |     | No    |      |      | Yes   |       |
| Value    | IRE                                       | mA    | V    | IRE  | mA    | V     | IRE | mA    | V    | IRE  | mA    | V     |
| WHITE    |                                           | 13.99 | 0.70 |      | 14.28 | 0.714 |     | 20.00 | 1.00 |      | 20.00 | 1.00  |
|          | 100                                       |       |      | 92.5 |       |       | 100 |       |      | 92.5 |       |       |
| BLACK    |                                           | 0     | 0    | 7.5  | 1.07  | 0.054 |     | 6.01  | 0.30 | 7.5  | 6.78  | 0.340 |
| BLANK    |                                           |       |      | 7.0  | 0     | 0     | 20  |       |      | 7.0  | 5.71  | 0.286 |
|          |                                           |       |      |      |       |       | -30 |       |      | -40  |       |       |
| SYNC     |                                           |       |      |      |       |       |     | 0     | 0    |      | 0     | 0     |

## 16.0 Package Information



## 17.0 Ordering Information

Table 19. Part Numbers

| Table 13: 1 alt Nambers |                    |         |  |  |  |  |
|-------------------------|--------------------|---------|--|--|--|--|
| Product                 | Part Number        | Speed   |  |  |  |  |
| RGB526                  | IBM 37RGB526 CF 17 | 170 MHz |  |  |  |  |
|                         | IBM 37RGB526 CF 22 | 220 MHz |  |  |  |  |
| PCR526DR                | IBM 37RGB526 DB 17 | 170 MHz |  |  |  |  |
| RGB526DB                | IBM 37RGB526 DB 22 | 220 MHz |  |  |  |  |



## 18.0 Change Summary

Table 20. Summary of Changes

| Date     | Changes                                                                                                                                                                                                                                                                                                                            |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 04/17/95 | 1. First publication.                                                                                                                                                                                                                                                                                                              |
| 09/25/95 | This revision adds the RGB526DB product; the document becomes a combined RGB526/RGB526DB data sheet. All of the changes are related to adding the RGB526DB product information:                                                                                                                                                    |
|          | 1. In section 2.4.1, "SCLK," added details of SCLK operation when double buffer operation is enabled.                                                                                                                                                                                                                              |
|          | 2. To section 3.0, "Modes of Operation," added sub-section 3.2, "RGB526DB Double Buffer Operation".                                                                                                                                                                                                                                |
|          | 3. To section 5.0, "VRAM Pixel Formats," added sub-section 5.6, "16 BPP Double Buffered (RGB526DB Only)". This is the detailed description of the RGB526DB double buffer operation.                                                                                                                                                |
|          | 4. Added Table 6, "Pixel Format Table - RGB526DB Double Buffer Operation".                                                                                                                                                                                                                                                         |
|          | 5. In Table 10, "Internal Register Summary," renamed register at index 0x0078 from "Key Control" to "Key Control/DB Operation". (Note: in the original publication this register was mistakenly omitted from the table.)                                                                                                           |
|          | 6. On page 35, add bit 0, DBUF MODE, to description of the Miscellaneous Control 3 register.                                                                                                                                                                                                                                       |
|          | 7. On page 41, for the 16 Bit Pixel Control register, added notes for bits 7-6 and bit 1 regarding use with double buffer operation.                                                                                                                                                                                               |
|          | 8. On page 56 the description of the Key Control register is broken into two discussions: RGB526 only and RGB526DB only. For the RGB526DB, the register is called the Key Control/DB Operation register, and bit 0 is assigned two uses: Key Enable (non-double buffer operation) and Suppress Buffer B (double buffer operation). |
|          | 9. To Table 19, "Part Numbers," added part numbers for RGB526DB.                                                                                                                                                                                                                                                                   |
|          | 10. Added appendix A.0, "RGB526, RGB526DB Comparison".                                                                                                                                                                                                                                                                             |
|          | 11. To appendix B.0 (previously A.0), added miscellaneous items for RGB526DB.                                                                                                                                                                                                                                                      |

#### **Appendix**

# A.0 RGB526, RGB526DB Comparison

The RGB526DB is a superset of the RGB526 that adds the 16 BPP double buffer operation. The two products are pin and register compatible and are identical in all aspects except for the register bits that control the double buffer operation:

- The Miscellaneous Control 3 register, bit 0, is unused on the RGB526 but is used as the DBUF MODE (double buffer mode enable) bit on the RGB526DB.
- 2. For the RGB526DB the Key Control register is relabeled as the Key Control/DB Operation register. Bit 0 of this register takes on a dual function for the RGB526DB. For non-16 BPP formats, bit 0 retains its function as the Key Enable bit (the same as the RGB526). For the 16 BPP format, bit 0 is defined as the SUPP BUFB (suppress buffer B) bit.

The actions of these bits are described in sections 2.4.1, 3.2 and 5.6.

Note that the contents of the ID register (index 0x0001) are the same for both products.

# B.0 Relationship to RGB524, RGB624

The RGB524, RGB526/RGB526DB and RGB624 products are a set of pin and register compatible Palette DACs that share these basic features: 144-pin QFP package, 64-bit pixel data path, packed 24-bit pixels, VGA pixel port, two on-chip programmable clock generators, video clocks up to 220 MHz, on-chip 64x64 hardware cursor, triple monotonic 8-bit DAC's to display 16.8 million colors.

The RGB526/RGB526DB improves on the RGB524 with the following features:

□ Enhanced PLL programming. While retaining the PLL programming features of the RGB524 for compatibility, the RGB526/RGB526DB offers a new mode for programming the PLLs. Called "full M over N", this new mode has larger M and N ranges, and removes restrictions on M and N combinations that exist with the previous generation. Full M over N gives finer control in programming for the desired output frequencies, and allows the internal operating points of the PLLs to be fine tuned.

- □ An "advanced function" hardware cursor. This provides the same cursor functions as the RGB524, and in addition provides a "translucent" cursor in which the underlying pixels appear to "shine through" the displayed cursor.
- □ 32 BPP Overlay/Underlay layers, with selection based on a "chroma key".
- □ Elimination of SCLK to LCLK skew specification (Table 16, "AC Characteristics," value t<sub>18</sub>). Previous generation parts, may need programming or external hardware to guarantee the required SCLK to LCLK separation. With the RGB526/RGB526DB no special handing is required.
- ☐ 15 BPP double buffer operation (RGB526DB only).
- ☐ Miscellaneous features described below.

The RGB624 offers these same features, and has the following additional features:

- YUV pixel support, with fully programmable YUV-RGB conversion.
- Mixed YUV/RGB pixels, with selection based on a "tag" bit.
- ☐ Additional 16 BPP and 32 BPP Overlay/Underlay layers, with selection based on a "chroma key" or "luma key"

In general the RGB524 can be used as the "base feature" set for a graphics adapter, and the additional features of the RGB526/RGB526DB or RGB624 can be added to an existing design by "dropping in" the new product, and enabling the new features by providing additional programming.

The exact differences between the RGB524 and RGB526/RGB526DB are detailed below. Several changes have been made to enhance the usability of the part or to work with the new features that are "non transparent". For drop in replacement of the RGB524 these changes should be examined to determine the effect on existing designs, if any. Users of other members of the RGB51x and RGB52x product family should also examine these changes to determine the effects on programming compatibility. It is felt that for the most part these changes will be considered desirable or nonconsequential.

The remaining changes are considered "transparent" because they remove previous restrictions, or they are added features that are enabled by setting register bits that are reserved in the RGB51x and RGB52x products.



#### **B.1** ID Register

The ID register (index 0x0001) contains the same value, 0x02, for both the RGB524 and the RGB526/RGB526DB. The RGB624 has a new value, 0x30.

#### **B.2** Non-Transparent Changes

#### **B.2.1** Revision Register

The value in the Revision register (index 0x0000) can vary from product to product.

#### **B.2.2 DAC Operation- Slew Rate**

For the RGB526/RGB526DB and the RGB624, the DSR bit (DAC Slew Rate) in the DAC Operation register (index 0x0006) is inverted: '0' is now the "fast" setting and '1' is now the "slow" setting.

The power on value for this register is changed from 0x00 to 0x02. This sets the DSR bit for a "slow" slew rate.

#### **B.2.3** Pixel PLL Power On Values

The power on values for three of the Pixel PLL programming registers is changed as follows:

The Fixed Pixel PLL Reference Divider (index 0x0014) is changed from "undefined" to 0x05; the F0 register (index 0x0020) is changed from 0x00 to 0x05; and the F1 register (index 0x0021) is changed from 0x00 to 0x0e.

As described in section 2.2.1, "REFCLK," these values are chosen for use with a 14.31818 MHz reference clock to produce the VGA frequencies of 25.057 MHz and 28.322 MHz.

#### **B.2.4** Pixel PLL Power On Enable

The power on value for the Miscellaneous Clock Control register (index 0x0002) is changed from 0x00 to 0x01. This sets the PPLL ENAB bit (Pixel PLL Enable) "on" (enabled), so that at power on time the Pixel PLL is running (using the power on programming values described above).

#### **B.2.5** PLL Behavior During Reset

For the RGB524, when  $\overline{RESET}$  is low both the SYSCLK and Pixel PLLs oscillate at some indeterminate frequency, generally in the range of 5 KHz to 250 KHz.

For the RGB526/RGB526DB and RGB624, when RESET is low both the SYSCLK and Pixel PLLs will oscillate at

their power on programmed values. When  $\overline{RESET}$  becomes high the PLLs will continue to oscillate at these same frequencies.

#### B.2.6 SYSCLK Source

For the RGB524 the source of the SYSCLK output can be either the SYSCLK PLL, or the REFCLK input. The System Clock Control register (index 0x0008), bit 1 (SYSC SRC) selects the SYSCLK source.

For the RGB526/RGB526DB and RGB624 REFCLK cannot be used as the source of the SYCLK output. Bit 1 of the System Clock Control register becomes "reserved".

#### **B.2.7** MISR Operation

For the previous generation RGB51x and RGB52x products the diagnostic MISR (Multiple Input Signature Register) is armed to accumulate a signature by "pulsing" the MISR CNTL bit in the Miscellaneous Control 1 register. That is, writing this register to change the MISR CNTL bit from '0' to '1' and back to '0'.

For the RGB526/RGB526DB and RGB624 the MISR is armed by changing the MISR CNTL bit from '0' to '1'. Also, MISR CNTL must stay at '1' throughout the frame, until the entire signature has been accumulated.

To detect the end of signature accumulation a new register, MISR Status, has been added at index 0x0083. This register contains a single bit, MISR DONE, that indicates when a signature has finished accumulating.

#### **B.3** Transparent Changes

#### B.3.1 SCLK to LCLK Relationship

For the previous generation RGB51x and RGB52x products there is a skew specification that requires the rising edge of LCLK to not be too close to the rising edge of SCLK (a "dead zone" must be maintained.)

For the RGB526/RGB526DB and RGB624 this restriction is eliminated.

#### B.3.2 SYSCLK Glitch on DF Change

For the RGB524 and RGB528, if the DF programming bits are changed when the SYSCLK programming values are changed then the SYSCLK output can glitch.

For the RGB526/RGB526DB and RGB624 this behavior does not occur. The DF bits (or the P bits, using the new "standard programming mode") can be changed along

with the other programming values, and the SYSCLK frequency will change smoothly to the new value.

#### **B.3.3** Generated Composite Sync

Miscellaneous Control 1 register (index 0x0070) changes bit 2 from "reserved" to XOR SYNC. This bit, when set, generates composite sync internally as the Exclusive OR of the incoming horizontal and vertical sync signals.

#### B.3.4 VRAM Input Byte Swapping

Miscellaneous Control 3 register (index 0x0072) changes bits 3 and 2 from "reserved" to SWAP BYTE. These bits, when set, cause incoming bytes on the PIX[63:00] inputs to be swapped within byte pairs.

#### B.3.5 Enhanced PLL Programming

The RGB526/RGB526DB and RGB624 add a new mode for programming the PLL frequencies. This new mode (now called the "standard" mode, or sometimes called "full M over N"), allows a wider range of "M", "N", and "P" values (multiply, prescale divide, and postscaler divide). Also, a link between the postscaler divide factor (DF bits in the old mode) and the prescaler divide value is removed, eliminating a programming restriction.

With the new programming mode an additional programming value, "C", must be supplied to adjust the operating point of the analog circuits.

For compatibility with the RGB51x and RGB52x products the "old" programming mode is retained (now called "restricted" programming). The power on mode is the "old" mode, and the power on programming values are "old" mode values.

System Clock Control register (index 0x0008) changes bit 2 from "reserved" to PROG MODE. This bit, when set, enables the new standard programming mode for the SYSCLK PLL. Also, with the new standard programming, the contents of the two SYSCLK programming registers located at indices 0x0015 and 0x0016 are redefined to supply the N and M values, and two new registers at indices 0x0017 and 0x0018 are added to supply the P and C values.

Pixel PLL Control 1 register (index 0x0010) changes the EXT/INT bit values of 100 and 101 from "reserved" to "Standard Mode", to enable the new standard programming mode for the Pixel PLL. '100' is for external frequency select and '101' is for internal frequency select.

Pixel PLL Control 2 register (index 0x0011) extends the meaning of the INT FS bits for use with the new stan-

dard programming mode, when the EXT/INT bits of Pixel PLL Control 1 are set to '101'.

With standard programming the F0 - F15 pixel PLL programming register values are redefined. The old programming mode organizes the F0 - F15 pixel PLL programming registers as 8 banks of 2 programming values, for a 1-of-8 frequency selection. The new standard programming mode organizes F0 - F15 as 4 banks of 4 programming values, for a 1-of-4 frequency selection. This is a consequence of having more programming bits needed for the new programming mode.

For diagnostic readback, with the new standard programming mode the contents of the readback registers at indices 0x008e and 0x008f are redefined to reflect the pixel PLL M and N values, and registers are added at indices 0x008c and 0x008d to reflect the P and C values.

#### B.3.6 Advanced Cursor

The cursor operation has been extended with the ability to display a "translucent" cursor pixel. With this pixel type the underlying pixel appears to "shine through" the translucent cursor color.

A new register, Advanced Cursor Control (index 0x0037) is added. This register has a single bit, ACA ENAB (Advanced Cursor Attribute Enable) to enable the new cursor operation. The power on value of this bit is "disabled", so that the standard cursor operation is used following a reset.

A second new register, Advanced Cursor Attribute (index 0x0038) is added. When the advanced cursor operation is enabled the two bit cursor value specifies one of four colors. Each of these colors has a two bit entry in the Advanced Cursor Attribute register which specifies whether the cursor pixel is transparent, solid, translucent, or highlighted.

#### B.3.7 32 BPP Overlay

Two new registers, the Key (index 0x0068) and the Key Mask (index 0x006c) are added for chroma key matching of the overlay layer for the new 32 BPP overlay pixel format.

A third register, the Key Control (index 0x0078) is also added. This register has a single bit, KEY ENAB, to enable the chroma key matching operation. This in effect enables the overlay format when the 32 BPP format is selected. The power on value of this bit is "disabled", so that normal 32 BPP operation is used following a reset.



If chroma key matching is enabled with the new Key Control register, and 32 BPP is selected, the 24 low order bits are the underlay, and the 8 high order bits are the overlay. If key matching is not enabled the 8 high order bits are unused and the 24 low order bits are used as before.

The 32 bit Pixel Control register (index 0x000e) has been extended with a new bit, bit 6 = B8 DCOL. This bit determines whether the 8 bit overlay is indirect (through the palette) or direct (to the DACs, for grey scale). This bit has no effect if chroma key matching is not enabled.

## B.3.8 Double Buffer Operation (RGB526DB only)

As described above in appendix A.0, for the RGB526DB bit 0 of the Miscellaneous Control 3 register becomes the DBUF MODE bit, the Key Control register is relabeled the Key Control/DB Operation register, and the Key Enable bit in that register takes on the SUPP BUFB function for 16 BPP format.

#### B.4 RGB624 Additional Features

The RGB526/RGB526DB and RGB624 differ from the RGB524 and other members of RGB as discussed above. In addition, the RGB624 offers the following pixel formats:

- ☐ 16 bit 4:2:2 YUV
- ☐ 16 bit mixed 4:2:2 YUV/5:5:5 RGB, selected with a tag bit
- ☐ 16 bit 8 RGB indirect, 16 4:2:2 YUV (overlay)
- ☐ 24 bit packed 4:4:4 YUV
- □ 32 bit 24 4:4:4 YUV, 8 unused
- □ 32 bit 24 4:4:4 YUV, 8 RGB indirect (overlay)

YUV is a format in which pixels are stored as luminance (Y) and chrominance (U and V) values. An on-board, programmable converter translates the YUV pixels to RGB. Four new registers K1, K2, K3, K4 (indices 0x00a0 - 0x00a3) are added to hold the constants for the color space converter.

The Key, Key Mask, and Key Enable registers used to support chroma keying for the 32 BPP mode are also used on the RGB624 to support "Luma Key" operation with 16 BPP and 32 BPP. (The Y value is compared to the Key value to switch between overlay and underlay.)

New bits are added to the 16, 24 Packed, and 32 Bit Pixel Control registers (index 0x000c, 0x000d and 0x000e) to enable the YUV formats.

See the RGB624 data sheet (document number IOG624DSU) for more details.

(Note: the RGB624 does not support the double buffer operation of the RGB526DB).

# C.0 PLL Compatibility Programming

The previous generation RGB51x and RGB52x products all have a programmable PLL for generating a pixel clock, and the RGB524 and RGB528 have a second PLL for driving a "SYSCLK" output. All of these PLLs are programmed identically.

As discussed in section 2.6 PLL Operation Compatibility with RGB51x/RGB52x on page 6, the

RGB526/RGB526DB provides a new method of programming the PLLs. This new method is less restrictive and is preferred for new applications, hence it is now called the "standard" programming method.

But for software compatibility with the previous generation RGB51x and RGB52x products the RGB526/RGB526DB additionally provides the same, "old" method of PLL programming. When reset the RGB526/RGB526DB PLL control registers are set for "old" programming, and the programming registers contain power on values appropriate for "old" programming.

This appendix describes the "old" programming modes.

#### C.1 PLL Programming

The two PLLs are programmed identically. Three values are used:

#### **REF DIV COUNT (Reference Divide Count)** This

number provides a count value for dividing down the incoming REFCLK. It must be between 2 and 31. Operation of the PLL is indeterminate if this number is 0 or 1.

#### VCO DIV COUNT (VCO Divide Count) This

number provides a count value for the divider in the PLL feedback loop. The value can range from 0 through 63. Internally, 65 is added to VCO DIV COUNT, so that the PLL feedback divider value ranges from 65 through 128.

DF (Desired Frequency) These are two bits with values of 00, 01, 10, and 11. The intent of these bits is to divide the operation of the PLL into four frequency ranges. Following the divide of the REFCLK provided by the REF DIV COUNT there is an additional divide-by-two which is selected or bypassed with the DF bits. Also, the output of the PLL has a divider stage, or postscaler, that is controlled by the DF bits.

Table 21, "PLL Equations," gives the general formulas for programming the PLLs. Because of the action of the DF bits there are four equations, one for each DF bit setting.

It is possible to program the PLLs with values that generate illegal operating conditions:

 The reference frequency VRF (Video Reference Frequency), which is internal to the PLL, cannot be less than 1 MHz.

Table 21. PLL Equations

| DF | Output Frequency            | Internal VRF        | Max Output Freq. (MHz) |         |  |
|----|-----------------------------|---------------------|------------------------|---------|--|
|    | Output Prequency            | internal vici       | 170                    | 220     |  |
| 00 | FREF × (VCO DIV COUNT + 65) | FREF                | 42.5                   | 55.0    |  |
| 00 | (REF DIV COUNT) × 8         | (REF DIV COUNT) × 2 | 42.3                   | 55.0    |  |
| 01 | FREF × (VCO DIV COUNT + 65) | FREF                | 85                     | 110 (*) |  |
| 01 | (REF DIV COUNT) × 4         | (REF DIV COUNT) × 2 | 65                     |         |  |
| 10 | FREF × (VCO DIV COUNT + 65) | FREF                | 170 (*)                | 220 (*) |  |
| 10 | (REF DIV COUNT) × 2         | (REF DIV COUNT) × 2 | 170()                  | 220 (*) |  |
| 11 | FREF × (VCO DIV COUNT + 65) | FREF                | 170 (*)                | 220 (*) |  |
| 11 | REF DIV COUNT               | REF DIV COUNT       | 170 (*)                |         |  |

<sup>1.</sup> FREF = REFCLK frequency

<sup>2.</sup> Frequencies marked with (\*) are maximum pixel PLL frequencies. The SYSCLK PLL maximum output frequency is 100 MHz.

- 2. The internal VCO (Voltage Controlled Oscillator) cannot exceed the rated speed of the product (170/220 MHz).
- 3. The SYSCLK output driven by the SYSCLK PLL cannot exceed 100 MHz.
- 4. The DDOTCLK output driven by the pixel PLL cannot exceed 100 MHz.

Table 21, "PLL Equations," gives the equations for calculating the internal VRF. Table 21 also gives the maximum allowable output frequency for each setting of DF. This reflects the action of the VCO postscaler. If the PLLs are programmed so that these maximum dot clock frequencies are not exceeded then the maximum VCO frequency will not be exceeded.

#### C.2 PLL Frequency Selection

The REF DIV COUNT, VCO DIV COUNT, and DF bits are provided to the PLLs in a pair of 8-bit registers. REF DIV COUNT is 5 bits and occupies one register, with the 3 high order bits unused. The 6 VCO DIV COUNT bits occupy the second register, with the 2 high order bits used by DF.

For the SYSCLK PLL, the two programming registers are the System PLL Reference Frequency, which holds REF DIV COUNT, and the System PLL VCO Divider, which holds VCO DIV COUNT and the DF bits.

For the pixel PLL, there are actually 17 registers which can be used to hold the programming values: Fixed Pixel PLL Reference Divider and F0 - F15. A pair of registers is selected from this group to provide the pixel PLL programming values. This selection is controlled by the pixel PLL Control 1 and pixel PLL Control 2 registers.

Two different programming styles are supported:

**Direct Programming** In this scheme only the register holding VCO DIV COUNT and DF is altered to change the frequencies. The register for REF DIV COUNT holds a value that is constant for all frequencies. This method is discussed in more detail below.

**M over N** In this scheme both register values are changed to program a new frequency. The name refers to the general PLL concept in which

Output frequency = Input reference  $\times$  (M/N)

where VCO DIV COUNT serves as M and REF DIV COUNT serves as N, with modifications to the equation as shown in Table 21, "PLL Equations."

For the SYSCLK PLL there is not much distinction between the two programming styles. Both registers are written to provide an initial operating frequency. Then to change frequency either one register is changed (System PLL VCO Divider), or both registers are changed, depending on the programming style.

For the pixel PLL, a set of preprogrammed frequencies can be stored in the F0 - F15 registers, and the number of stored frequencies depends on the programming style.

When the direct programming style is used a single REF DIV COUNT is stored in the Fixed PLL Reference Divider register. Up to 16 values of VCO DIV COUNT and DF can be stored in the F0 - F15 registers, allowing 16 preprogrammed pixel clock frequencies.

With the M/N style the Fixed Pixel PLL Reference Divider register is not used. The F0 - F15 are reconfigured as 8 pairs of M and N values (M0,N0,M1,N1, ... M7,N7). This allows 8 preprogrammed pixel clock frequencies.

The selection of the programming registers, either 1 of the 16 F0 - F15 registers or 1 of the 8 M/N pairs, is done either externally with the FS[1:0] inputs to the module, or internally with the INT FS[3:0] bits of Pixel PLL Control 2 register. When the M/N style is used INT FS[3] is ignored.

The programming style and selection source is chosen with the EXT/INT bits of the Pixel PLL Control 1 register, as shown in Table 22, "Pixel PLL Control 1 EXT/INT Freq. Selection."

Table 22. Pixel PLL Control 1 EXT/INT Freq. Selection

| EXT<br>/INT | Frequency<br>Selection | REF DIV<br>COUNT           | VCO DIV<br>COUNT, DF |
|-------------|------------------------|----------------------------|----------------------|
| 000         | External<br>FS[1:0]    | Fixed Reference<br>Divider | F0-F3                |
| 001         | External<br>FS[1:0]    | N0-N3                      | M0-M3                |
| 010         | Internal<br>FS[3:0]    | Fixed Reference<br>Divider | F0-F15               |
| 011         | Internal<br>FS[2:0]    | N0-N7                      | M0-M7                |

Note that there are more selections available with the internal register INT FS[3:0] than using the external FS[1:0] inputs. With the external inputs, only 4 frequencies can be chosen, using either direct programming or M/N. With the INT FS[3:0] bits 8 frequencies can be chosen using M/N or 16 frequencies can be chosen using direct programming.

Table 23. Direct Programming Reference Divider Values

| values       |                                               |  |  |  |  |  |
|--------------|-----------------------------------------------|--|--|--|--|--|
| REFCLK (MHz) | Fixed PLL Reference Divider<br>Register Value |  |  |  |  |  |
| 4            | 0x0002                                        |  |  |  |  |  |
| 6            | 0x0003                                        |  |  |  |  |  |
| 8            | 0x0004                                        |  |  |  |  |  |
| 10           | 0x0005                                        |  |  |  |  |  |
| 12           | 0x0006                                        |  |  |  |  |  |
| 14           | 0x0007                                        |  |  |  |  |  |
| 16           | 0x0008                                        |  |  |  |  |  |
| 18           | 0x0009                                        |  |  |  |  |  |
| 20           | 0x000a                                        |  |  |  |  |  |
| 22           | 0x000b                                        |  |  |  |  |  |
| 24           | 0х000с                                        |  |  |  |  |  |
| 26           | 0x000d                                        |  |  |  |  |  |
| 28           | 0x000e                                        |  |  |  |  |  |
| 30           | 0x000f                                        |  |  |  |  |  |
| 32           | 0x0010                                        |  |  |  |  |  |
| 34           | 0x0011                                        |  |  |  |  |  |
| 36           | 0x0012                                        |  |  |  |  |  |
| 38           | 0x0013                                        |  |  |  |  |  |
| 40           | 0x0014                                        |  |  |  |  |  |
| 42           | 0x0015                                        |  |  |  |  |  |
| 44           | 0x0016                                        |  |  |  |  |  |
| 46           | 0x0017                                        |  |  |  |  |  |
| 48           | 0x0018                                        |  |  |  |  |  |
| 50           | 0x0019                                        |  |  |  |  |  |
| 52           | 0x001a                                        |  |  |  |  |  |
| 54           | 0x001b                                        |  |  |  |  |  |
| 56           | 0x001c                                        |  |  |  |  |  |
| 58           | 0x001d                                        |  |  |  |  |  |
| 60           | 0x001e                                        |  |  |  |  |  |
| 62           | 0x001f                                        |  |  |  |  |  |

#### C.3 Direct Programming

Use the following steps to calculate the values used with direct programming:

- 1. Look up the REFCLK frequency in Table 23, "Direct Programming Reference Divider Values," and write the given programming value into the PLL Reference Divider register (System PLL Reference Divider for the SYSCLK PLL, Fixed Pixel PLL Reference Divider for the pixel PLL). If the incoming REFCLK frequency does not appear in this table, then the direct programming method cannot be used.
- 2. Use Table 24, "PLL Direct Programming Equations," to determine the values to write into the VCO Divider register (System PLL VCO Divider for the SYSCLK PLL, F0 F15 for the pixel PLL). First, pick the row of the table whose frequency range covers the frequency of interest. This will determine the value of the DF bits to write. Next, use the given equation to calculate the value of the VCO DIV BITS. Write these two values together to the appropriate register.

The generated pixel clock frequency is designated in this table as VF, for Video Frequency. Note that within each range the desired VF frequency must lie on a given step value (e.g., with DF = 11 a frequency of 159 MHz is invalid because it does not lie on a 2 MHz step; but either 158 MHz or 160 MHz is valid).

**Table 24. PLL Direct Programming Equations** 

| DF                           | VCO Divide<br>Count | Frequency Range | Step (MHz) |  |  |  |  |
|------------------------------|---------------------|-----------------|------------|--|--|--|--|
| 00                           | (4 x VF) - 65       | 16.25 - 32 MHz  | 0.25       |  |  |  |  |
| 01                           | (2 x VF) - 65       | 32.5 - 64 MHz   | 0.5        |  |  |  |  |
| 10                           | VF - 65             | 65.0 - 128 MHz  | 1.0        |  |  |  |  |
| 11                           | (VF / 2) - 65       | 130.0 - 220 MHz | 2.0        |  |  |  |  |
| VF = Desired Video Frequency |                     |                 |            |  |  |  |  |



#### C.4 M/N Programming

For the "M over N" programming style use Table 21, "PLL Equations," in the following steps:

- Select values for REF DIV COUNT, VCO DIV COUNT, and DF that generate the desired frequency (or come close enough). Note that the values 0 and 1 are illegal for REF DIV COUNT under all conditions.
- Calculate the internal reference frequency VRF. Verify that this frequency is not less than 1 MHz.
- 3. Verify that the dot clock frequency does not exceed the maximum value specified in the table.
- 4. If conditions 2 and 3 are not met then the selected values cannot be used.

#### C.5 General PLL Programming

Fundamentally the only differences between the two programming styles are these:

- Direct programming can be used only if the REFCLK frequency falls on a 2 MHz boundary from 4 MHz through 62 MHz.
- 2. With direct programming, for a given pixel clock frequency there is only one set of programming values. These values are obtained from Table 23, "Direct Programming Reference Divider Values," and Table 24, "PLL Direct Programming Equations." Illegal conditions cannot be generated as long as the correct value from Table 23, "Direct Programming Reference Divider Values," is used.
- M/N can be used with any REFCLK frequency from 2 MHz through 100 MHz
- 4. A given pixel clock can be generated with multiple combinations of programming values. Some of these values can produce illegal internal conditions. Table 21, "PLL Equations," is used to calculate the resulting pixel clock and to determine if conditions are violated.

If the incoming REFCLK does not meet the requirements for direct programming, then M/N programming must be used for both PLLs.

If REFCLK is suitable for direct programming, then the programming style for the SYSCLK PLL is generally a matter of convenience.

For the pixel PLL, the use of preprogrammed frequencies, and the number required, 8 or 16, can affect the choice of programming styles.

However, the register selection specified with the EXT/INT bits of the Pixel PLL Control 1 register does not necessarily force the selection of programming style, direct or M/N. For example, there is nothing to prevent an arbitrary value from being written into the Fixed Pixel PLL Reference Divider and writing an appropriate value into one of the F0 - F15 registers as calculated with the M/N method. Of course, if multiple "N" values are used and they have to be re-written to the Fixed Pixel PLL Reference Divider every time the FS[3:0] value changes, this defeats the purpose of the FS[3:0] selection mechanism.

Likewise, when the 1-of-8 M/N register selection is used there is nothing to prevent using the direct programming equations from being used for the values. The same value will wind up being used for all of the "N" values.

#### C.6 Start-up Values

As mentioned previously when the RGB526/RGB526DB is reset the PLLs are initialized for "old" style programming.

The System PLL VCO Divider (index 0x0016) is reset to 0x41. This yields a DF value of '01', and a VCO DIV COUNT value of decimal 1.

The System PLL Reference Divider (index 0x0015) is reset to 0x08. This gives a REF DIV COUNT of decimal 8.

Using the equation in Table 21, "PLL Equations," for DF = 01, the SYSCLK frequency will be REFCLK times:

$$(1+65)/(8\times 4)=66/32=33/16$$

The F0 and F1 (indices 0x0020 and 0x0021) hold the VCO Divider values for the Pixel PLL. F0 is initialized to 0x05, for a DF value of 00 and a VCO DIV COUNT of decimal 5. F1 is initialized to 0x0e, for a DF value of 00 and a VCO DIV COUNT of decimal 14.

The Fixed Pixel PLL Reference Divider (index 0x0014) is initialized to 0x05, for a REF DIV COUNT of decimal 5.

Using the equation in Table 21 for DF = 00, the F0 frequency will be REFCLK times:

$$(5+65)/(5\times8) = 70/40 = 7/4$$

and the F1 frequency will be REFCLK times:

$$(14 + 65)/(5 \times 8) = 79/40$$

#### D.0 Switching Into VGA Mode

The RGB526/RGB526DB has two fundamental modes of operation which depend on the input pixel port selected, VGA or VRAM. The port is selected with the "PORT SEL" bit (bit 0) of Miscellaneous Control 2 register.

On the RGB513, RGB514, and RGB525 products, there are two problems that can occur when switching from the VRAM port back to the VGA port. Internally latched data from the previously selected VRAM port can corrupt the VGA data, and the SCLK can stop running momentarily. Both of these problems can be circumvented with a software work-around.

For software compatibility with the RGB513, RGB514, and RGB525 it is recommended that this software workaround also be incorporated in the software used with the RGB526/RGB526DB. The RGB526/RGB526DB does not require this software modification, but it does continue to operate correctly (that is, the software patch is transparent to the RGB526/RGB526DB.)

The software modification is as follows:

When doing a "mode switch" into VGA mode, the following additional steps should be taken:

- Set bits 1 and 0 to '1's in VRAM Mask Low register, to mask off the lowest VRAM byte. The remaining VRAM Mask bits are "don't care".
- 2. Set bit 6 (VMSK CNTL) in Miscellaneous Control 1 register to '1', to enable the VRAM MASKing.
- Make sure at least one SCLK occurs. This means setting up the chip for VRAM pixel data operation. In particular, make sure that the Pixel Format register is set to one of the valid formats (4 BPP...32 BPP). A valid pixel format must be set or SCLK will not run.
- 4. At this point the low byte of the internal VRAM pixel data should be '0's, and will not interfere with the VGA data.

The VGA Port can now be selected. A two step process is required:

- 1. Write to the Miscellaneous Control 2 register. Set bit 0 (PORT SEL) to '0' for VGA, but write bits 7 and 6 as '01' (PCLK SEL = Internal PLL.)
- Do a second write to the Miscellaneous Control 2
  register. Again, set bit 0 (PORT SEL) to '0' for VGA.
  But now set bits 7 and 6 to '00' (PCLK SEL =
  LCLK.) The VGA port is now selected.

When doing a mode switch back to VRAM port operation, make sure that bit 6 (VMSK CNTL) in Miscellaneous Control 1 register is set back to '0', to disable the VRAM MASKing.



© International Business Machines Corporation 1995 Printed in the United States of America 9-95

All Rights Reserved

- ® IBM and the IBM logo are registered trademarks of the IBM Corporation.
- ™ The following terms are trademarks of the IBM Corporation: IBM Microelectronics, RGB513, RGB514, RGB524, RGB525, RGB526, RGB526DB, RGB528, RGB624.

The information provided is believed to be accurate and reliable. IBM reserves the right to make changes to the product described without notice. No liability is assumed as a result of its use nor for any infringement of the rights of others.

IBM Microelectronics Division 1580 Route 52, Bldg. 504 Hopewell Junction, NY 12533-6531

The IBM home page can be found at http://www.ibm.com.

The IBM Microelectronics Division home page can be found at

http://www.chips.ibm.com.

Fast Fax Service 415-885-4121