

## 82C480 8514/A-COMPATIBLE GRAPHICS CONTROLLER

- Fully Compatible with IBM® 8514/A at both register and software ('Adapter Interface' or AI) level
- Runs Windows and Presentation Manager for the 8514/A without special drivers
- Single Chip Solution: 160-Pin Plastic Flatpack
- Integrated Micro Channel, Industry Standard Architecture, and EISA Bus Interfaces
- Autoconfigurable for 8-bit or 16-bit System Interface
- Demultiplexed bus interface resulting in lower chip count. Total of 9 chips required for a complete 8514/A implementation including memory:
  - 1 82C480 Graphics Controller
  - 1 74LS245 Bus Transceiver
  - 1 RAMDAC
  - 1 LM339 Comparator
  - 4 256Kx4 VRÂMs (+4 for 256 colors)
  - 1 82B484 Support Chip
  - +1 EPROM (optional)

## Supports both 256K and 1M VRAMs

|                    | 16<br>256K | 32<br>256K | 4<br>1M | 8<br>1M |
|--------------------|------------|------------|---------|---------|
| 640x480x16-color   | х          | х          | х       | х       |
| 640x480x256-color  | х          | X          | X       | X       |
| 1024x768x16-color  | X          | X          | X       | X       |
| 1024x768x256-color |            | X          |         | X       |

- Hardware Graphics Functions:
  - Bit Blt Polygon Fill - Line Draw - Pattern Fill
  - Color Mixing Scissoring
- External palette DAC support for up to 16 million colors (Autoconfigurable for 6-bit or 8-bit RAMDACs)
- Resolutions supported up to 2540x2048 (either interlaced or non-interlaced) with video rates up to 300 MHz
- Software transparent 1024x768 non-interlaced monitor support
- Low-Power CMOS process



82C480 System Block Diagram

Revision 1.6 Preliminary 82C480



# **Revision History**

| Revision | <u>Date</u> | <u>By</u> | Comment                                                                                                                                           |
|----------|-------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.3      | 5/20/90     | DR        | Document updated to reflect Rev.1 silicon (internal use only) - Register definition added - VESA register and bitfield naming scheme incorporated |
| 1.4      | 6/13/90     | ST        | Change document format to Chips Standard Data Sheet Format                                                                                        |
| 1.5      | 7/11/90     | DR        | Document updated to reflect Rev. 2 silicon                                                                                                        |



## **Table of Contents**

| Section                                 | Page Page | <u>Section</u>                            | Page     |
|-----------------------------------------|-----------|-------------------------------------------|----------|
| Introduction                            | 1         | Pixel Operations                          | 70       |
| Bus Interface                           | 5         | Mixes                                     | 70       |
| ROM Interface                           | 6         | Source Operand Selection                  | 70       |
| VRAM Interface                          | 6         |                                           |          |
|                                         | -         | Foreground and Background                 | 70       |
| Extension Registers                     | 6         | Foreground Select Mode                    | 72       |
| External Color Palette                  | 6         | Color Comparison                          | 72       |
| Performance                             | 6         | Plane Masks                               |          |
| Monitor Support                         | 6         | Across Planes vs. Through Planes          | 74       |
| Line Draw                               | 6         | Scratch Register                          | 75       |
| Text and Alphanumeric Support           | 7         | · ·                                       |          |
| Video Subsystem Total Chip Count        | 7         | Drawing Operations                        | 76       |
| Package                                 | 7         | Diamag operations                         | , 0      |
| 92C490 System Diagrams                  | 7         | Line                                      | 76       |
| 82C480 System Diagrams                  | ,         | SSV Drawing                               | 76       |
| D' .                                    | •         | Copy Rectangle                            | 78       |
| Pinouts                                 | 8         | Fast Rectangle                            | 78       |
|                                         |           | V Doctorale                               | 70       |
| Pin Diagram                             | 8         | X Rectangle                               | 78       |
|                                         | •         | Y Rectangle                               | 79       |
| Pin Descriptions - System Bus Interface | 9         | Polygon Fill                              | 79       |
| Pin Descriptions - Display Memory       | 14        | Text Modes                                | 79       |
| Pin Descriptions - Clocks               | 16        |                                           |          |
| Pin Descriptions - Test, Power & Ground | 18        | Application Schematic Examples            | 81       |
| Register and Port Address Summaries     | 19        | IntroductionISA Bus Circuit Example       | 81<br>82 |
| m . t m. a                              | ••        | Micro Channel Bus Circuit Example         | 83       |
| Register Bit Summary                    | 20        | VRAM Memory Configuration A               | 84       |
|                                         |           | VRAM Memory Configuration B               | 85       |
| Functional Description                  | 57        |                                           |          |
|                                         |           | Video Circuit (IMSG176/178) Color Palette | 86       |
| System Interface                        |           | Video Circuit (BT471/478) Color Palette   | 87       |
| Micro Channel Interface                 | 57        |                                           |          |
| ISA Interface                           | 57        | Electrical Specifications                 | 89       |
| Queue                                   | 58        |                                           |          |
| Interrupts                              | 58        | Absolute Maximum Conditions               | 89       |
| Memory Interface                        | 60        | Operating Conditions                      | 89       |
| Memory Architecture                     | 60        | DC Characteristics                        | 89       |
| Mamore Configurations                   |           | AC Characteristics                        | 90       |
| Memory Configurations                   | 61        | Nugget Clock Timing                       |          |
| RAM Cycle Types                         | 62        | Reset Timing                              |          |
| Video Interface                         | 64        | ICA Due Timing                            | 01       |
| Horizontal Timing                       | 64        | ISA Bus Timing                            | 91       |
| Vertical Timing                         | 64        | MCA Bus Timing                            |          |
| Refresh Counter                         | 66        | VRAM Timing                               |          |
| Serial Bus                              | 66        | Switching Characteristics                 |          |
| Alternate Video Registers               |           | Timing Requirements                       | 99       |
| Initialization/Configuration            | 67        | Video Timing                              |          |
| Initialization/Configuration            | 68        |                                           |          |
| Reset                                   | 68        | Video Register Parameters                 | 107      |
| POS Operation                           | 68        | TIGO REGISCH LAMMENTS                     | 107      |
| Configuration Options                   | 68        | Machanical Spacifications                 | 100      |



## List of Figures and Tables

| Figure                           | Page                                                                                                                                   | <u>Table</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Page                                                                                                          |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| System Diagram                   | 1                                                                                                                                      | VRAM 256K Resolution Support                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1                                                                                                             |
| VGA/8514 Pass-Through Interface  | 5                                                                                                                                      | Relative Performance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 6                                                                                                             |
| 82C452 Pinouts                   | 8                                                                                                                                      | Minimum Video Subsystem Chip Count                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 7                                                                                                             |
| Mix Select Pixel Drawing Engine  | 71<br>73<br>77<br>82<br>83<br>84<br>85<br>86<br>87<br>90<br>92<br>93<br>94<br>95<br>97<br>98<br>101<br>102<br>103<br>104<br>105<br>106 | Minimum Video Subsystem Chip Count  82C480 Pin Usage  16-bit Byte Steering Bus Cycle Type Monitor ID Type MCLK Frequency vs. VRAM Speed Clock Frequency Select  82C480 Registers Bit Summary Horizontal Sync Polarities Vertical Sync Polarities IBM 8514/A Standard ROM Address Map MCA IBM 8514/A vs. 480 ROM Map VGA ROM Map Mix Background Selection Foreground Mix Selection Foreground Mix Selection  Bus Signal Connections Memory Configurations & Resolutions Sync Polarities vs. Resolution Scan Modulus Alternate Register Selects Alternate Register Enable VRAM Interleave | 7<br>10<br>11<br>13<br>16<br>16<br>19<br>20<br>25<br>27<br>31<br>35<br>48<br>49<br>57<br>61<br>64<br>65<br>67 |
| 82C480 Mechanical Specifications | 109                                                                                                                                    | ROM Base Address Mix Selection Color Compare Operation Fill Boundary Mask  Absolute Maximum Conditions. Normal Operating Conditions. DC Characteristics. AC Characteristics - Nugget Clock Timing. AC Characteristics - Reset Timing. AC Characteristics - ISA Bus Timing. AC Characteristics - MCA Bus Timing. AC Characteristics - VRAM Timing. AC Characteristics - VRAM Timing. AC Characteristics - Video Timing.  Video Register Parameters                                                                                                                                       | 69<br>70<br>74<br>74<br>89<br>89<br>90<br>90<br>91<br>96<br>99                                                |



## Introduction

The 82C480 is a 100% register-level IBM 8514/A compatible controller. The 82C480 provides memory interface logic, video control logic, and interface logic to the ISA (PC/AT<sup>TM</sup>) Bus, EISA Bus, and Micro Channel (MCA).

With 512 KBytes of display memory, the 82C480 supports 16 and 256 displayable colors in 640x480 resolution and 16 with 1024x768 resolution. With 1Mbyte of display memory, it supports 256 displayable colors with 1024x768 resolution. An external RAMDAC supports 256K (6-bit DAC) or 16 million (8-bit DAC) total colors.

The 82C480 supports the following modes selectable via software:

- VGA mode (pass through video from VGA subsystem)
- Advanced Function mode (8514/A 1024x768 or 640x480)

The 82C480 defaults to VGA mode on reset. In the Advanced Function mode, the 82C480 supports 640x480 or 1024x768 resolution as well as providing more complex hardware functions such as BitBlt, line drawing, polygon fill, patterns, raster operations, and scissoring (post-clipping).

Software support for the 82C480 is provided via the Chips and Technologies Adapter Interface (AI) and drivers for major software applications. Any software which supports the IBM 8514/A will also support a compatible 82C480 implementation.

The 82C480 is supplied in a 160-pin PFP package.

#### **Bus Interface**

The 82C480 allows selection of either ISA (PC/AT) or MCA (Micro Channel) Bus Interface by detecting a strapping option during reset. All control signals



Revision 1.6 5 Preliminary 82C480



for both interface types are integrated onto the single 8514/A-compatible chip.

The 82C480 supports both 8-bit and 16-bit CPU interfaces.

#### **ROM Interface**

The 82C480 supports an optional 8-bit ROM for Power-On-Self-Test (POST) code which may be implemented in AT-bus systems without using additional external components except the ROM chip. The ROM address is decoded and the ROMCS/ pin is asserted to enable ROM data onto the data bus. A 16-bit ROM may be implemented with two ROM chips and one additional external PAL.

Video initialization code and support functions may be included in the POST ROM, incorporated into the system BIOS, loaded from disk at system initialization as a TSR, or incorporated directly into drivers.

### **VRAM Interface**

Like the IBM 8514/A, the 82C480 supports 256K (64Kx4) VRAMs. In addition, the 82C480 also supports 1M (256Kx4) VRAMs, allowing a lower cost, lower chip-count 8514/A implementation. The 82C480 supports a faster memory clock (40 MHz) to maximize use of VRAM bandwidth.

The 82C480 supports five memory cycle types:

- 1. Read (page mode)
- 2. Write (page mode)
- 3. Read-Modify-Write (page mode)
- 4. RAS-only refresh
- 5. Data Transfer Cycle

### **Extensions and Extended Registers**

The 82C480 chip provides enhanced modes of operation which are not available on the IBM 8514/A. These extended features are controlled via bits in extension registers.

The 82C480 has extended the 8514/A architecture to make virtually all of the registers readable. This improves the testability of the chip and makes state saving easy to accomplish.

#### **External Color Palette**

The 82C480 supports the programming of an external color palette DAC (RAMDAC) by decoding the CPU addresses and generating the read and write signals for the external palette.

Normally, each RAMDAC analog output provides 6-bit resolution (64 shades of color on each of the analog R, G, and B outputs). However, a pin is provided by the 82C480 for selecting 8-bit-per-color mode for the DAC (e.g., if using an INMOS IMSG-178 or BT478) which provides 256 shades of color on each RGB output. If this capability is not required, the 8BITDAC pin may instead be used as a general purpose output.

#### Performance

The 82C480 provides up to 2 times the performance of the IBM 8514/A hardware. Projected performance for major graphics operations are listed below (Mp/s = million pixels per second):

| Function            | 82C480    | 8514/A   | Relative<br>Performance |
|---------------------|-----------|----------|-------------------------|
| Clear<br>Horizontal | 28.6 ms   | 33.3 ms  | 1.2x                    |
| Solid Line          | 14.8 Mp/s | 7.3 Mp/s | 2.0x                    |
| Vertical Line       | 3.7 Mp/s  | 2.9 Mp/s |                         |
| BitBlt              | 14.8 Mp/s | 9.6 Mp/s | 1.5x                    |

### Bit-Block Transfer (BITBLT)

The 82C480 uses an internal 32/40 pixel register file for BitBlts (8 words x 32/40 bits). This allows reading a block of pixels in page mode, then writing them using page mode RMW cycles. The 82C480 has a 32/40-bit internal data path, and its faster clock rate results in faster BitBlt performance.

#### Monitor Support

The 82C480 supports the following analog monitors:

- IBM Monochrome Display 8503 or compatible
- IBM High Resolution Monochrome Display 8507 or compatible
- IBM Color Display 8512 or compatible
- IBM Color Display 8513 or compatible
- Interlaced monitors supporting high resolution (IBM 8514, 8515, or compatible)
- Multisync and compatible monitors
- Any interlaced or non-interlaced monitor with a resolution of up to 2560x2048 and supporting video rates of up to 300 MHz

#### Line Draw

Line draw functions (straight lines only) are handled in hardware by the 82C480 chip. Arcs, circles, and



other higher-level shapes must be decomposed to a series of short straight-line segments. The 82C480 uses the Bresenham algorithm for line drawing.

### **Text and Alphanumeric Support**

The 82C480 chip (like the 8514/A) does not support a separate text mode in hardware. Text display is supported via graphics modes, so text may be any size.

The AI supports 3 standard text modes at 1024x768 resolution:

- Mode 0: 85x38 (12x20 character cell)
- Mode 2: 128x54 (8x14 character cell)
- Mode 3: 146x51 (7x15 character cell)

The AI also supports an 80x34 text mode (mode 1) at 640x480 resolution (8x14 character cell).

### Video Subsystem Total Chip Count

Using the 82C480, a complete 8514/A-compatible 8-bit video subsystem can be built with just 9 ICs (10 ICs for a 16-bit system), including display memory, as shown in the table below:

### Qty Chip Type

- 1 82C480 Graphics Controller Chip
- 1 74LS245 Transceiver (2 for 16-bit interface)
- 1 IMSG176-65 RAMDAC
- 1 LM339 Comparator
- 4 256Kx4 VRAM (120 ns) (+4 for 8 planes)
- 1 82B484 Support Chip
- 9 Total
- +1 27256 POST ROM (optional)

Additional components required would be 25.175, 32.5, 44.900 and 65.000 MHz oscillators, 15-pin video connector, LM334 Current reference, 1N4148 diode, and various resistors and capacitors. The indicated configuration (4 256K x 4 VRAM's) supports 640x480 non-interlaced (25.175 MHz.) 16-color and 256-color modes and 1024x768 interlaced (44.900 MHz.) and non-interlaced (65.000 MHz.) 16-color mode.

Adding 256-color support for 1024x768 would require four additional 256Kx4 VRAM chips (for a total of 8 256K x 4 VRAM's).

If a 'Power-On-Self-Test' (POST) ROM is implemented in a Micro Channel bus configuration, two additional 8-bit address latches (74LS373 or equivalent) are also required.

### **Package**

The 82C480 is available in a 160-pin plastic flat pack (PFP).

Complete descriptions of all 82C480 pins are included in this document starting on the next page. The pins are separated into the following logical groups for discussion: Bus Interface, Display memory, Video, Clock, Power, and Ground.

| 82C480 Pin Usage Summary |    |  |  |  |  |
|--------------------------|----|--|--|--|--|
| Bus Interface:           | 60 |  |  |  |  |
| Display Memory:          | 61 |  |  |  |  |
| Video:                   | 9  |  |  |  |  |
| Clock:                   | 6  |  |  |  |  |
| Test:                    | 3  |  |  |  |  |
| Power:                   | 7  |  |  |  |  |
| Ground:                  | 14 |  |  |  |  |

Total: 160

### 82C480 System Diagrams

Included at the end of this document are schematic examples of the following:

- 1. 8/16-bit ISA (PC/AT) Bus Interface 16-bit Micro Channel (MCA) Bus Interface
- Memory Interfacing (40-bit Configuration A) Memory Interfacing (80-bit Configuration B)
- 3. Video/Clock Logic (82B484 IMSG176/8) Video/Clock Logic (82B484 - BT471/8)



## 82C480 Pinouts



Revision 1.6 8 Preliminary 82C480



### **System Bus Interface**

| Pin#     | Pin Name   | Ту       | ype        | Active       | Description                                                                                                                                                      |
|----------|------------|----------|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23       | D15        |          | /O         | High         | System Upper Data Bus                                                                                                                                            |
| 24       | D14        | Ţ,       | <b>/O</b>  | High         | All by a secondary is down intermelled so the 92C490 may                                                                                                         |
| 25       | D13        | 1/       | /O<br>/O   | High<br>High | All byte steering is done internally, so the 82C480 may be used without data transceivers in motherboard                                                         |
| 26<br>27 | D12<br>D11 |          | /O<br>/O   | High         | applications; 74LS245 or equivalent transceivers are                                                                                                             |
| 28       | D11<br>D10 |          | /O         | High         | recommended for adapter cards to meet the 24 mA drive                                                                                                            |
| 29<br>29 | D10<br>D9  |          | ίδ         | High         | requirement.                                                                                                                                                     |
| 30       | D8         |          | VÕ         | High         |                                                                                                                                                                  |
| 32       | D7         | I,       | (/O        | High         | System Lower Data Bus                                                                                                                                            |
| 33       | D6         |          | (O)        | High         |                                                                                                                                                                  |
| 34       | D5         |          | <b>/O</b>  | High         |                                                                                                                                                                  |
| 35       | D4         |          | (O         | High         |                                                                                                                                                                  |
| 36       | D3         |          | (O)        | High         |                                                                                                                                                                  |
| 37       | D2         | I,<br>T  | (/O<br>(V) | High<br>High |                                                                                                                                                                  |
| 38<br>39 | D1<br>D0   |          | OVI        | High         |                                                                                                                                                                  |
| 70       | A23        |          | In         | High         | System Address Bus (latched internally for the MCA                                                                                                               |
| 69       | A22        |          | In         | High         | bus on the falling edge of CMD/)                                                                                                                                 |
| 68       | A21        |          | In         | High         |                                                                                                                                                                  |
| 67       | A20        |          | In         | High         | In MCA designs, connect A23:0 to A23:0. In ISA                                                                                                                   |
| 66       | A19        |          | In         | High         | (PC/AT) Bus designs, connect A19:0 to SA19:0 and                                                                                                                 |
| 65       | A18        |          | In         | High         | A23:20 to ground.                                                                                                                                                |
| 64       | A17        |          | In         | High         | In MCA designs, A14:0 must be latched externally by                                                                                                              |
| 63       | A16        |          | In<br>In   | High<br>High | ADL/ or CMD/ for the ROM. In ISA bus designs, the                                                                                                                |
| 61<br>60 | A15<br>A14 |          | In         | High         | address inputs need not be latched.                                                                                                                              |
| 59       | A13        |          | In         | High         | address inputs need not be faterious.                                                                                                                            |
| 58       | A12        |          | In         | High         |                                                                                                                                                                  |
| 57       | A11        |          | In         | High         |                                                                                                                                                                  |
| 56       | A10        | •        | In         | High         |                                                                                                                                                                  |
| 55       | A9         |          | In         | High         |                                                                                                                                                                  |
| 54       | A8         |          | In         | High         |                                                                                                                                                                  |
| 53       | A7         |          | In         | High         |                                                                                                                                                                  |
| 52       | A6         |          | In         | High         |                                                                                                                                                                  |
| 51<br>50 | A5<br>A4   |          | In<br>In   | High<br>High |                                                                                                                                                                  |
| 50<br>49 | A4<br>A3   |          | In         | High         |                                                                                                                                                                  |
| 48       | A3<br>A2   |          | In         | High         |                                                                                                                                                                  |
| 47       | A1         |          | In         | High         |                                                                                                                                                                  |
| 46       | A0         |          | In         | High         |                                                                                                                                                                  |
| 72       | ISA/       | [SETUP/] | In         | Low          | The primary function of this pin is to indicate whether the 82C480 should be configured for the MCA or ISA (PC/AT) bus interface. This pin may be tied to ground |

(PC/AT) bus interface. This pin may be tied to ground or RESOUT/ in ISA Bus configurations. The MCA interface also drives this pin to select the 82C480 during POS (if low, the POS registers at 100-102h are not accessible and all others are if the enable bit in register 102h is set).



System Bus Interface

| Pin#     | Pin Name       |                                       | Туре           | Active     | Description                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------|----------------|---------------------------------------|----------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15       | RESET          |                                       | In             | High       | RESET=1 resets the 82C480 and tristates all output pins except RESOUT/. Also puts internal counters in a known state for chip test.                                                                                                                                                                                                                                                                            |
| 78       | RESOUT/        |                                       | Tri-O          | Low        | RESOUT/ is an inverted and delayed RESET. It is used to enable any external tristate buffers required to drive programming options on the 82C480 pins; these options are latched on the falling edge of RESET. RESOUT/ is guaranteed to stay low long enough to meet the hold time requirement from RESET for any programming option. Some options, such as on the MA8 pin, may be driven by RESOUT/ directly. |
| 13       | ВНЕ/           |                                       | In             | Low        | Byte High Enable. Low indicates that the high order byte at the current word address is being accessed. Along with A0, indicates which bytes are transferred over the bus (all byte steering is done internally):  BHE/ A0 Effect                                                                                                                                                                              |
|          |                |                                       |                |            | 0 0 Both bytes on D15:0 (16-bit slot only) 0 1 High byte on D15:8 (16-bit slot only) 1 0 Low byte on D7:0 (8- or 16-bit slot) 1 1 High byte on D7:0 (8-bit slot only)                                                                                                                                                                                                                                          |
|          |                |                                       |                |            | The 82C480 configures itself to 8- or 16-bit slots. BHE/ is located on the 16-bit bus extension in PC/AT systems, so BHE/ has an internal pullup to hold it inactive in case the card is installed in an 8-bit slot.                                                                                                                                                                                           |
| 22<br>31 | RDHI/<br>RDLO/ | · · · · · · · · · · · · · · · · · · · | Tri-O<br>Tri-O | Low<br>Low | Direction control for high and low external data bus transceivers. These outputs are tristate when RESET is active, so have internal pullups to prevent driving the bus.                                                                                                                                                                                                                                       |
|          | -              |                                       |                |            | 0 = Read data from 82C480<br>1 = Write data into 82C480                                                                                                                                                                                                                                                                                                                                                        |
| 71       | MEMW/          | [MADE24]                              | In             | Both       | In ISA (PC/AT) bus interface, currently unused, but should be connected to SMEMW/ for compatibility with future products. In MCA interface, MADE24=1 indicates only 24 bits of address are being decoded; the 82C480 will not respond to any cycle in MCA mode unless this pin is high. MADE24 may also be used as an active-high chip select to decode 32-bit addresses.                                      |



## System Bus Interface

| Pin# | Pin Name |        | Туре  | Active | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|----------|--------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17   | MEMR/    | [CMD/] | In    | Low    | In MCA, indicates a command cycle (valid data on the bus). Driven by CMD/ from MCA, VGACMD/ from CHIPS/250. In ISA bus, indicates a memory read cycle.                                                                                                                                                                                                                                                                                                                         |
| 19   | IOWR/    | [S0/]  | In    | Low    | In ISA (PC/AT) bus interface, indicates an I/O Write cycle. In MCA bus interfaces, indicates Status bit 0 (S0/).                                                                                                                                                                                                                                                                                                                                                               |
| 18   | IORD/    | [S1/]  | In    | Low    | In ISA (PC/AT) bus interface, indicates an I/O Read cycle. In MCA bus interfaces, indicates Status bit 1 (S1/).                                                                                                                                                                                                                                                                                                                                                                |
| 16   | AEN      | [MIO/] | In    | Both   | In ISA (PC/AT) bus interface, defines valid I/O address: 0 = valid I/O address, 1 = Invalid I/O address (DMA cycle). If single-cycle DMA is used, memory addresses will be on the bus at the same time that IORD/ or IOWR/ is active. The 82C480 will not respond to IORD/ or IOWR/ while AEN=1. In MCA bus interface, indicates memory or I/O cycle: 1 = memory cycle, 0 = I/O cycle.  MIO/ S1/ S0/ Cycle Type                                                                |
|      |          |        |       |        | 0 0 0 -reserved- 0 0 1 I/O Read 0 1 0 I/O Write 0 1 1 -reserved- 1 0 0 -reserved- 1 0 1 Memory Read 1 1 0 Memory Write (not used on 480) 1 1 1 -reserved-                                                                                                                                                                                                                                                                                                                      |
| 14   | RFSH/    |        | In    | Low    | Active low signal indicating Refresh cycle. When this pin is low, the chip is not accessible. This pin and MADE24 are effectively active-high chip selects.                                                                                                                                                                                                                                                                                                                    |
| 43   | RDY      |        | Tri-O | High   | Ready. Driven low to indicate that the current cycle should be extended with wait states. Driven high at the end of cycle to indicate 'ready', then tristated. This signal is normally tristated and is only driven low if the 82C480 cannot respond immediately to I/O requests (or when the ROM is addressed in MCA) to insert the necessary wait states. Another way to look at this pin is as an active-low wait-state request line, instead of an active-high ready line. |



## **System Bus Interface**

| Pin# | Pin Name |          | Туре  | Active | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|----------|----------|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 44   | MEM16/   | [CSFB/]  | Tri-O | Low    | In ISA (PC/AT) bus configurations, this pin is currently unused. It is reserved to indicate 16-bit memory cycle capability. For compatibility with future products, this pin should be connected to MEMCS16/ in ISA bus configurations. In MCA bus configurations, this pin is called 'Card Select Feedback'; it indicates any valid access to the 82C480. It is an unlatched decode of A23:0, MIO/, and MADE24.                                                                   |
| 12   | IOCS16/  | [DS16/]  | Tri-O | Low    | In ISA (PC/AT) bus interface, indicates 16-bit I/O cycle. In MCA Interface, indicates 16-bit Memory or I/O cycle. Asserted by the 82C480 to indicate that the chip is capable of transferring 16 bits over the bus at the requested address. In the MCA bus, DS16/ is active for all 82C480 accesses except those to the RAMDAC, POS, and ROM.                                                                                                                                     |
| 45   | IRQ      | [IRQ/]   | Tri-O | Both   | In the ISA (PC/AT) bus, this pin is tristated when interrupts are not enabled, low when interrupts are enabled but no interrupt is pending, and high when interrupts are enabled and an interrupt is pending. In the MCA bus, this pin functions as an active-low open-collector output. The interrupt request pin is normally connected to IRQ9. IRQ9/ may be shared by multiple controllers on the MCA bus; in the ISA bus, only one controller at a time may have IRQ9 enabled. |
|      |          |          |       |        | This pin has high drive capability (IOL = -16mA). While this is still not enough to meet the MCA bus specification of 24mA, the board designer may still want to connect IRQ/ directly to the bus, eliminating the need for a 74LS125 driver.                                                                                                                                                                                                                                      |
| 77   | ROMCS/   | [POSEN/] | I/O   | Low    | In ISA (PC/AT) bus configurations, this pin indicates access to ROM space. In MCA configurations, this pin indicates access to ROM space or to the POS ID registers (I/O address 100-101h and SETUP/ active). In 82C480-based designs with ROM, the POS registers map into the ROM. In systems without ROM, the same information may be provided from external TTL drivers activated by A0 and POSEN/.                                                                             |

Note: Since ROMCS/ is in input mode during reset, an internal pullup resistor ensures the ROM is held in a quiescent state.



**System Bus Interface** 

| Pin#           | Pin Name                                                                                                                                                                                         | Туре       | Active               | Descrip                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | tion                                 |                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 76<br>74<br>75 | ROMPG2 (MS2)<br>ROMPG1 (MS1)<br>ROMPG0 (MS0)                                                                                                                                                     | I/O<br>I/O | High<br>High<br>High | ROM Page (ROM Address msb) outputs / Monitor II inputs. During reset, these pins are inputs sampled of the falling edge of RESET (these pins have internal 50 pullups) to latch the state of the Monitor ID input (MS2:0) from the video connector, which may then be read from the Subsystem Status register. If a ROM is connected to ROMPG2:0, MS2:0 are normally drived onto these pins with a tri-state buffer enabled by RESOUT/. However, if P4D6 is low at the falling edge of RESET, these pins remain inputs so MS2:0 may be connected to these pins directly. If P4D6 is high at the falling edge of RESET, these pins then become output driven by ROM_PAGE_SEL[2:0]. If ROM paging capability is desired, these pins connect to ROM address inputs A14:12 (32K) or A12:10 (8K). |                                      |                                      | t, these pins are inputs sampled on ESET (these pins have internal 50K he state of the Monitor ID inputs ideo connector, which may then be system Status register. If a ROM is PG2:0, MS2:0 are normally driven ith a tri-state buffer enabled by er, if P4D6 is low at the falling edge has remain inputs so MS2:0 may be bins directly. If P4D6 is high at the ET, these pins then become outputs AGE_SEL[2:0]. If ROM paging these pins connect to ROM address |
|                |                                                                                                                                                                                                  |            |                      | MS2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | MS1                                  | MS0                                  | Monitor Type                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Note:          | The ROMPG2:0 outputs are force high during SETUP mode, indept dent of the ROM Page register contents.  ROM_PG_SEL [2:0] register bit set to 1 on RESET, so that the page defaults to ROM page 7. | ts are     |                      | 0<br>0<br>0<br>0<br>1<br>1<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0<br>0<br>1<br>1<br>0<br>0<br>1<br>1 | 0<br>1<br>0<br>1<br>0<br>1<br>0<br>1 | reserved<br>8507 (Mono) (31.5/35.5 KHz)<br>8514 (Color) (31.5/35.5 KHz)<br>reserved<br>reserved<br>8503 (Mono) (31.5 KHz)<br>8512/13 (Color) (31.5 KHz)<br>reserved                                                                                                                                                                                                                                                                                               |

Note: In MCA systems, address bits A11:0 must be latched for the ROM. Addresses may be latched by 74LS373 or equivalent transparent latches on the falling edge of CMD/ or by 74LS374 or equivalent registers on the rising edge of ADL/. In ISA systems, ROM addresses A11:0 are held valid during the entire bus cycle and need not be latched.

Note: In MCA systems, A1:0 may be connected directly to the RAMDAC. IMSG176 or equivalent RAMDACs latch their register select inputs internally on the leading edge of PALRD/ or PALWR/ and the MCA bus holds addresses valid long enough to meet hold time requirements. If addresses are latched for a ROM however, use the latched address hence minimizing the bus signal fanout.



## Display Memory Interface

| Pin#    | Pin Name     |              | Туре       | Active       | Description                                                                                                 |
|---------|--------------|--------------|------------|--------------|-------------------------------------------------------------------------------------------------------------|
| 118     | P4D7         | (8PLANE)     | I/O        | High         | VRAM Data Bus. The first digit in the signal name in-                                                       |
| 119     | P4D6         | (ROM PAGING) | I/O        | High         | dicates the position of the pixel within the 'nugget'.                                                      |
| 123     | P4D5         | (ROMSIZE)    | ĬΟ         | High         | The second indicates the bit position ('plane') within the                                                  |
| 124     | P4D4         | (ROMBASÉ1)   | Ϊ/O        | High         | pixel                                                                                                       |
| 125     | P4D3         | (ROMBASEO)   | Í/O        | High         | •                                                                                                           |
| 126     | P4D2         | (reserved)   | Ϊ⁄Ο        | High         | For horizontal resolutions of 1024 or less, four-pixel                                                      |
| 127     | P4D1         | (reserved)   | ΪΟ         | High         | nuggets may be used and the minimum number of                                                               |
| 128     | P4D0         | (reserved)   | Ϊ⁄Ο        | High         | 256Kx4 VRAMs required is four (connected to P3:0Dn with P4Dn unconnected). For 1280 horizontal resolu-      |
| 130     | P3D7         |              | I/O        | High         | tion, the minimum number of 256Kx4 VRAMs required                                                           |
| 131     | P3D6         |              | Ĩ/Ŏ        | High         | becomes five (connected to P4:0Dn).                                                                         |
| 132     | P3D5         |              | Ĭ/O        | High         | The P4Dn pins are also used for hardware configuration                                                      |
| 133     | P3D4         |              | Ĭ/Ŏ        | High         | options. On the falling edge of RESET, the state of the                                                     |
| 134     | P3D3         |              | I/O        | High         | P4Dn pins are latched internally. These 8 bits contain                                                      |
| 135     | P3D2         |              | I/O        | High         | internal pull-ups which cause the options to default to                                                     |
| 136     | P3D2<br>P3D1 |              |            | High         | the correct values for 8514/A compatibility. An external                                                    |
| 137     | P3D0         |              | I/O<br>I/O | High<br>High | LS244 buffer (enabled by RESOUT/) may be used to drive non-default ('0') configuration values on any        |
| 1.40    | DADA         |              | 1/0        | TT: -1-      |                                                                                                             |
| 142     | P2D7         |              | ľO         | High         | subset of the P4Dn pins. The inputs of the buffer may                                                       |
| 143     | P2D6         |              | ľO         | High         | be strapped to ground or tied to jumpers for user-confi-                                                    |
| 144     | P2D5         |              | I/O        | High         | gurable options. Alternatively, P4Dn inputs may be                                                          |
| 145     | P2D4         |              | I/O        | High         | connected to 100Ω pulldown resistors in 32-bit pixel                                                        |
| 146     | P2D3         |              | I/O        | High         | data bus configurations. Software may write over any                                                        |
| 147     | P2D2         |              | I/O        | High         | configuration options latched from P4Dn which elimi-                                                        |
| 148     | P2D1         |              | ľO         | High         | nates the need for most strapping options.                                                                  |
| 149     | P2D0         |              | ľO         | High         | P4D7 is saved at reset as a read-only bit in Subsystem Status register (42E8) bit-7 (SUBSYS_STAT[7]). It is |
| 151     | P1D7         |              | I/O        | High         | also accessible (read/write) in Extended Configuration                                                      |
| 152     | P1D6         |              | ľO         | High         | register #2 (5AE8h) bit-7 (EC2[7]). It is interpreted as                                                    |
| 153     | P1D5         |              | Ϊ/O        | High         | the <b>8PLANE</b> ('8 Bit Planes') bit:                                                                     |
| 154     | P1D4         |              | Ĭ/O        | High         |                                                                                                             |
| 155     | P1D3         |              | ΪΟ         | High         | 0 = 4-Plane/16-color configuration                                                                          |
| 156     | P1D2         |              | Ϊ⁄Ŏ        | High         | 1 = 8-Plane/256-color configuration (default)                                                               |
| 157     | P1D1         |              | Ϊ⁄Ο        | High         | P4D6 is saved in EC2[6] as ROM Paging:                                                                      |
| 158     | P1D0         |              | Ĭ/Ŏ        | High         | 0 = ROMPG2:0 are input pins readable at                                                                     |
| 2       | D0D7         |              | T/O        | Uich         | SUBSYS_STAT[6:4] (Monitor Sense pins).                                                                      |
| 3       | POD7         |              | I/O        | High         | 1 = ROMPG2:0 output ROM_PAGE_SEL[2:0]                                                                       |
| 4       | P0D6         |              | I/O        | High         | (Monitor Sense bits are latched from ROMPG2:0                                                               |
| 5       | POD5         |              | I/O        | High         | on the falling edge of RESET only)                                                                          |
| 6       | POD4         |              | I/O        | High         |                                                                                                             |
| 7<br>8  | P0D3<br>P0D2 |              | I/O<br>I/O | High<br>High | P4D5 is saved in EC2[5] as ROM Size:                                                                        |
| 9<br>10 | P0D1<br>P0D0 |              | I/O<br>I/O | High<br>High | P4D5: 0=32K, 1=8K ROM space in system memory                                                                |
| 10      | 1000         |              | ų          | mgn          | P4D4:3 are saved in EC2[4:3] at reset. These are interpreted by hardware as <b>ROMBase</b> :                |
|         |              |              |            |              | P4D4:3 8K MCA 8K ISA 32K                                                                                    |
|         |              |              |            |              | 00 C8000h C6000h D0000h                                                                                     |
|         |              |              |            |              | 01 D8000h D8000h D8000h                                                                                     |
|         |              |              |            |              | 10 C0000h C0000h C0000h                                                                                     |
|         |              |              |            |              | 11 (default) C6000h C8000h C8000h                                                                           |
|         |              |              |            |              |                                                                                                             |

Revision 1.6 Preliminary 82C480



## Display Memory Interface

| Pin#                                                        | Pin Name                                                    |                      | Туре                                                               | Active                                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------|-------------------------------------------------------------|----------------------|--------------------------------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 116<br>115<br>114<br>113<br>112<br>111<br>110<br>109<br>108 | MA8<br>MA7<br>MA6<br>MA5<br>MA4<br>MA3<br>MA2<br>MA1<br>MA0 | (1MVRAM)             | I/O<br>Tri-O<br>Tri-O<br>Tri-O<br>Tri-O<br>Tri-O<br>Tri-O<br>Tri-O | High<br>High<br>High<br>High<br>High<br>High<br>High<br>High | VRAM Address. On the falling edge of RESET, the state of MA8 is latched into extension register EC2[10]. If 0, 256Kb VRAMs are being used (same as the 8514/A); if 1, 1Mb VRAMs are being used, and the 82C480 reinterprets VRTCFG register bits to maintain register compatibility with the 8514/A. MA8 (only) has an internal 50K pull-up resistor, so the default is 1. To select 256K VRAMs, drive MA8 with RESOUT/.                                                                                                                                                             |
| 106                                                         | RAS/                                                        |                      | Tri-O                                                              | Low                                                          | VRAM Row Address Strobe. An internal pullup keeps the VRAMs in a quiescent state during reset. During normal operation, RAS/ will be observed active (low) except when a RAS precharge cycle is necessary.                                                                                                                                                                                                                                                                                                                                                                           |
| 103<br>102<br>99<br>98                                      | CAS3/<br>CAS2/<br>CAS1/<br>CAS0/                            | (BANKS1)<br>(BANKS0) | I/O<br>I/O<br>Tri-O<br>Tri-O                                       | Low<br>Low<br>Low<br>Low                                     | VRAM Column Address Strobes for memory <u>banks</u> 0–3. CAS3:1/ are unused in single-bank configurations (such as the basic four 1M-VRAM minimum configuration). CAS3:2/ have internal pullups and are sampled at reset and saved in EC2[9:8] as the number of VRAM banks installed: 00=1, 01=2, and 11=4 banks.                                                                                                                                                                                                                                                                    |
| 117<br>129<br>138<br>150<br>2                               | WE4/<br>WE3/<br>WE2/<br>WE1/<br>WE0/                        | (5PN)                | I/O<br>Tri-O<br>Tri-O<br>Tri-O<br>Tri-O                            | Low<br>Low<br>Low<br>Low<br>Low                              | VRAM Write Enables for <u>pixels</u> 4:0 of the nugget, respectively. WE4/ is only used in 5-pixel nugget configurations (it is unused in 4-pixel nugget configurations, such as the basic four 1M-VRAM minimum configuration). WE4/ has an internal pullup and should be connected to RESOUT/ or GND to configure the 82C480 for 4-pixel nuggets. The state of WE4/ at reset (called the 5PN or '5-Pixel Nugget' bit) is saved in Extension Register EC2[11] (read/write) and in the Memory Control register MEM_CNTL[0] as part of the horizontal configuration (HORCFG) bitfield. |
| 105                                                         | DTOE/                                                       |                      | Tri-O                                                              | Low                                                          | Data Transfer / Output Enable for all VRAM chips                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 104                                                         | Reserved                                                    |                      | n/c                                                                | n/a                                                          | This pin is reserved for future use and should be left unconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |



Clocks

| Pin# | Pin Name | Pin Name Type Active |      | Description                |                                                                                                                        |  |  |  |
|------|----------|----------------------|------|----------------------------|------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 62   | MCLK     | In                   | High | CRT contro                 | ock. MCLK clocks everything except the ol logic (which uses NCLK). The MCLK is selected to match the speed of the RAMs |  |  |  |
|      |          |                      |      | MCLK                       | VRAM Speed                                                                                                             |  |  |  |
|      |          |                      |      | 25 MHz<br>32 MHz<br>40 MHz | 150 ns<br>120 ns<br>100 ns (Max MCLK frequency)                                                                        |  |  |  |
| 88   | NCLK     | In                   | High | Double Nug                 | gget Clock. Used to generate timing inside                                                                             |  |  |  |

Note: The NCLK frequency is 1/8 or 1/10 of the selected video clock frequency (depending on whether the memory array is configured for 4- or 5-pixel nuggets). CLKSEL2:0 are used to select the video clock from up to eight frequencies (see the CLKSEL selection table below). The selected video frequency is used to clock the external video shift registers and RAMDAC. 82C480 internal logic is clocked on the rising edge of NCLK. HSYNC is delayed by one half NCLK cycle and is clocked on the falling edge of NCLK.

| 95 | CSEL2 | (INTERLEAVE) | Tri-O | High |
|----|-------|--------------|-------|------|
| 96 | CSEL1 | (5PN)        | Tri-O | High |
| 97 | CSEL0 | (PS8)        | Tri-O | High |

Video Clock Select. If BLANK/=0 (blank active), used to select one of up to eight frequencies using external clock selection logic (only the first two frequencies are required for IBM 8514/A compatibility).

| 2 | SE<br>1 | L<br>0 | Frequency<br>Selected | Resolution     |                |
|---|---------|--------|-----------------------|----------------|----------------|
| 0 | 0       | 0      | 25.175 MHz            | 640x480        | non-interlaced |
| 0 | 0       | 1      | 44.900MHz             | 1024x768       | interlaced     |
| 0 | 1       | 0      | 65.000MHz             | 1024x768       | non-interlaced |
| 0 | 1       | 1      | 80.000MHz             | 1280x1024      | interlaced     |
| 1 | 0       | 0      | User-specified        | User-specified |                |
| 1 | 0       | 1      | User-specified        | User-specified |                |
| 1 | 1       | 0      | User-specified        | User-specified |                |
| 1 | 1       | 1      | User-specified        | User-specified |                |

Note: The selected frequency is used to clock the external video shift registers and RAMDAC. It is divided by eight or ten (depending on whether the memory array is configured for 4-pixel or 5-pixel nuggets) for input on NCLK. CLKSEL2:0 are controlled by EC3[10:8] (CLKSEL0 is duplicated in ADVFUNC\_CNTL[2]).

If BLANK/=1 (blank inactive), these pins output INTERLEAVE, 5PN (5-pixel nugget), and PS8 (Pseudo-8-plane mode) bits. 5PN is MEM\_CNTL[0]. PS8 mode is selected by setting VRTCFG=00 (MEM\_CNTL[3:2]) (normal setting is 01).

| 93 | AF | (BANK) | Tri-O | High | If BLANK/=0, indicates Advanced Function (ADVFUNC_CNTL[0]); 1=82C480 drives the video connector, 0=external logic (usually a VGA) drives the video connector. If BLANK/=1, indicates BANK, used by external logic to select which serial output enables (SOE3:0/) to activate for a particular scan line in 4-bank configurations: BANK=0 selects SOE1:0/; BANK=1 selects SOE3:2/. In two-bank configurations, BANK=0 selects SOE0/ and BANK=1 selects SOE1/. |
|----|----|--------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|----|----|--------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Revision 1.6 Preliminary 82C480



Test, Power, and Ground

| Pin#           | Pin Name                 | Туре                    | Active              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|--------------------------|-------------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 83             | PALRD/                   | Tri-O                   | Low                 | Connected to the Read input of the Palette DAC (IMSG176, BT471, or compatible). Asserted when the 82C480 is enabled and an I/O Read occurs from addresses 2EAh-2EDh. Tristate during reset. Internal 50K pullup.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 84             | PALWR/                   | Tri-O                   | Low                 | Connected to the Write input of the Palette DAC (IMSG176, BT471, or compatible). Asserted when the 82C480 is enabled and an I/O Write occurs to addresses 2EAh-2EDh (or 3C6h-3C9h in VGA pass-through mode). Tristate during reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 82             | 8BITDAC                  | I/O                     | High                | Used to control the '6/8-Bit-Analog-Output' pin of the Palette DAC (0=6-bit, 1=8-bit) if using an IMSG178, BT478, or compatible. This pin is sampled at reset, the state is loaded into EC2[13], then this pin becomes an output driven by EC2[13]. If EC2[13] is written by software, the chip attempts to drive the pin to the programmed level; if EC2[13] is read, the value read is the actual state of the pin, not the register bit. Thus this pin can be used to control the DAC output resolution (with default to either 6-bit or 8-bit operation depending on whether a 10K resistor is connected to the pin as a pullup or a pulldown). If it is desired to use a fixed size RAMDAC, this pin should be connected to ground via a $5.1\Omega$ (max) resistor for 6-bit or to +5V via a $5.1\Omega$ (max) resistor for 8-bit operation. (Automatic DAC Size Detection: Patent Pending) |
| 90<br>89<br>94 | HSYNC<br>VSYNC<br>BLANK/ | Tri-O<br>Tri-O<br>Tri-O | Both<br>Both<br>Low | Horizontal and Vertical Sync signals for the monitor and Blanking signal for the external palette DAC. Sync polarities are programmable. Tristated during reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 92<br>91       | VHSYNC<br>VVSYNC         | In<br>In                | Both<br>Both        | Horizontal and Vertical Sync signals from external VGA. When not in Advanced Function (AF) mode (i.e., 82C480 not enabled), these signals are used to drive the HSYNC and VSYNC outputs instead of the 82C480 H/V Sync.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 73             | SENSE                    | In                      | High                | Sense Input for analog output and monochrome/color monitor connection testing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

For compatibility, this pin should be connected to the outputs of an LM339 comparator. The comparator 'plus' inputs are connected to a 0.34V comparison voltage (corresponding to approximately half brightness) and the 'minus' inputs are connected to analog R, G, and B (maximum analog output voltage is 0.7V). If the R, G, or B output voltage is below the comparison voltage, the corresponding comparator output will be inactive (tristated/high); if above the comparison voltage, the comparator output will be driven low. Therefore, SENSE will be high if R, G, and B are all below half brightness. SENSE will be low if any one of R, G, or B is higher than half brightness. The SENSE input may be read via software as bit-0 of the Display Status register at 02E8h.



## Test, Power, and Ground

| Pin# | Pin Name       | Туре   | Active       | Description                                                                                              |  |  |  |  |  |
|------|----------------|--------|--------------|----------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 87   | Reserved       | n/c    | n/a          | This pin is reserved for future use and should be left unconnected for normal operation.                 |  |  |  |  |  |
| 85   | Reserved       | n/c    | n/a          | This pin is reserved for future use and should be left unconnected for normal operation.                 |  |  |  |  |  |
| 86   | Reserved (GND) | n/c    | n/a          | This pin is reserved for future use and should be grounded for compatibility with future chip revisions. |  |  |  |  |  |
| 1    | VCC            | P      | <del>-</del> | Power Pins                                                                                               |  |  |  |  |  |
| 20   | VCC            | P      | _            |                                                                                                          |  |  |  |  |  |
| 40   | VCC            | P      | -            |                                                                                                          |  |  |  |  |  |
| 81   | VCC            | P      | -            |                                                                                                          |  |  |  |  |  |
| 100  | VCC            | P      | -            |                                                                                                          |  |  |  |  |  |
| 120  | VCC            | P      | -            |                                                                                                          |  |  |  |  |  |
| 140  | VCC            | P      | -            |                                                                                                          |  |  |  |  |  |
| 11   | GND            | P      | _            | Ground Pins                                                                                              |  |  |  |  |  |
| 21   | GND            | P      | -            |                                                                                                          |  |  |  |  |  |
| 41   | GND            | P      | -            |                                                                                                          |  |  |  |  |  |
| 42   | GND            | P      | -            |                                                                                                          |  |  |  |  |  |
| 79   | GND            | P      | -            |                                                                                                          |  |  |  |  |  |
| 80   | GND            | P      | -            |                                                                                                          |  |  |  |  |  |
| 101  | GND            | P      | -            |                                                                                                          |  |  |  |  |  |
| 107  | GND            | P      | -            |                                                                                                          |  |  |  |  |  |
| 121  | GND            | P      | -            |                                                                                                          |  |  |  |  |  |
| 122  | GND            | P      | -            |                                                                                                          |  |  |  |  |  |
| 139  | GND            | P      | -            |                                                                                                          |  |  |  |  |  |
| 141  | GND            | P      | -            |                                                                                                          |  |  |  |  |  |
| 159  | GND            | P<br>P | -            |                                                                                                          |  |  |  |  |  |
| 160  | GND            | r      | <u>-</u>     |                                                                                                          |  |  |  |  |  |



## 82C480 Registers

| Register<br>Mnemonic | Register Name                     |              | Read<br>Access | Write<br>Access | Bits | Reg<br>Type      | Page     |
|----------------------|-----------------------------------|--------------|----------------|-----------------|------|------------------|----------|
| POS_2                | Setup Control                     |              | 0102           | 0102            | 1    | POS              | 21       |
| DISP_STAT            | Display Status                    |              | 02E8*          | N/A             | 3    | 8514/A           | 21       |
| H_TOTAL              | Horizontal Total                  |              | 26E8*          | 02E8*           | 9    | 8514/A           | 22       |
| DAC_MASK             | DAC Mask                          |              | 02EA           | 02EA†           | 8    | <b>RAMDAC</b>    | 22       |
| DAC_R_INDEX          | DAC Read Index                    |              | 02EB           | 02EB†           | 8    | <b>RAMDAC</b>    | 23       |
| DAC_W_INDEX          | DAC Write Index                   |              | 02EC           | 02EC†           | 8    | <b>RAMDAC</b>    | 23       |
| DAC_DATA             | DAC Data                          |              | 02ED           | 02ED†           | 8    | <b>RAMDAC</b>    | 24       |
| H_DISP               | Horizontal Displayed              |              | 06E8*          | 06E8*           | 8    | 8514/A           | 24       |
| H_SYNC_STRT          | Horizontal Sync Start             |              | 0AE8*          | 0AE8*           | 8    | 8514/A           | 25       |
| H_SYNC_WID           | Horizontal Sync Width             |              | 0EE8*          | 0EE8*           | 6    | 8514/A           | 25       |
| V_TOTAL              | Vertical Total                    |              | 12E8*          | 12E8*           | 12   | 8514/A           | 26       |
| V_DISP               | Vertical Displayed                |              | 16E8*          | 16E8*           | 12   | 8514/A           | 26       |
| V_SYNC_STRT          | Vertical Sync Start               |              | 1AE8*          | 1AE8*           | 12   | 8514/A           | 27       |
| V_SYNC_WID           | Vertical Sync Width               |              | 1EE8*          | 1EE8*           | 6    | 8514/A           | 27<br>27 |
| DISP_CNTL            | Display Control                   |              | 22E8*          | 22E8*           | 7    | 8514/A           | 28       |
| SUBSYS_STAT          | Subsystem Status                  |              | 42E8*          | N/A             | 16   | 8524/A           | 29       |
| SUBSYS_CNTL          | Subsystem Control                 |              | 2EE8*          | 42E8*           | 12   | 8514/A           | 30       |
| ROM_PAGE_SEL         | ROM Page Select                   |              | 46E8*          | 46E8*           | 3    | 8514/A           | 31       |
| ADVFUNC_CNTL         | Advanced Function Control         |              | 4AE8*          | 4AE8*           | 2    | 8514/A           | 32       |
| EC0                  | Extended Configuration Register 0 | 1            | 52E8*          | 52E8*           | Õ    | CHIPS            | 33       |
| EC1                  | Extended Configuration Register 1 |              | 56E8*          | 56E8*           | ő    | CHIPS            | 33       |
| EC1<br>EC2           |                                   |              | 5AE8*          | 5AE8*           | 13   | CHIPS            | 34       |
|                      | Extended Configuration Register 2 |              | 5EE8*          | 5EE8*           | 12   | CHIPS            | 36       |
| EC3                  | Extended Configuration Register 3 | •            | 82E8*          | 82E8*           | 12   | 8514/A           | 30<br>37 |
| CUR_Y                | Current Y Position                |              | 86E8*          | 86E8*           | 12   |                  | 38       |
| CUR_X                | Current X Position                | Constant     |                | 8AE8*           | 13   | 8514/A           | 38       |
| DESTY_AXSTP          | Destination Y Position/Axial Step |              | 8AE8*<br>8EE8* |                 | 13   | 8514/A<br>8514/A | 39       |
| DESTX_DIASTP         | Destination X Position/Diagonal S | tep Constant |                | 8EE8*           |      |                  | 39       |
| ERR_TERM             | Error Term                        | VV 2: 44L    | 92E8*          | 92E8*           | 16   | 8514/A           | 40       |
| MAJ_AXIS_PCNT        | Major Axis Pixel Count/Rectangle  | widui        | 96E8*          | 96E8*           | 11   | 8514/A           |          |
| GP_STAT              | Graphics Processor Status         |              | 9AE8*          | N/A             | 10   | 8514/A           | 41       |
| CMD                  | Command                           |              | N/A            | 9AE8*           | 16   | 8514/A           | 42       |
| SHORT_STROKE         | Short Stroke Vector Transfer      |              | 9EE8*          | 9EE8*           | 16   | 8514/A           | 44       |
| BKGD_COLOR           | Background Color                  |              | A2E8*          | A2E8*           | 8    | 8514/A           | 45       |
| FRGD_COLOR           | Foreground Color                  |              | A6E8*          | A6E8*           | 8    | 8514/A           | 45       |
| WRT_MASK             | Write Mask                        |              | AAE8*          | AAE8*           | 8    | 8514/A           | 46       |
| RD_MASK              | Read Mask                         |              | AEE8*          | AEE8*           | 8    | 8514/A           | 46       |
| COLOR_CMP            | Color Compare                     |              | B2E8*          | B2E8*           | 8    | 8514/A           | 47       |
| BKGD_MIX             | Background Mix                    |              | B6E8*          | B6E8*           | 8    | 8514/A           | 48       |
| FRGD_MIX             | Foreground Mix                    | _            | BAE8*          | BAE8*           | 8    | 8514/A           | 49       |
|                      | Multi-function Control Index (MF  |              | N/A            | BEE8*           | 4    | 8514/A           | 50       |
| MIN_AXIS_PCNT        |                                   | FC[0]        | BEE8*          | BEE8*           | 11   | 8514/A           | 50       |
| SCISSORS_T           |                                   | FC[1]        | BEE8*          | BEE8*           | 12   | 8514/A           | 51       |
| SCISSORS_L           |                                   | FC[2]        | BEE8*          | BEE8*           | 12   | 8514/A           | 51       |
| SCISSORS_B           |                                   | FC[3]        | BEE8*          | BEE8*           | 12   | 8514/A           | 52       |
| SCISSORS_R           |                                   | FC[4]        | BEE8*          | BEE8*           | 12   | 8514/A           | 52       |
| MEM_CNTL             | Memory Control M                  | FC[5]        | BEE8*          | BEE8*           | 5    | 8514/A           | 53       |
| PATTERN_L            |                                   | FC[8]        | BEE8*          | BEE8*           | 5    | 8514/A           | 54       |
| PATTERN_H            |                                   | FC[9]        | BEE8*          | BEE8*           | 5    | 8514/A           | 54       |
| PIX_CNTL             |                                   | FC[A]        | BEE8*          | BEE8*           | 7    | 8514/A           | 55       |
| PIX_TRANS            | Pixel Data Transfer               |              | E2E8*          | E2E8*           | 8/16 |                  | 56       |
| ·                    |                                   |              | =              | -               |      | •                |          |

**Revision 1.6** 19 Preliminary 82C480

<sup>\*</sup> Indicates 16-bit read/write access at port addresses xxx8/xxx9.
† When in VGA Pass-through mode, write accesses to 3C6–3C9h are mirrored in the 8514/A RAMDAC.



| Register       | I/O      | 15       | 14   | 13   | 12  | 11   | 10         | 9                                      | 8           | 7     | 6     | 5        | 4      | 3             | 2     | 1     | 0     |
|----------------|----------|----------|------|------|-----|------|------------|----------------------------------------|-------------|-------|-------|----------|--------|---------------|-------|-------|-------|
| DISP_STAT      | 02E8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           | 0     | 0     | 0        | 0      | 0             | TOG   | VBK   | SENS  |
| H TOTAL        | 26E8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      |             |       | Ů     |          | OTAL   |               | 100   | , 211 | 02.10 |
| DAC_MASK       | 02EA     | X        | X    | X    | Х   | X    | х          | X                                      | X           |       |       | PALE     |        |               |       |       |       |
| DAC R INDEX    | 02EB     | X        | X    | X    | Х   | X    | Х          | Х                                      | X           |       |       |          | AD INI | _             |       |       |       |
| DAC W INDEX    | 02EC     | х        | Х    | X    | Х   | Х    | х          | Х                                      | Х           |       |       | <u> </u> | TE IN  |               |       |       |       |
| DAC DATA       | 02ED     | X        | X    | X    | X   | X    | X          | X                                      | X           |       | RAM   | DAC I    |        |               | STER  |       |       |
| H DISP         | 06E8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           |       |       | IZON     |        |               |       |       |       |
| H_SYNC_START   | 0AE8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           |       |       | ZONT     |        |               |       |       |       |
| H_SYNC_WID     | 0EE8     | 0        | 0    | 0    | ō   | 0    | 0          | 0                                      | 0           | 0     | 0     | POL      |        |               | NC W  | DTH   |       |
| V TOTAL        | 12E8     | 0        | 0    | 0    | 0   |      |            |                                        |             | VIB   |       |          |        |               | ,     | VTAD  | J     |
| V DISP         | 16E8     | 0        | 0    | 0    | 0   |      |            |                                        |             | VTD   |       |          |        |               | ,     | VDAD  | J     |
| V_SYNC_STRT    | 1AE8     | 0        | 0    | 0    | 0   |      |            |                                        |             | VSB   |       |          |        |               | ,     | VSAD  | J     |
| V_SYNC_WID     | 1EE8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           | 0     | 0     | POL      |        | V SY          | NC W  | IDTH  |       |
| DISP_CNTL      | 22E8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           | 0     | DISI  | PEN      | INL    | DBL           | MEN   | 1CFG  | ODD   |
| SUBSYS_STAT    | 42E8R    |          | СНІ  | P ID |     |      | СНІ        | REV                                    |             | 8P    |       | II NON   | b      | GPI           | ІЮ    | PF    | VBF   |
| SUBSYS_CNTL    | 42E8W    | GPC      | TRL  | CHI  | TST | IGPI | ШО         | IPF                                    | IVBF        | 0     | 0     | 0        | 0      | RGPI          | RIIO  | RPF   | RVBF  |
| ROM_PAGE_SEL   | 46E8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           | 0     | 0     | 0        |        |               | RC    | M PA  |       |
| ADVFUNC_CNTL   | 4AE8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           | 0     | 0     | 0        | 0      | Ō             | CLK   | 1     | AF    |
| EC2            | 5AE8     | 0        | 0    | DAC  | 0   | 5PN  | 1 <b>M</b> | BAN                                    | īKS         | 8BP   | RPG   | RSIZ     | ROM    | BASE          | 1     | 1     | 1     |
| EC3            | 5EE8     | 0        | 0    | 0    | OVR | 0    | CLK2       | CLK1                                   | CLK0        | ALE   | AHE   | ALS      | AHS    |               | MFC   | INDE  | x     |
| CUR_Y          | 82E8     | 0        | 0    | 0    | 0   | 0    |            |                                        |             |       | Yl    | POSIT    | ION    |               |       |       |       |
| CUR_X          | 86E8     | 0        | 0    | 0    | 0   |      |            |                                        |             |       | X-I   | POSIT    | ION    |               |       |       |       |
| DESTY_AXSTP    | 8AE8     | 0        | 0    | 0    | SGN |      |            | 7                                      | -DES        | TINAT | TON / | AXIA     | L STE  | P CON         | STAN  | Т     |       |
| DESTX_DIASTP   | 8EE8     | 0        | 0    | 0    | SGN |      | -          | X-DESTINATION / DIAGONAL STEP CONSTANT |             |       |       |          |        |               |       |       |       |
| ERR_TERM       | 92E8     | R/W      | R/W  | R/W  |     |      |            |                                        | IN          | ITIAL | ERRC  | R TEI    | RM     |               |       |       |       |
| MAJ_AXIS_PCNT  | 96E8     | 0        | 0    | 0    | 0   | 0    |            | MAJ                                    | OR AX       | IS PD | ŒL C  | OUNT     | / REC  | TANG          | LE W  | IDTH  |       |
| GP_STAT        | 9AE8R    | 0        | 0    | 0    | 0   | 0    | 0          | BSY                                    | RDY         |       |       | QUE      | UE ST  | ATE           |       |       |       |
| CMD            | 9AE8W    | CO       | MMA  | ND   | BSQ | 0    | 0          | 16B                                    | PCD         | INCY  | MAJ   | INCX     | DRW    | TYP           | LAST  | AP    | WRT   |
| SHORT_STROKE   | 9EE8     | -        | ANGL | E    | DRW |      | LEN        | GTH                                    |             |       | ANGL  | E        | DRW    |               | LEN   | GTH   |       |
| BKGD_COLOR     | A2E8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           |       | BA    | CKGF     | ROUNI  | COL           | OR    |       |       |
| FRGD_COLOR     | A6E8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           |       | FO    | REGR     | OUNI   | COL           | OR    |       |       |
| WRT_MASK       | AAE8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           |       |       | WR       | ITE M. | ASK           |       |       |       |
| RD_MASK        | AEE8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           |       |       | REA      | AD MA  | ASK           |       |       |       |
| COLOR_CMP      | B2E8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           |       | (     | COLO     | R COM  | <b>IPAR</b> I | E     |       |       |
| BKGD_MIX       | B6E8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           | 0     | B     | SS       |        | B             | ACKM  | IX    |       |
| FRGD_MIX       | BAE8     | 0        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           | 0     | F     | SS       |        | FC            | DREM  | ΙΧ    |       |
| MULTIFUNC_CNTI | BEE8     |          | IND  | EX   |     | Х    | Х          | X                                      | X           | X     | X     | X        | X      | X             | X     | X     | X     |
| MIN_AXIS_PCNT  | BEE8     | 0        | 0    | 0    | 0   | 0    |            | N                                      | MINOR       | AXIS  | PIXE  | L COU    | JNT/R  | ECT F         | IEIGH | T     |       |
| SCISSORS_T     | BEE8     | 0        | 0    | 0    | 1   |      |            |                                        |             |       | TOP   | SCISS    | SORS   |               |       |       |       |
| SCISSORS_L     | BEE8     | 0        | 0    | 1    | 0   |      |            |                                        |             | :     | LEFT  | SCIS     | SORS   |               |       |       |       |
| SCISSORS_B     | BEE8     | 0        | 0    | 0    | 1   |      |            |                                        |             | В     | OTTO  | M SC     | ISSOR  | S             |       |       |       |
| SCISSORS_R     | BEE8     | 0        | 1    | 0    | 0   |      |            |                                        |             |       | RIGH  | T SCI    | SSORS  | 3             |       |       |       |
| MEM CAPPI      | BEE8     | 0        | 1    | 0    | 1   | 0    | 0          | 0                                      | 0           | 0     | 0     | 0        | SWP    | VR            | CFG   | НО    | RCFG  |
| MEM_CNTL       | 1        |          |      |      |     |      | _          |                                        | Ι Λ         | 0     | 0     | 0        |        |               | CIZI  | O117  | :     |
| PATTERN_L      | BEE8     | 1        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           | יין   |       | U        |        | IVIL/         | ASK L | UW    | :     |
|                | <b>L</b> | 1        | 0    | 0    | 0   | 0    | 0          | 0                                      | 0           | 0     | 0     | 0        |        |               | ASK D |       |       |
| PATTERN_L      | BEE8     | <u> </u> |      |      |     |      |            | <del></del>                            | <del></del> | 0     |       | 0        | LCMI   | MA            | SK H  |       | 0     |

Revision 1.6 20 Preliminary 82C480



# SETUP CONTROL REGISTER (POS\_2)

Read at I/O Address 102h Write at I/O Address 102h Byte Accessible only



- 0 480 Card Enable
  - 1 = Card enabled
  - 0 = Card disabled (all registers and memory invisible to system except POS Setup registers).
- 7-1 Reserved = 0

# DISPLAY STATUS REGISTER (DISP\_STAT)

Read only at I/O Address 02E8h Byte or Word Accessible



- SENSE is the result of a wired-OR of comparators on each of the RGB video signals. This sense input may be used to determine if a color, monochrome or no monitor is connected to the analog connector. The RAMDAC expects to be driving a 75Ω matched impedance cable. The comparator reference voltage is generally chosen to be approximately half of the full scale DAC output. By programming the RAMDAC for various voltage outputs and patterns and then reading SENSE, the monitor type can be deduced.
- 1 VBLANK Vertical Blank State
  - 0 = Vertical Blank inactive
  - 1 = Vertical Blank active
- 2 HORTOG Horizontal Toggle reads the state of a flip-flop which is clocked by HSYNC; the beginning of the sync pulse (which generally occurs after the end of displayed data) can be detected by polling this bit and waiting for a change of state.
- 15-3 Reserved = 0



# HORIZONTAL TOTAL REGISTER (H TOTAL)

Read at I/O Address 26E8h Write at I/O Address 02E8h Byte or Word Accessible



DAC MASK REGISTER

(DAC\_MASK)
Read at I/O Address 02EAh
Write at I/O Address 02EAh
Write at I/O Address 03C6h (VGA Mode Only)
Byte Accessible only



8-0 Horizontal Total defines the total horizontal scan line width including the display, blank, and sync times. All horizontal timings are measured in terms of double nuggets (8 or 10 pixels depending upon the state of MEM\_CNTL[0]). By definition, H\_TOTAL is measured from the start of the first displayed pixel on the scan line. Therefore, the total time per scan line is:

(H\_TOTAL+1) double nugget periods.

15-9 Reserved = 0

7-0 DAC Mask. This register is in the RAMDAC Color Palette. Pixel data bits are ANDed with the DAC Mask before going to the palette. This can be used to split the display buffer into multiple buffers by alternately enabling different planes.

The 8514/A palette registers may be written at their equivalent VGA I/O addresses when the 8514/A is in VGA pass-through mode. This allows the 8514/A palette to mirror the contents of the VGA palette hence displaying the correct colors when outputing VGA pass-through video. The 8514/A never responds to I/O read accesses to the VGA palette.



# DAC READ INDEX REGISTER (DAC\_R\_INDEX)

Read at IIO Address 02EBh Write at IIO Address 02EBh Write at IIO Address 03C7h (VGA Mode Only) Byte Accessible only



7-0 DAC Read Index. This register is in the RAMDAC Color Palette.

The DAC Read Index is used to point to the location in the RAM lookup table which will be read by the current sequence of I/O reads to the DAC\_DATA register. To read the contents of a location in the RAM palette:

- Write the RAM address for that location to the DAC Read Index register. The data in the RAMDAC at that address is read into the DAC\_DATA register. The DAC Read Index register auto-increments to point to the next RAMDAC address location. Address location 0FFh wraps around to 0.
- 2. The palette data for that location may then be read by three consecutive accesses to the DAC\_DATA register, one each for Red, Green, and Blue palette data (6 or 8 bits).

Upon completion of the third read to the DAC\_DATA register, the 18/24 bits of data for the next address location is available to be read from the DAC\_DATA register.

The IBM 8514/A uses an 18-bit wide color palette (6 bits each for Red, Green, and Blue). The 82C480 supports both 6 and 8 bit RAMDACs.

# DAC WRITE INDEX REGISTER (DAC\_W\_INDEX)

Read at I/O Address 02ECh Write at I/O Address 02ECh Write at I/O Address 03C8h (VGA Mode Only) Byte Accessible only



7–0 DAC Write Index. This register is in the RAMDAC Color Palette.

The DAC Write Index is used to point to the location in the RAM lookup table which will be loaded following the completion of a triple write sequence to the DAC\_DATA register. To update a location in the RAM palette:

- 1. Write the RAM address for that location to the DAC Write Index register.
- 2. In three consecutive writes to the DAC\_DATA register, output Red, Green, and Blue palette data (6 or 8 bits).

Upon completion of the third write to the DAC\_DATA register, the 18/24 bits of palette data is transferred to the RAMDAC lookup table. The DAC Write Index is then incremented to point to the next RAMDAC address location. Address location 0FFh wraps around to 0.

The IBM 8514/A uses an 18-bit wide color palette (6 bits each for Red, Green, and Blue). The 82C480 supports both 6 and 8 bit RAMDACs.



# DAC DATA REGISTER (DAC DATA)

Read at I/O Address 02EDh Write at I/O Address 02EDh Write at I/O Address 03C9h (VGA Mode Only) Byte Accessible only



7-0 DAC Data. This register is in the RAMDAC Color Palette.

To write a new color for a pixel, first write its address to DAC\_W\_INDEX, then write the red, green, and blue values consecutively to DAC\_DATA. After the blue value is written, all three color values are simultaneously transferred to the palette, and DAC\_W\_INDEX is incremented to point to the next palette word. This allows writing the whole palette with only one write to the DAC\_W\_INDEX register.

To read a color value, first write its address to DAC\_R\_INDEX; this causes that locations value to be copied into a temporary register (18 or 24-bit) and DAC\_R\_INDEX to be incremented. Then the red, green, and blue values (6 or 8-bit) may be read consecutively by reading the DAC\_DATA register. As soon as the blue value is read, the next locations color data is transferred to the temporary register and DAC\_R\_INDEX is again incremented. This allows reading of the whole palette with only one write of the DAC\_R\_INDEX register.

The IBM 8514/A uses an 18-bit wide color palette (6 bits each for Red, Green, and Blue). The 82C480 supports both 6 and 8 bit RAMDACs.

# HORIZONTAL DISPLAYED REGISTER (H DISP)

Read at I/O Address 06E8h (Chips Extension) Write at I/O Address 06E8h Byte or Word Accessible



7-0 Horizontal Displayed defines both the number of displayed pixels per scan line and the start of the horizontal blanking. All horizontal timings are performed in terms of double nuggets. The start of the horizontal blanking signal occurs at:

(H\_DISP+1) double nugget periods after the start of the scan line.

15-8 Reserved = 0



## HORIZONTAL SYNC START REGISTER

(H\_SYNC\_STRT)
Read at I/O Address 0AE8h (Chips Extension) Write at I/O Address 0AE8h Byte or Word Accessible



7-0 Horizontal Sync Start defines the timing delay of the horizontal sync signal from the start of a scan line. For HSYNC to occur, H\_SYNC\_STRT must be less than H\_TOTAL. The horizontal sync pulse begins at:

> (H\_SYNC\_STRT+1) double nugget periods after the beginning of a scan line.

15-8 Reserved = 0

## HORIZONTAL SYNC WIDTH REGISTER

(H\_SYNC\_WID)
Read at I/O Address 0EE8h (Chips Extension) Write at I/O Address 0EE8h Byte or Word Accessible



- Horizontal Sync Width defines the width (in double nugget periods) of the horizontal sync pulse. The horizontal sync pulse is independent of Horizontal Total in that the end of a scan line does not terminate the HSYNC signal.
- **HSYNCPOL** (Horizontal Sync Polarity) 5
  - 1 = Negative(-)
  - 0 = Positive (+)

The horizontal and vertical sync polarities are used to indicate the horizontal and vertical frame times to some IBM monitors as described below:

| Horizontal<br>Sync<br>Polarity | Sync | Horizontal<br>Scan<br>Freq (KHz) | Vertical<br>Scan<br>Freq (Hz) |  |  |
|--------------------------------|------|----------------------------------|-------------------------------|--|--|
|                                | -    | 31.47                            | 59.94                         |  |  |
| _                              | +    | 31.47                            | 70.08                         |  |  |
| +                              | _    | 31.47                            | 70.08                         |  |  |
| +                              | +    | 35.52                            | 43.48                         |  |  |

15-6 Reserved = 0



# VERTICAL TOTAL REGISTER (V\_TOTAL)

Read at I/O Address 12E8h (Chips Extension) Write at I/O Address 12E8h Byte or Word Accessible



### 2-0 VTADJ = Vertical Total Adjust

### 11-3 VTB = Vertical Total Base

The Vertical Total value is calculated from VTB, VTADJ, and the Scan Modulus. The internal vertical counter register is incremented at the end of every scan line when in non-interlaced mode. When in interlaced mode, the vertical counter increments every half scan line (ie. when the horizontal counter reaches H\_TOTAL+2 and H\_TOTAL). For true interlacing to occur, Vertical Total must be programmed to an odd number of half scan lines (ie. VTADJ is even).

 $Vertical\ Total = (Modulus * VTB) + VTADJ + 1$ 

The Scan Modulus is calculated from the DBLSCAN and MEMCFG bits of the DISP\_CNTL register as follows:

| DBLSCAN | MEM | CFG | Scan Modulus |
|---------|-----|-----|--------------|
| 0       | 0   | 0   | 2            |
| 0       | 0   | 1   | 4            |
| 0       | 1   | 0   | 6            |
| 0       | 1   | 1   | 8            |
| 1       | 0   | 0   | 4            |
| 1       | 0   | 1   | 8            |
| 1       | 1   | 0   | 12           |
| 1       | 1   | 1   | 16           |

15-12 Reserved = 0

# VERTICAL DISPLAYED REGISTER (V\_DISP)

Read at I/O Address 16E8h (Chips Extension) Write at I/O Address 16E8h Byte or Word Accessible



### 2-0 VDADJ = Vertical Displayed Adjust

### 11–3 VDB = Vertical Displayed Base

The Vertical Displayed value is calculated from VDB, VDADJ, and the Scan Modulus (opposite). The internal vertical counter is incremented at the end of every scan line when in non-interlaced mode; every half scan line (ie. when the horizontal counter reaches H\_TOTAL+2 and H\_TOTAL) when in interlaced mode. The Vertical Displayed value also determines the starting location for the Vertical Blank signal. The Vertical Blank signal is synchronized to the end of a scan line (full H\_TOTAL).

## Vertical Disp = (Modulus \* VDB) + VDADJ + 1

Since Vertical Total must be odd when in interlaced mode, scan lines have an alternating odd/even relationship with the half scan line count in alternate frames. (In even frames, the vertical counter begins counting at the start of a full scan line and ends on a half scan line. In the odd frame which follows, the vertical counter begins on a half scan line and ends on a full scan line.) Because Vertical Blank is synchronized to full H\_TOTAL, the Vertical Blank pulse for even frames is delayed by H\_TOTAL+2 and is shorter by this amount in odd frames.

**15–12** Reserved = 0

Preliminary 82C480



### VERTICAL SYNC START REGISTER (V\_SYNC\_STRT)

Read at I/ $\overline{O}$  Address 1AE8h (Chips Extension) Write at I/O Address 1AE8h Byte or Word Accessible



- VSADJ = Vertical Sync Start Adjust
- 11-3 VSB = Vertical Sync Start Base

The Vertical Sync Start value is calculated from VSB, VSADJ, and the Scan Modulus. The internal vertical counter register is incremented at the end of every scan line when in non-interlaced mode. When in interlaced mode, the vertical counter increments every half scan line (i.e. when the horizontal counter reaches H\_TOTAL+2 and H\_TOTAL). The Vertical Sync signal is not synchronized to the end of a scan line (full H\_TOTAL) as is the Vertical Blank.

### VSYNC START = (VSB \* Modulus) + VSADJ + 1

The Scan Modulus is calculated from the DBLSCAN and MEMCFG bits of the DISP\_CNTL register as follows:

| DBLSCAN | MEM | <b>ICF</b> G | Scan Modulus |
|---------|-----|--------------|--------------|
| 0       | 0   | 0            | 2            |
| 0       | 0   | 1            | 4            |
| 0       | 1   | 0            | 6            |
| 0       | 1   | 1            | 8            |
| 1       | 0   | 0            | 4            |
| 1       | 0   | 1            | 8            |
| 1       | 1   | 0            | 12           |
| 1       | 1   | 1            | 16           |

15-12 Reserved = 0

# VERTICAL SYNC WIDTH REGISTER

(V SYNC WID)
Read at I/O Address 1EE8h (Chips Extension) Write at I/O Address 1EE8h Byte or Word Accessible



- Vertical Sync Width defines the width of the vertical sync pulse in scan lines. The vertical sync pulse is independent of Vertical Total so that when the vertical counter reaches Vertical Total, the VSYNC signal is not terminated. When in interlaced mode, the pulse width is counted in half scan lines.
  - 5 VSYNCPOL (Vertical Sync Polarity)

1 = Negative (-)

0 = Positive (+)

The horizontal and vertical sync polarities are used to indicate the horizontal and vertical frame times to some IBM monitors as described below:

| Vertical<br>Sync<br>Polarity | Horizontal<br>Scan<br>Freq (KHz) | Vertical<br>Scan<br>Freq (Hz)                             |
|------------------------------|----------------------------------|-----------------------------------------------------------|
| _                            | 31.47                            | 59.94                                                     |
| +                            | 31.47                            | 70.08                                                     |
| _                            | 31.47                            | 70.08                                                     |
| +                            | 35.52                            | 43.48                                                     |
|                              | Sync<br>Polarity<br>-<br>+<br>-  | Sync Scan<br>Polarity Freq (KHz)  - 31.47 + 31.47 - 31.47 |

15–6 Reserved = 0



# DISPLAY CONTROL REGISTER (DISP CNTL)

Read at I/O Address 22E8h (Chips Extension) Write at I/O Address 22E8h Byte or Word Accessible



- ODDBNKENAB (Odd Bank Enable). This bit is not used internally by the 480.
  - 0 = No Change
  - 1 = Horizontally Interleave banks (normal 8514/A mode).
- 2–1 MEMCFG (Memory Configuration)

#### 2 1 Function

- 0 0 NCLK (PS8 Mode)
- 0 1 NCLK + 2 (Normal 8514/A Mode)
- 1 0 NCLK+3
- 1 1 NCLK+4
- 3 DBLSCAN (Double Scan).
  - 0 = Single scan
  - 1 = Double scanning enabled
- 4 INTERLACE
  - 0 = Non-interlace
  - 1 = Interlace

### 6-5 DISPEN (Display Enable)

## 6 5 Function

- 0 0 No effect
- 0 1 Enable Hsync, Vsync, Blank, data transfer cycles, and refresh cycles
- 1 x Disable Hsync, Vsync, Blank, data transfer cycles, and refresh cycles

Bits 6:5 control an R-S latch. The output of this latch is read back in bit 5; bit 6=0.

15-7 Reserved = 0

NOTE: INTERLACE, DBLSCAN, and MEMCFG bits are duplicated in each of the alternate video register sets.



# SUBSYSTEM STATUS REGISTER (SUBSYS STAT)

Read at I/O Address 42E8h Byte or Word Accessible



- 3-0 Interrupt requests. These bits show the state of internal interrupt requests; these will only activate the IRQ pin if the corresponding Interrupt Enable bit in the SUBSYS\_CNTL register is set. Interrupts may only be reset by writing a 1 to the corresponding Interrupt Clear bit in the SUBSYS\_CNTL register. The interrupt conditions supported are:
  - VBLNKFLG (Vertical Blank Flag) -Vertical blank signal has become active
  - PICKFLAG The current XY position went inside the scissor while executing a line, outline, SSV, bitblt or rectangle command.
  - 2 INVALIDIO The host attempted to write to the queue when no words were available or read from PIX\_TRANS when no data was ready.
  - 3 GPIDLE The graphics drawing engine is idle.
- 6-4 MONITORID This field contains the monitor ID bits from pins MS2:0. These bits are driven by some monitors to indicate monitor type. The following monitor IDs are returned by IBM and compatible monitors:

| M | Monitor ID |   | IBM Monitor Type           |  |
|---|------------|---|----------------------------|--|
| 0 | 0          | 0 | Reserved                   |  |
| 0 | 0          | 1 | 8507 (1024x768) Monochrome |  |
| 0 | 1          | 0 | 8514 (1024x768) Color      |  |
| 0 | 1          | 1 | Reserved                   |  |
| 1 | 0          | 0 | Reserved                   |  |
| 1 | 0          | 1 | 8503 (640x480) Monochrome  |  |
| 1 | 1          | 0 | 8512/8513 (640x480) Color  |  |
|   |            |   |                            |  |

7 8PLANE - 8 bit planes Latched on reset from P4D7, 8PLANE emulates the function of the jumper on the IBM 8514/A board.

1 Reserved

0 = 4 planes1 = 8 planes

- 11-8 CHIP\_REV Revision number of the silicon. This number, in combination with the CHIP\_ID will allow programmers to determine which advanced capabilities are available on this 8514/A.
- 15-12 CHIP\_ID This field contains the CHIPS ID for this 8514/A implementation.
  - 0 = Chips and Technologies 82C480



# SUBSYSTEM CONTROL REGISTER (SUBSYS CNTL)

Read at I/O Address 2EE8h (Chips Extension) Write at I/O Address 42E8h Byte or Word Accessible



- 3-0 Interrupt Reset. These bits are used to reset active interrupt flags. They may be reset individually or in combination.
  - 0 = Don't reset flag
  - 1 = Reset flag

The reset bits are as follows:

- 0 RVBLNKFLG Reset Vertical Blank Flag
- 1 RPICKFLAG Reset PICK Flag
- 2 RINVALIDIO Reset Queue overflow / Data underflow flag
- 3 RGPIDLE Reset Graphics Engine Idle flag

Note:Bits 3:0 always read back = 0.

- 7-4 Reserved = 0
- 11-8 Interrupt Enables. These bits are used to permit a particular interrupt condition to generate an external IRQ.
  - 0 = Disable interrupts for this condition 1 = Enable interrupts for this condition
  - 8 IBLNKFLG Enable Vertical Blank interrupt
  - 9 IPICKFLAG Enable PICK interrupt
  - 10 IINVALIDIO Enable Queue Overflow / Data Underflow interrupt
  - 11 IGPIDLE Enable Graphics Engine Idle interrupt

13-12 CHPTEST Chip test bits used by IBM for testing their two chip set. Program to 01 to enable normal function.

On read back, bit D13 = 1 if 13:12 were programmed to 1x; otherwise = 0. On reset, initialized to 0 (Normal Operation). Bit D12 always reads back as 0.

15–14 GPCTRL Graphics Processor Control

#### 15 14 Effect on 82C480

0 0 No effect

1

- 0 1 Enable Chip
  - O Reset Chip. Stop all VRAM cycles, flush queue, clear GPBUSY and Queue Status flags. Don't reset counters or tristate pins.
- 1 1 Reset Chip. Stop all VRAM cycles, flush queue, clear GPBUSY and Queue Status flags. Don't reset counters or tristate pins. (Same as 1 0).

Bits 15:14 control an R-S type latch. The status of this software reset latch is read back in bit D15; bit D14 = 0.

On reset bit D15 = 0 (enabled).



# ROM PAGE SELECT REGISTER (ROM PAGE SEL)

Read at I/O Address 46E8h (Chips Extension) Write at I/O Address 46E8h Byte or Word Accessible



- 3 VGA ENABLE This bit is not physically present on the 82C480, but is standard on ISA VGA cards. It is included here for completeness.
  - 0 = Disable VGA 1 = Enable VGA
- 4 VGA SETUP This bit is not physically present on an 8514/A card but is standard on ISA VGA cards. It is included here for completeness.
  - 0 = Normal operation
  - 1 = Setup mode
- 15-5 Reserved = 0

2-0 ROMPAGE. ROMPAGE allows mapping one of 8 different 4K pages of on-board ROM to the same 4K memory in address space.

All of the standard IBM 8514/A address ranges except CA000h-CA7FFh conflict with most extended VGA BIOS. To prevent a conflict from occurring, we suggest the ROM (if installed) be relocated to another address range using the ROM relocation bits in Extended Configuration Register EC3. EC3 also contains bits to disable ROM paging and to select the size of the ROM address space.

| ISA Bus Address<br>(20-bit) | MCA Bus Address<br>(24-bit) | ROMPAGE<br>2 1 0 | 32K x 8 ROM<br>Address | Comments  |
|-----------------------------|-----------------------------|------------------|------------------------|-----------|
| C6800-C6FFF                 | 0C6800-0C6FFF               | xxx              | 7800-7FFF              | Fixed ROM |
| C7000-C7FFF                 | 0C7000-0C7FFF               | 000              | 0000-0FFF              | Paged ROM |
| C7000-C7FFF                 | 0C7000-0C7FFF               | 001              | 1000-1FFF              | Paged ROM |
| C7000-C7FFF                 | 0C7000-0C7FFF               | 010              | 2000-2FFF              | Paged ROM |
| C7000-C7FFF                 | 0C7000-0C7FFF               | 0 1 1            | 3000-3FFF              | Paged ROM |
| C7000-C7FFF                 | 0C7000-0C7FFF               | 100              | 4000-4FFF              | Paged ROM |
| C7000-C7FFF                 | 0C7000-0C7FFF               | 101              | 5000-5FFF              | Paged ROM |
| C7000C7FFF                  | 0C7000-0C7FFF               | 110              | 6000-6FFF              | Paged ROM |
| C7000-C7FFF                 | 0C7000-0C7FFF               | 1 1 1            | 7000-7FFF              | Paged ROM |
| CA000-CA7FF                 | 0CA000-0CA7FF               | ххх              | 7000-77FF              | Fixed ROM |

IBM 8514/A Standard ROM Address Mapping

Revision 1.6 31 Preliminary 82C480



# ADVANCED FUNCTION CONTROL REGISTER (ADVFUNC CNTL)

Read at I/O Address 4AE8h (Chips Extension)
Write at I/O Address 4AE8h
Byte or Word Accessible



- O DISABPASSTHRU This bit controls the VGA pass-through feature of the 8514/A.
  - 0 = VGA video is passed through the 8514/A RAMDAC to the display.
  - 1 = Advanced Function. 8514/A video is passed through the RAMDAC to the display.
- 1 RSDV0 Reserved bit 0 = 1
- 2 CLKSEL (Clock Select) The IBM 8514/A supports only two clock frequencies; 0=25.175MHz (640x480), and 1=44.900MHz (1024x768 interlaced). The 480 supports 8 clock frequencies through its extended clock select bits in register EC3. This bit also controls the selection of the alternate video register sets if they are enabled. Alternate Video Register sets are an 82C480 extension of the 8514/A standard. They are used to support display timing parameters other than the IBM standard (eg. 1024x768 non-interlaced).
- 3 RSDV1 Reserved bit 1 = 0
- 15-4 Reserved = 0

WARNING: All write accesses to this register will reset the Alternate Register Set OVERRIDE bit (EC3[12]). This means that a non-standard resolution driver must rewrite register EC3 each time a write to ADVFUNC CNTL is performed.

Preliminary 82C480



## EXTENDED CONFIGURATION REGISTER 0 (EC0)

Read at I/O Address 52E8h (Chips Extension) Write at I/O Address 52E8h (Chips Extension) Byte or Word Accessible



15-0 Reserved for future use by CHIPS.

# **EXTENDED CONFIGURATION REGISTER 1** (EC1)

Read at I/O Address 56E8h (Chips Extension) Write at I/O Address 56E8h (Chips Extension) Byte or Word Accessible



15-0 Reserved for future use by CHIPS.



## EXTENDED CONFIGURATION REGISTER 2 (EC2)

Read at I/O Address 5AE8h (Chips Extension) Write at I/O Address 5AE8h (Chips Extension) Byte or Word Accessible



- 2-0 Reserved = 1. These bits are latched on reset from P4D2:0 and as yet have no defined usage. They each have internal pull-up resistors so they default to 1.
- 4-3 ROMBASE ROM Base defines the start of the 8514/A ROM address space in system memory (default = 11). These bits are latched on reset from P4D4:3. ROM address mapping is also dependant on ROMSIZE (below) and the type of system interface.

| E   | C2  | 8K     |       | 32K    |       |
|-----|-----|--------|-------|--------|-------|
| [4] | [3] | MCA    | ISA   | MCA    | ISA   |
| 0   | 0   | 0C8000 | C6000 | 0D0000 | D0000 |
| 0   | 1   | 0D8000 | D8000 | 0D8000 | D8000 |
| 1   | 0   | 0C0000 | C0000 | 0C0000 | C0000 |
| 1   | 1   | 0C6000 | C8000 | 0C8000 | C8000 |

ROM page 0 always maps to the first 4K of address space.

NOTE: The VGA ROM takes up 32K bytes at C0000-C7FFFh which conflicts with the space used by the MCA bus 8514/A (C6000-C7FFFh). Also, CA000h as used by IBM conflicts with other cards in typical ISA bus systems. For this reason, it is recommended that the ROM space in 480-based systems be configured for the default addresses: C6000-C7FFFh in MCA and

- C8000-C9FFFh in the ISA bus. For specific ROM mapping tables consult the tables on the following page.
- 5 ROMSIZE Indicates the size of the address space allocated in memory (starting at the base address indicated by ROMBASE above).

0 = 32K ROM address space

1 = 8K ROM address space (default)

This bit is latched on reset from P4D5.

If a 32K physical ROM is implemented in an 8K address space, then the ROMPG2:0 pins should be connected to ROM address inputs A14:12. The upper 4K of the ROM space may then be paged from any one of the eight 4K pages in the ROM. This is done via the ROM\_PAGE\_SEL register. If an 8K physical ROM is connected, ROMSIZE should be selected as 8K and ROMPG2:0 do not need to be connected. These bits may then be used as general purpose outputs or may be selected by the ROM PAGING bit as transparent inputs for the MONITOR\_ID bits.

- 6 ROMPAGING This bit is latched on reset from P4D6.
  - 0 = ROMPG pins are inputs
  - 1 = ROMPG pins are outputs

If ROMPAGING = 1, after latching the MONITOR\_ID data on reset, the ROMPG pins then become outputs. If ROMSIZE is also latched low on reset, then ROMPG pins always output the contents of ROM\_PG\_SEL[2:0]. If ROMSIZE = 1, then ROMPG pins output either address or ROM\_PG\_SEL[2:0] as demonstrated in the paging table on the following page.

If ROMPAGING = 0, then the ROMPG pins become transparent inputs readable at SUBSYS\_STAT[6:4]. This allows the detection of a monitor which was connected after power was switched on.

7 8BP (8 Bit Planes). This bit is a copy of the read-only 8PLANE bit in SUBSYS\_STAT[7]. It is latched from P4D7 on reset. Configuration drivers written specifically for the 82C480 may write this bit, eliminating the need for a jumper.

0 = 4-bit planes

1 = 8-bit planes (default)



9-8 BANKS Indicates the number of VRAM banks connected to the 82C480.

00 = 1 bank

01 = 2 banks

10 = 3 banks

11 = 4 banks (default)

These bits are latched from pins CAS3/ and CAS2/ on reset.

10 1MB Indicates type of VRAMs used:

0 = 64Kx4

1 = 256Kx4 (default)

This bit is latched from MA8 on reset.

11 5PN 5-Pixel Nuggets. This bit is latched from WE4/ on reset. It determines whether the VRAM bank configuration is 4 or 5 pixels deep. It is necessary to program MEM\_CNTL[0] in order to set the 82C480

into 5-pixel nugget mode.

12 Reserved = 0

13 8BITDAC 8-Bit DAC Control. Latched from 8BITDAC on reset.

0 = 6-bit

1 = 8-bit

15-14 Reserved = 0

Note: The 82C480 mapping table shown below demonstrates the address space mapping for a default 480 MCA configuration. Paging in the C7000–C7FFFh range is chosen by n=ROM\_PAGE\_SEL[2:0]. The value of 'n' is determined by the ROMPAGING bits. 'OL' refers to the lower 4KB of the 8KB ROM page 0; 'OH' refers to the upper 4KB of that page.

| System<br>Address | IBM MCA<br>8514/A ROM<br>Address | 480 MCA<br>8K ROM<br>Address | ROM<br>Page |
|-------------------|----------------------------------|------------------------------|-------------|
| C6000-C67FF       | N/A                              | 0000-07FF                    | OL          |
| C6800-C6FFF       | 7800-7FFF                        | 0800-0FFF                    | 7H/0H       |
| C7000-C7FFF       | n000-nFFF                        | n000-nFFF                    | n           |
| CA000-CA7FF       | 7000-77FF                        | N/A                          | 7L          |

8514/A and 480 ROM Map (MCA Bus)

| System<br>Address | IBM ISA<br>VGA ROM<br>Address | Typical ISA<br>VGA ROM<br>Address | ROM<br>Page |
|-------------------|-------------------------------|-----------------------------------|-------------|
| C0000-C5FFF       | 0-5FFF                        | 0000-5FFF                         | 0–5         |
| C6000-C67FF       | N/A                           | 6000-67FF                         | 6L          |
| C6800-C6FFF       | 7800-7FFF                     | 6800-6FFF                         | 7H/6H       |
| C7000-C7FFF       | n000-nFFF                     | 7000-7FFF                         | n/7         |
| CA000-CA7FF       | 700077FF                      | N/A                               | <i>7</i> L  |

VGA ROM Map (ISA Bus)



## EXTENDED CONFIGURATION REGISTER 3 (EC3)

Read at I/O Address 5EE8h (Chips Extension) Write at I/O Address 5EE8h (Chips Extension) Byte or Word Accessible



- 3-0 Multifunction Control Register Read Index. These bits indicate which of the Multifunction Control [MFC] index registers will be read by a read access to BEE8h. When a read is performed at BEE8h, the index bits [15:12] are undefined.
- 4 AHRS Alternate High Register Select. This bit controls write access to the Alternate High group of Video Timing Parameter Registers.
  - 0 = Not selected (default)
  - 1 = Selected

This bit is set to initialize the High-Resolution video parameters (1024x768). This would generally only be done once following power-up under the control of the BIOS or a device driver. It may be used to customize the video timing for a specific country or monitor type (eg. non-interlaced vs. interlaced).

Warning: This bit disables write access to the normal video registers. Do not enable select bits AHRS and ALRS simultaneously. Do not leave this bit set after programming the desired video timing registers.

- 5 ALRS Alternate Low Register Select. This bit controls write access to the Alternate Low group of Video Timing Parameter Registers.
  - 0 = Not selected (default)
  - 1 = Selected

This bit is set to initialize the Low-Resolution video parameters (640x480). This would generally only be done once following power-up under the control of the BIOS or device driver. It may be used to customize the video timing for a specific country or monitor type (eg. 72Hz. refresh).

Warning: This bit disables write access to the normal video registers. Do not enable select bits AHRS and ALRS simultaneously. Do not leave this bit set after programming the desired video timing registers.

- AHRE Alternate High Register Enable. This bit enables the alternate High-resolution video timing register set. When this bit is set, a write to the ADVFUNC\_CNTL register with CLKSEL0=1, will select the alternate high registers for use when generating video.
  - 0 = Use normal video registers (default)
  - 1 = Use Alternate High video registers
- ALRE Alternate Low Register Enable. This bit enables the alternate Low-resolution video timing register set. When this bit is set, a write to the ADVFUNC\_CNTL register with CLKSEL0=0, will select the alternate low registers for use when generating video.
  - 0 = Use normal video registers (default)
  - 1 = Use Alternate Low video registers
- 10-8 CLKSEL2:0 Clock Select 2-0. There are three sets of Clock Select bits maintained internally by the 480. One set each for Alternate High, Alternate Low, and normal video register sets. When one of the Alternate Register Select bits is set, then the CLKSEL bits corresponding to that alternate set is visible (read/write) at this location. The default on reset is the normal set. The CLKSEL0 bit of the normal video register

Warning: All writes to this register should be 8-bit. Due to the nature of the control bits in the lower byte, simultaneous writes to the alternate CLKSEL bits would be indeterminate.

**Revision 1.6** 

Preliminary 82C480



set is always read/write accessible in the ADVFUNC\_CNTL register.

- 11 Reserved = 0
- 12 OVERRIDE (default = 1)
  - 0 = Do not override AHRE, ALRE
  - 1 = Force normal video register set

This bit allows an 82C480 custom driver to force the 480 to use the normal video register set. That is, it overrides the Alternate Register Enable bits since it is using a video mode other than 640x480 or 1024x768.

This bit is reset on any write to the ADVFUNC\_CNTL register. This is necessary to avoid improper recovery when a non-standard exit from an application driver occurs. The 480 must always force an unsuspecting program (not a CHIPS 480 driver) to use the Alternate Video Register Set if one is enabled.

The implications of this reset is that if a high resolution device driver which uses OVERRIDE should need to write ADVFUNC\_CNTL, then it must immediately write EC3 to again override the Alternate Register Enable bits.

#### 15-13 Reserved = 0

## CURRENT Y POSITION REGISTER (CUR Y)

Read at I/O Address 82E8h Write at I/O Address 82E8h Byte or Word Accessible



11-0 Y Position = Y coordinate of current position (in pixels). The XY position is relative to the top left corner of the display. Each scan line displays X-coordinates 0 through XMAX - 1. Each screen displays Y-coordinates 0 through YMAX - 1.

15-12 Reserved = 0



## CURRENT X POSITION REGISTER (CUR X)

Read at I/O Address 86E8h Write at I/O Address 86E8h Byte or Word Accessible



11-0 X Position = X coordinate of current position (in pixels). The XY position is relative to the top left corner of the display. Each scan line displays X-coordinates 0 through XMAX - 1. Each screen displays Y-coordinates 0 through YMAX - 1.

Warning: In 5PN mode, bits 11, 1 and 0 are remainder bits; 10:2 are the current X position modulus 5.

15-12 Reserved = 0

### DESTINATION Y POSITION REGISTER AXIAL STEP CONSTANT REGISTER (DESTY AXSTP)

(DESTY\_AXSTP)
Read at I/O Address 8AE8h (Chips Extension)
Write at I/O Address 8AE8h
Byte or Word Accessible



- 11-0 Y-Destination. During BITBLT operations this register is programmed to the destination Y address (measured in pixels).
- 11-0 Axial Step Constant. During line drawing, this register is programmed as the Bresenham constant 2\*dminor (dminor is the length of the line projected onto the minor or dependant axis).
- 12 AXSTPSIGN Sign flag for Axial Step Constant (should be set to 0 during BITBLT operations).
- **15–13** Reserved = 0



# DESTINATION X POSITION REGISTER DIAGONAL STEP CONSTANT REGISTER (DESTX DIASTP)

Read at I/O Address 8EE8h (Chips Extension) Write at I/O Address 8EE8h Byte or Word Accessible



- 11-0 X-Destination. During BITBLT operations this register is programmed to the destination X address (measured in pixels).
- 11-0 Diagonal Step Constant. During line drawing, this register is programmed as the Bresenham constant 2\*dminor 2\*dmajor (dminor is the length of the line projected onto the minor or dependant axis; dmajor is the length of the line projected onto the major or independent axis).
- 12 DGSTPSIGN Sign flag for Diagonal Step Constant (should be set to 0 for BITBLT operations).
- **15–13** Reserved = 0

# ERROR TERM REGISTER (ERR\_TERM)

Read at I/O Address 92E8h Write at I/O Address 92E8h Byte or Word Accessible



- 12-0 Initial Error Term. This register is programmed to the Bresenham initial error term before a line drawing command is issued. Its initial value is set to 2\*dminor dmajor (dminor is the length of the line projected onto the minor or dependant axis; dmajor is the length of the line projected onto the major or independent axis). During the line draw, this register holds the current state of the error term. When bit 12=1, it causes the Bresenham logic to increment the dependant axis (make a diagonal step).
- 15-13 Reserved (R/W)

  These bits are read/write but do not participate in the calculation of the error term.

Revision 1.6 39 Preliminary 82C480



### MAJOR AXIS PIXEL COUNT REGISTER RECTANGLE WIDTH REGISTER (MAJ AXIS PCNT)

Read at I/O Address 96E8h (Chips Extension) Write at I/O Address 96E8h Byte or Word Accessible



- 10-0 Major Axis Pixel Count holds the constant term dmajor for Bresenham line drawing (dmajor is the length of the projection of the line to be drawn along the independent axis). This must be a positive number.
- 10-0 Rectangle Width holds the width of the rectangle (in pixels) for BITBLT and rectangle drawing commands.
- 15-11 Reserved = 0



## GRAPHICS PROCESSOR STATUS REGISTER (GP STAT)

Read at I/O Address 9AE8h Byte or Word Accessible



7-0 Queue State indicates the number of positions available in the queue. The standard 8514/A command queue is eight bytes deep. Queue State is nicknamed the thermometer register. It shows the number of bytes available encoded linearly. Queue State = 0 if the queue is empty; this does not imply that the 82C480 is idle-it may have consumed all of the data in the command queue but still may be executing a drawing command. Always test BUSY to determine if the drawing engine is idle.

### Queue State 76543210

00000000 = 8 words available-queue empty

00000001 = 7 words available

00000011 = 6 words available

00000111 = 5 words available

00001111 = 4 words available

000111111 = 3 words available

001111111 = 2 words available

011111111 = 1 word available

11111111 = 0 words available-queue full

8 DATARDY indicates availability of variable data from the PIX\_TRANS register.

0 = No new data ready

1 = Data is ready to be read from the PIX\_TRANS register. This will occur if a drawing command is

executed with WRTDATA=0 and PCDATA=1. It indicates that the next pixel has been read from the display buffer and may be read from the PIX\_TRANS register.

9 GPBUSY (Graphics Processor Busy)

0 = Not Busy

1 = Busy (currently executing a drawing command).

**15–10** Reserved = 0



### COMMAND REGISTER

(CMD)

Write at I/O Address 9AE8h Byte or Word Accessible



- 0 WRTDATA = Pixel write operation
  - Read operation (line, SSV, or rectangle commands). Commands execute normally except that no writes to memory are performed. This can be used with rectangle commands to copy rectangular blocks of the display bitmap into system memory.
  - 1 = Write operation. VRAM writes are enabled for drawing command.
- 1 PLANAR defines the orientation of the display bitmap for most drawing operations.
  - 0 = Through plane mode
  - 1 = Across plane mode

Some rectangle drawing commands disregard this bit and force Across plane mode for increased speed.

- 2 LASTPIX = Last Pixel Null
  - 0 = Last pixel is drawn
  - 1 = Last pixel is not drawn

For line commands (CMD\_LINE, SSV, or CMD\_LINEAF) the current position (CUR\_X, CUR\_Y) is moved to the end of the line but the last pixel is not drawn. This is used for those mixes (such as XOR) which would produce the wrong color if the

same pixel were drawn twice (e.g. at the end of one polygon segment and at the start of the next segment).

For rectangles, this bit has different effects depending on which rectangle command is issued and also the state of the INC\_X and INC\_Y bits as listed below:

#### CMD RECT

 $IN\overline{C}_X = 0$  Leftmost column not drawn  $INC_X = 1$  Rightmost column not drawn

#### CMD\_RECTV1

 $INC_Y = 0$  Top row not drawn  $INC_Y = 1$  Bottom row not drawn

### CMD\_RECTV2

No effect

### CMD\_BITBLT

INC\_X = 0 Leftmost column not drawnINC\_X = 1 Rightmost column not drawn

- 3 LINETYPE (Vector Enable).
  - 0 = Enable Bresenham line drawing
  - 1 = Enable vector line drawing

When vector line drawing is enabled (LINETYPE = 1) and a CMD\_NOP issued, writes to the SHORT\_STROKE register allow the specified vector to be drawn at the current position. When LINETYPE = 1, and a draw line command (CMD\_LINE) is issued, a vector of length MAJ\_AXIS\_PCNT is drawn in the direction specified by LINEDIR. Lines drawn with LINETYPE = 1 are restricted to 45° angles. Lines of any slope may be drawn using the Bresenham drawing registers (LINETYPE = 0).

- 4 DRAW This bit is the equivalent of a pen up/pen down flag on a plotter.
  - Marking disabled for line and BitBlts. Current position is moved, but no pixels are modified.
  - 1 = Marking enabled.

Note: This bit should be set when attempting to <u>read</u> or write bitmap data.



- 5 INC\_X (X positive) This bit along with INC\_Y (below) determine which quadrant the slope of a line lies within. They also determine the orientation for rectangle draw commands. The upper left corner of the screen is the origin (x,y = 0,0).
  - 0 = Lines are drawn in negative X direction (right to left).
  - 1 = Lines are drawn in positive X direction (left to right).
- 6 YMAJAXIS For Bresenham line drawing commands, this bit determines which axis is the independent or major axis. Bits INC\_X, and INC\_Y define which quadrant the slope falls within; this bit further defines the slope to within an octant.
  - 0 = X is major (independent) axis.
  - 1 = Y is major (independent) axis.
- 7 INC\_Y (Y positive) This bit along with INC\_X (above) determine which quadrant the slope of a line lies within. They also determine the orientation for rectangle draw commands. The upper left corner of the screen is the origin (x,y = 0,0).
  - 0 = Lines are drawn in the negative Y direction (up the screen).
  - 1 = Lines are drawn in the positive Y direction (down the screen).
- 7-5 LINEDIR When a line draw command (CMD\_LINE) is issued with LINETYPE = 1, LINEDIR bits specify the angular direction in which the line is to be drawn (counterclockwise relative to the positive x-axis). The length of the line is determined by the MAJ\_AXIS\_PCNT register.

| LINEDIR | Angular Direction |
|---------|-------------------|
| 000     | 000°              |
| 001     | 045°              |
| 010     | 090°              |
| 011     | 135°              |
| 100     | 180°              |
| 101     | 225°              |
| 110     | 270°              |
| 111     | 315°              |

- 8 PCDATA (Pixel Data Enable)
  This bit is used to indicate that data is to be read/written through the PIX\_TRANS register during the draw / SSV command.
  - 0 = Pixel data transfer disabled
  - Pixel data transfer enabled. The drawing engine waits for read/write of the PIX\_TRANS register for each pixel during a draw operation. Depending on the foreground and background source select bits of the command issued, this data is not necessarily used in determining the actual pixel drawn.
- 9 16BIT 16-bit operation.
  - 0 = PIX\_TRANS register is accessed as an 8-bit register.
  - 1 = PIX\_TRANS register is processed internally as two bytes in the order specified by BYTSEQ (below).

Note: The IBM 8514/A does not handle 8-bit data transfer cycles properly to the PIX\_TRANS register (IN AL,DX or OUT DX,AL). When developing programs which must execute on any IBM 8514/A or compatible, only 16-bit I/O operations should be performed (IN AX,DX or OUT DX,AX) to this register.

#### 11–10 Reserved = 0

- 12 BYTSEQ Byte Sequence affects both reads and writes of SHORT\_STROKE and PIX\_TRANS registers when 16BIT = 1.
  - 0 = Take high byte first
  - 1 = Take low byte first

### 15-13 CMD Draw Command

- 111 = Illegal
- 110 = CMD\_BITBLT (Copy rectangle)
- 101 = CMD\_LINEAF (outline)
- 100 = CMD\_RECTV2 (Fast filled Y direction rectangle)
- 011 = CMD\_RECTV1 (Fill rectangle in Y direction)
- 010 = CMD\_RECT (Fill rectangle in X direction)
- 001 = CMD LINE
- 000 = CMD\_NOP (This should be used when drawing SSVs)



## SHORT STROKE VECTOR TRANSFER REGISTER (SHORT STROKE)

Read at I/O Address 9EE8h (Chips Extension)
Write at I/O Address 9EE8h
Byte Accessible (16BIT=0)
Byte or Word Accessible (16BIT=1)



- 3-0 LENGTH = Length of vector projected onto major axis (this is also the number of pixels drawn). The current position is always moved LENGTH pixels from its starting value. A LENGTH of 0 leaves the current position unchanged.
- 4 SSVDRAW

0 = Don't write pixels

1 = Write pixels

7-5 VECDIR Vector Direction indicates the angle (measured counter-clockwise from horizontal right) at which the line is drawn.

| VECDIR | Angular Direction |
|--------|-------------------|
| 000    | 000°              |
| 001    | 045°              |
| 010    | 090°              |
| 011    | 135°              |
| 100    | 180°              |
| 101    | 225°              |
| 110    | 270°              |
| 111    | 315°              |

15-8 The lower 8 bits are duplicated in the upper 8 bits of the register so that two SSV commands may be issued simultaneously. These vectors are then executed in the order specified by BYTSEQ (CMD[12]).

WARNING: The high byte of SHORT\_STROKE must always be written in order for the command to execute. This means that if a byte write is performed to 9EE8h, it must be followed by a byte write to 9EE9h before the drawing engine will start. This register functions independent of the state of the 16BIT bit.

This is identical to the way in which the IBM 8514/A functions and is duplicated in the 82C480 for compatibility. The IBM Adapter Interface (AI) appears to always communicate with the 8514/A SHORT\_STROKE register using 16-bit I/O instructions.

It is always possible to pad a single SSV instruction with a NUL byte. The drawing engine recognizes an SSV with LENGTH = 0 and SSVDRAW = 0 as a NOP.



# BACKGROUND COLOR REGISTER (BKGD COLOR)

Read at I/O Address A2E8h (Chips Extension) Write at I/O Address A2E8h Byte or Word Accessible



7-0 Background Color. This is the color used for writing pixels where the Foreground Color Mix is selected and FSS=00, or the Background Color Mix is selected and BSS=00.

#### 8-15 Reserved = 0

Warning: The BKGD\_COLOR register is readable at A2E8h only when GPBUSY = DATARDY = 0. Otherwise, during drawing commands, A2E8h returns PIX\_TRANS register data and performs as if a read were made to the PIX\_TRANS register. This is required for IBM compatibility.

The BKGD\_COLOR register is writable at A2E8h whenever GPBUSY = DATARDY = 0 or when PCDATA = 0. Otherwise, during drawing commands with PCDATA = 1, a write to A2E8h functions as a write to the PIX\_TRANS register.

### FOREGROUND COLOR REGISTER (FRGD COLOR)

Read at I/O Address A6E8h (Chips Extension) Write at I/O Address A6E8h Byte or Word Accessible



7-0 Foreground Color. This is the color used for writing pixels where the Foreground Color Mix is selected and FSS=01, or the Background Color Mix is selected and BSS=01.

#### 8-15 Reserved = 0

Warning: The FRGD\_COLOR register is readable at A6E8h only when GPBUSY = DATARDY = 0. Otherwise, during drawing commands, A6E8h returns PIX\_TRANS register data and performs as if a read were made to the PIX\_TRANS register. This is required for IBM compatibility.

The FRGD\_COLOR register is writable at A6E8h whenever GPBUSY = DATARDY = 0 or when PCDATA = 0. Otherwise, during drawing commands with PCDATA = 1, a write to A6E8h functions as a write to the PIX\_TRANS register.



### WRITE MASK REGISTER (WRT MASK)

Read at I/O Address AAE8h (Chips Extension) Write at I/O Address AAE8h Byte or Word Accessible



- **7–0** Write Mask is used to prevent data from being modified in specific planes.
  - 0 = Disable modifying plane
  - 1 = Enable modifying plane
- 15-8 Reserved = 0

Note: WRT\_MASK has some special functions during area fill operations. Refer to the discussion of the PLANEMODE bits with respect to area fill described in the Drawing Operations section of this manual.

## READ MASK REGISTER (RD MASK)

Read at I/O Áddress AEE8h (Chips Extension) Write at I/O Address AEE8h Byte or Word Accessible



- 7-0 Read Mask is primarily used when performing bounded fill operations (PIX\_CNTL[2]=1). RD\_MASK affects the following commands:
  - Fill operations using CMD\_RECT
  - Fill operations using CMD\_BITBLT
  - Reading data in Across Plane Mode

RD\_MASK is used to allow bit planes to participate in any logical or arithmetic mix:

- 0 = Allow plane to be read
- 1 = Prevent plane from being read

The effect of setting Read Mask = 0 for noncontiguous ranges of bits when an arithmetic mix is selected is undefined. This is because carry bits may propagate to bits (planes) which are masked by Read Mask.

Warning: When performing a fill operation with PLANEMODE = 11, this register must contain a non-zero value even though it is not directly used for either the Boundary Mask or the Plane Mask.

15–8 Reserved = 0

Note: RD\_MASK has some special functions during area fill operations. Refer to the discussion of the PLANEMODE bits with respect to area fill described in the Drawing Operations section of this manual.



## COLOR COMPARE REGISTER (COLOR CMP)

Read at ITO Address B2E8h (Chips Extension) Write at ITO Address B2E8h Byte or Word Accessible



7-0 Color Compare defines an 8-bit color which is compared to the destination data during BitBlts. The arithmetic comparison to be used (<,>,=,true,false, etc..) is specified by the COLCMPOP bits of the PIX\_CNTL register (MFC[A][5:3]).

If the result of the comparison is true, the destination data is left unchanged. This is like the transparency concept used by Microsoft Windows, but with two differences:

- 1. The comparison is generalized to include more than just an equality test.
- 2. The comparison is with the destination data, not the source. IBM refers to this type of comparison as underpaint. PLANEMODE and DRAW can affect the Color Compare.

15-8 Reserved = 0



## BACKGROUND MIX REGISTER (BKGD MIX)

Read at IIO Address B6E8h (Chips Extension) Write at IIO Address B6E8h Byte or Word Accessible



4-0 BACKMIX The background mix defines the mix or raster op to be used in drawing operations. It is analogous to the Foreground Color Mix. One of these two mixes is selected for each pixel in the current nugget based on the PIX\_CNTL register. All 16 logical mixes, and five arithmetic mixes (sum, difference, min, max, and average) are supported. Options also exist for sum, average, and difference mixes to

include saturation (no sum can be greater than 0FFh, and no difference can be less than 0). This prevents visually undesirable effects when these mixes are selected.

### 6-5 BSS Background Source Select

| BSS | Source Selected        |
|-----|------------------------|
| 00  | Background Color       |
| 0 1 | Foreground Color       |
| 10  | Pixel data (PIX_TRANS) |
| 1 1 | Bitmap data            |

Pixel data may be supplied pixel by pixel (through plane mode) or nugget by nugget (across plane mode). This permits data transfer between the screen and system memory.

Bitmap data is the source data from the display buffer. The result of doing a line draw or SSV with this source selected is undefined. It is primarily used for BitBlt operations.

#### 15-7 Reserved = 0

NOTE: In the table below, the destination (DST) operand is always the bitmap destination data, but the source (SRC) operand has four possible sources selected by the BSS bits. There are only 30 unique mixes (24–25, and 28–29 are duplicates).

| BACKMIX   | Result            | BACKMIX   | Result                     |
|-----------|-------------------|-----------|----------------------------|
| 0 0 0 0 0 | not DST           | 1 0 0 0 0 | min (SRC, DST)             |
| 0 0 0 0 1 | 0 (false)         | 10001     | DST_SRC with underflow     |
| 0 0 0 1 0 | 1 (true)          | 10010     | SRC-DST with underflow     |
| 0 0 0 1 1 | DST               | 10011     | SRC+DST with overflow      |
| 0 0 1 0 0 | not SRC           | 1 0 1 0 0 | max (SRC, DST)             |
| 0 0 1 0 1 | SRC xor DST       | 1 0 1 0 1 | (DST-SRC)/2 with underflow |
| 0 0 1 1 0 | not (SRC xor DST) | 1 0 1 1 0 | (SRC-DST)/2 with underflow |
| 0 0 1 1 1 | SRC               | 1 0 1 1 1 | (SRC+DST)/2 with overflow  |
| 0 1 0 0 0 | not (SRC and DST) | 1 1 0 0 0 | DST-SRC with saturate      |
| 0 1 0 0 1 | (not SRC) or DST  | 1 1 0 0 1 | DST-SRC with saturate      |
| 0 1 0 1 0 | SRC or (not DST)  | 1 1 0 1 0 | SRC-DST with saturate      |
| 0 1 0 1 1 | SRC or DST        | 1 1 0 1 1 | SRC+DST with saturate      |
| 0 1 1 0 0 | SRC and DST       | 1 1 1 0 0 | (DST–SRC)/2 with saturate  |
| 0 1 1 0 1 | SRC and (not DST) | 1 1 1 0 1 | (DST_SRC)/2 with saturate  |
| 0 1 1 1 0 | (not SRC) and DST | 1 1 1 1 0 | (SRC-DST)/2 with saturate  |
| 0 1 1 1 1 | not (SRC or DST)  | 1 1 1 1 1 | (SRC+DST)/2 with saturate  |

Revision 1.6 48 Preliminary 82C480



## FOREGROUND MIX REGISTER (FRGD MIX)

Read at I/O Address BAE8h (Chips Extension) Write at I/O Address BAE8h Byte or Word Accessible



4-0 FOREMIX The foreground mix defines the mix or raster op to be used in drawing operations. It is analogous to the Background Color Mix. One of these two mixes is selected for each pixel in the current nugget based on the PIX\_CNTL register. All 16 logical mixes, and five arithmetic mixes (sum, difference, min, max, and average) are supported. Options also exist for sum, average, and difference mixes to

include saturation (no sum can be greater than 0FFh, and no difference can be less than 0). This prevents visually undesirable effects when these mixes are selected.

**6–5** FSS Foreground Source Select

| FSS | Source Selected        |
|-----|------------------------|
| 00  | Background Color       |
| 0 1 | Foreground Color       |
| 10  | Pixel data (PIX_TRANS) |
| 11  | Bitmap data            |

Pixel data may be supplied pixel by pixel (through plane mode) or nugget by nugget (across plane mode). This permits data transfer between the screen and system memory.

Bitmap data is the source data from the display buffer. The result of doing a line draw or SSV with this source selected is undefined. It is primarily used for BitBlt operations.

### 15–7 Reserved = 0

NOTE: In the table below, the destination (DST) operand is always the bitmap destination data, but the source (SRC) operand has four possible sources selected by the FSS bits. There are only 30 unique mixes (24–25, and 28–29 are duplicates).

| FOREMIX   | Result            | FOREMIX   | Result                     |
|-----------|-------------------|-----------|----------------------------|
| 0 0 0 0 0 | not DST           | 1 0 0 0 0 | min (SRC, DST)             |
| 0 0 0 0 1 | 0 (false)         | 1 0 0 0 1 | DST-SRC with underflow     |
| 0 0 0 1 0 | 1 (true)          | 1 0 0 1 0 | SRC-DST with underflow     |
| 0 0 0 1 1 | DST               | 1 0 0 1 1 | SRC+DST with overflow      |
| 0 0 1 0 0 | not SRC           | 1 0 1 0 0 | max (SRC, DST)             |
| 0 0 1 0 1 | SRC xor DST       | 1 0 1 0 1 | (DST_SRC)/2 with underflow |
| 0 0 1 1 0 | not (SRC xor DST) | 1 0 1 1 0 | (SRC-DST)/2 with underflow |
| 0 0 1 1 1 | SRC               | 1 0 1 1 1 | (SRC+DST)/2 with overflow  |
| 0 1 0 0 0 | not (SRC and DST) | 1 1 0 0 0 | DST_SRC with saturate      |
| 0 1 0 0 1 | (not SRC) or DST  | 1 1 0 0 1 | DST-SRC with saturate      |
| 0 1 0 1 0 | SRC or (not DST)  | 1 1 0 1 0 | SRC-DST with saturate      |
| 0 1 0 1 1 | SRC or DST        | 1 1 0 1 1 | SRC+DST with saturate      |
| 0 1 1 0 0 | SRC and DST       | 1 1 1 0 0 | (DST_SRC)/2 with saturate  |
| 0 1 1 0 1 | SRC and (not DST) | 1 1 1 0 1 | (DST_SRC)/2 with saturate  |
| 0 1 1 1 0 | (not SRC) and DST | 1 1 1 1 0 | (SRC-DST)/2 with saturate  |
| 0 1 1 1 1 | not (SRC or DST)  | 1 1 1 1 1 | (SRC+DST)/2 with saturate  |

Revision 1.6 49 Preliminary 82C480



### MULTIFUNCTION CONTROL INDEX REGISTER

(MULTIFUNC CNTL)
Read at I/O Address BEE8h (Chips Extension) Write at I/O Address BEE8h Byte or Word Accessible



11-0 Multifunction Control Register Data. The MULTIFUNC\_CNTL register is the index to a set of registers at the same address. The INDEX bits are used to determine which of the nine currently implemented registers is being written to. This data field is defined for each of the indexed registers in the pages to follow.

> The 82C480 also allows these registers to be read. The index of the register to read is written to EC3[3:0] (Multifunction Control Register Read Index), then the register data is read from the least significant 12 bits at this register address (BEE8h); bits 15:12 are undefined.

15-12 INDEX indicates which Multifunction control sub-register is currently being written to.

### MINOR AXIS PIXEL COUNT REGISTER (MIN\_AXIS\_PCNT) (MFC[0])

Read at I/O Address BEE8h (Chips Extension) Write at I/O Address BEE8h Byte or Word Accessible



Minor Axis Pixel Count is used to define the height for BITBLT and rectangle commands. The actual height is:

Minor Axis Pixel Count + 1

- Reserved = 011
- 15-12 INDEX = 0000



TOP SCISSORS REGISTER (SCISSORS\_T) (MFC[1])

Read at I/O Address BEE8h (Chips Extension) Write at I/O Address BEE8h Byte or Word Accessible



11-0 Top Scissors is the minimum Y coordinate value for the scissors rectangle.

15-12 INDEX = 0001

LEFT SCISSORS REGISTER (SCISSORS\_L) (MFC[2])

Read at I/O Address BEE8h (Chips Extension) Write at I/O Address BEE8h Byte or Word Accessible



**11–0** Left Scissors is the minimum X coordinate value for the scissors rectangle.



# BOTTOM SCISSORS REGISTER (SCISSORS\_B) (MFC[3])

Read at I/O Address BEE8h (Chips Extension) Write at I/O Address BEE8h Byte or Word Accessible



11-0 Bottom Scissors is the maximum Y coordinate value for the scissors rectangle.

15-12 INDEX = 0011

### RIGHT SCISSORS REGISTER (SCISSORS\_R) (MFC[4])

Read at I/O Address BEE8h (Chips Extension) Write at I/O Address BEE8h Byte or Word Accessible



11–0 Right Scissors is the maximum X coordinate value for the scissors rectangle.



# MEMORY CONTROL REGISTER (MEM\_CNTL) (MFC[5])

Read at I/O Address BEE8h (Chips Extension) Write at I/O Address BEE8h Byte or Word Accessible



1-0 HORCFG This field contains information which the 8514/A uses to determine the X-Coordinate divisor. Bit 0 is used to indicate 5-pixel operation and should only be set if EC2[11] = 1 (the 5PN bit). Bit 1 determines if the VRAMs are interleaved in the horizontal direction. The interleave table results in the following:

| HORCFG | Interleave |
|--------|------------|
| 00     | 4          |
| 0 1    | 5          |
| 10     | 8          |
| 11     | 10         |

HORCFG = 10 always for the IBM 8514/A. For the 82C480, only the last two values, 10 and 11 are of interest.

3-2 VRTCFG specifies the amount by which to divide the Y coordinate internally when addressing different memory configurations. These bits also determine the bank interleave factor in the Y (vertical) direction. These bits are re-interpreted when 1Mbit VRAMs are used to maintain software compatibility with the 8514/A (which uses 256Kbit VRAMs). These bits are related to the number of VRAM banks in the system. The number of installed banks may be determined by reading EC2[9:8] (BANKS).

Writing VRTCFG = 00 (if this does not match the reset value) invokes Pseudo 8-Plane mode (PS8). Writing VRTCFG  $\neq$  00 deactivates PS8 mode.

|        | VRAM | banks |
|--------|------|-------|
| VRTCFG | 256K | 1M    |
| 0 0    | 2    |       |
| 0 1    | 4    | 1     |
| 1 0    | _    | 2     |
| 1 1    | _    | 4     |

VRTCFG = 01 is the 8514/A standard value (4 banks either 4-planes or 8-planes deep).

VRTCFG = 1x is used for extended resolutions beyond 1024x768.

4 BUFSWP is used to select planes when in Pseudo 8-plane mode:

0 = select buffer 0 (lower 4 planes) 1 = select buffer 1 (upper 4 planes)

BUFSWP = 0 always when not in Pseudo 8-plane mode.

11-5 Reserved = 0



# FIXED PATTERN LOW REGISTER (PATTERN\_L) (MFC[8])

Read at I/O Address BEE8h (Chips Extension) Write at I/O Address BEE8h

Byte or Word Accessible



4-0 Mask Low is used to select the mix on a pixel by pixel basis. If MIXSEL = 01, then the pattern registers are used to select foreground or background mix. Mask Low applies to even numbered nuggets (0 is leftmost on the screen); Mask High is applied to odd numbered nuggets.

0 = select BACKMIX 1 = select FOREMIX

The bits are in left to right order as they would appear on the display:

D4 = pixel 0 (within a nugget)

D3 = pixel 1

D2 = pixel 2

D1 = pixel 3

D0 = pixel 4 (if 5PN mode)

11-5 Reserved = 0

15-12 INDEX = 1000

# FIXED PATTERN HIGH REGISTER (PATTERN\_H)

(MFC[9])

Read at I/O Address BEE8h (Chips Extension) Write at I/O Address BEE8h Byte or Word Accessible



4-0 Mask High is used to select the mix on a pixel by pixel basis. If MIXSEL=01, then the pattern registers are used to select foreground or background mix. Mask High applies to odd numbered nuggets (0 is leftmost on the screen); Mask Low is applied to even numbered nuggets.

0 = select BACKMIX

1 = select FOREMIX

The bits are in left to right order as they would appear on the display:

D4 = pixel 0 (within a nugget)

D3 = pixel 1

D2 = pixel 2

D1 = pixel 3

D0 = pixel 4 (if 5PN mode)

11-5 Reserved = 0



# PIXEL CONTROL REGISTER (PIX CNTL) (MFC[A])

Read at I/O Address BEE8h (Chips Extension) Write at I/O Address BEE8h Byte or Word Accessible



 $\mathbf{0}$  Reserved =  $\mathbf{0}$ 

### 2-1 PLANEMODE

0 0 = Normal Operation

0.1 = Indeterminate

- 1 0 = Fill area using RD\_MASK as boundary mask. Does not fill second edge of boundary. Plane Mask is a mixture of RD\_MASK and WRT\_MASK.
- 1 1 = Fill area using WRT\_MASK as boundary mask. Does fill second edge of boundary. Plane Mask is WRT\_MASK (although RD\_MASK must be non-zero for correct operation).

Note: For a complete description of area fill and the interactions of the PLANEMODE bits and masks, refer to the Area Fill discussion in Drawing Operations.

5-3 COLCMPOP (Color Comparison Operation)
These bits determine the comparison operation performed on each pixel.

#### **COLCMPOP Operation** 000 **False** (always write DST) 0 0 1 True (never write DST) DST >= COLOR\_CMP 0 1 0 < COLOR\_CMP ≠ COLOR\_CMP 0 1 1 DST 100 DST 1 0 1 DST = COLOR\_CMP 1 0 DST <= COLOR\_CMP 1 1 1 DST > COLOR CMP

7-6 MIXSEL (Mix Select)

 $0 \ 0 = FOREMIX$  is always used

0 1 = PATTERN\_L,PATTERN\_H select mix. (1 = FOREMIX, 0 = BACKMIX)

1 0 = Variable pixel data (from PIX\_TRANS) selects the mix (1 = FOREMIX, 0 = BACKMIX).

1 1 = SRC selects the mix (used to implement transparency during a BITBLT command).

11-9 Reserved = 0



## PIXEL DATA TRANSFER REGISTER (PIX TRANS)

Read at I/O Address E2E8h Write at I/O Address E2E8h Byte Accessible (16BIT=0) Byte or Word Accessible (16BIT=1)



15-0 Pixel/Plane Data In through planes mode (PLANAR=0), bits D7:0 and D15:8 map onto bit planes 7:0 of an individual pixel. In across planes mode (PLANAR=1), bits D4:0 and D12:8 map onto pixels 0:4 within a nugget (1 bit per pixel).

The PIX\_TRANS register can be used to allow data reads or writes to the display buffer. It can also be used to apply any arbitrary pattern during BITBLT or LINE drawing operations.

WARNING: The type of data transfer operation performed depends upon the state of the 16BIT bit in the CMD register. The IBM 8514/A actually only functions correctly when 16 bit I/O transfers are performed. The useful data transferred however does depend on 16BIT. That is, if 16BIT=0, then an IN AX,DX reads 8 bits of valid data on the low data bus (AL) and no valid data on the high data bus (AH). Although an IN AL, DX to E2E8h will read the correct data, it does not clear the DATARDY bit and the graphics processor will remain idle until an IN is performed to E2E9h.

The high byte of PIX\_TRANS must always be read/written in order for the command to continue execution. This means that if a byte write is performed to E2E8h, it must be followed by a byte write to E2E9h before the drawing engine will start. This is independent of the state of the 16BIT bit. The effect that the 16BIT bit has is that when 16BIT=1, both high and low bytes written are used (in the order specified by BYTSEQ). If 16BIT=0 however, only the low byte is executed (regardless of the state of BYTSEQ and the data written to E2E9h is ignored). The same is true of the read operation. This means that if a byte read is performed from E2E8h, it must be followed by a byte read from E2E9h before the drawing engine will start again. This is independent of the state of the 16BIT bit. The effect that the 16BIT bit has is that when 16BIT=1, both high and low bytes read are valid data (if BYTSEQ = 1 the high and low bytes are swapped). If 16BIT=0 however, only the low byte is valid data (the data read from E2E9h should be discarded).

This is how the IBM 8514/A functions and is duplicated in the 82C480 for compatibility. The IBM Adapter Interface (AI) always appears to communicate with the 8514/A using 16-bit I/O instructions so the high byte dummy instructions are never needed. If you intend to write code which will work universally, it is probably safest to follow IBM's lead and always set 16BIT=1. If an odd number of pixels need to be written to PIX\_TRANS then the high byte of the last output is discarded. Likewise, when inputing an odd length from the PIX\_TRANS register, the high byte of the final data transfer may be discarded.

Note: For compatibility, this register may also be read at A2E8h and A6E8h during drawing commands.

Revision 1.6 Freliminary 82C480



### 82C480 System Interface

The 82C480 can interface as a slave to 2 different system buses: MCA (Micro Channel) and ISA (Industry Standard Architecture or PC/AT). The 82C480 auto-configures to 8-bit or 16-bit slots on either bus. MCA mode is the default, ISA mode is selected by tying ISA/low.

In either mode, the 82C480 supports I/O reads, I/O writes, memory reads, and interrupts. It does not support memory writes (the only supported memory is ROM), burst mode transfers, matched-memory transfers, 32-bit transfers, or any Bus Master functions. All reads or writes are of the 'Asynchronous-Extended' variety where an I/O Channel Ready signal from the chip controls the length of the cycle.

82C480 registers are mapped into areas which skip around in I/O space (see the IO Map, at the beginning of the register section). However, since PC/AT system boards decode only the lower 10 address bits as 'official' I/O addresses, all internal registers appear at PC/AT I/O address 2E8h. The rest of the address bits appear on the ISA bus, and are necessary for proper register selection, but are "don't cares" for some motherboard peripherals. 8514/A I/O mapping minimizes the impact on the PC or AT.

Only the initialization ROM is memory-mapped, defaulting to the range C8000h-C9FFFh for ISA bus or C6000h-C7FFFh for MCA bus configurations. The display buffer is not memory mapped. The only way to read or write display memory is through the use of 82C480 commands. Control and data registers for such commands are mapped into I/O space.

VGA support is provided by the Micro Channel Video Bus Extension (MCA systems), or the VESA video pass-through connector (ISA systems). In VGA mode, video data and video clock are multiplexed to the 8514/A palette/DAC, and syncs are multiplexed to the 8514/A video connector. In VGA mode, the 8514/A responds to all writes to the VGA palette (3C6h-3C9h); this ensures the 8514/A palette displays the VGA colors correctly. It does not respond to reads of the VGA palette to prevent bus contention.

Operation of the upper 8 data bits on the MCA or ISA bus is controlled by Byte High Enable (BHE/). When the 82C480 is installed on an 8-bit bus, BHE/ is not driven (it is located on the 16-bit connector

extension); an internal pull-up holds BHE/ inactive in this case. The 82C480 will not activate Data\_Size\_16 (DS16/) for word or odd byte transfers if BHE/ = 1. The host will convert word transfers to byte transfers in this case. Internal byte steering logic directs odd-byte data over D7:0 when BHE/ = 1.

The 82C480 may be used without external data transceivers in motherboard applications where 4 mA drive is sufficient, or with transceivers where 24 mA drive is required. It provides RDLO/ and RDHI/ outputs to control the direction of these transceivers.

Bus signals are connected as follows.

| 82C480 Pin | MCA Signal | ISA Signal |
|------------|------------|------------|
| A23:20     | A23:20     | Ground     |
| A19:0      | A19:0      | SA19:0     |
| BHE/       | -SBHE      | -SBHE      |
| AEN        | M/-IO      | AEN        |
| IORD/      | -S1        | -IOR       |
| IOWR/      | -S0        | -IOW       |
| MEMR/      | -CMD       | -SMEMR     |
| MEMW/      | MADE 24    | -SMEMW     |
| IOCS16/    | -CD DS16   | -IOCS16    |
| RDY        | CD CHRDY   | IOCHRDY    |
| RFSH/      | -RFSH      | -RFSH      |
| IRO        | -IRQ9      | IRQ9       |
| RESÈT      | CHRESET    | RESETDRV   |
| ISA/       | -CD SETUP  | Ground     |
| MEMCS16/   | -CD SFDBK  | -MEMCS16   |

#### Micro Channel Interface

Micro Channel mode is selected by default (ISA/pin not grounded). The following Micro Channel signals are not used: ADL/, PREEMPT/, DS16RTN, CHRDYRTN, BURST/, TC/, ARBn, ARB/-GNT (all Bus Master/DMA functions), CHCK/, AUDIO, AUDIO GND, and all 32-bit extended signals. Addresses are latched on the falling edge of CMD/.

POS operations are described later in this document.

## Industry Standard Architecture (ISA) Interface

ISA Mode is selected by tying the ISA/pin low. The 82C480 doesn't decode LA23:17, so SMEMR/ is used instead of MEMR/. SMEMR/ is used only for the ROM; SMEMW/ isn't used. The 82C480 doesn't generate MEMCS16/, so it does not support 16-bit ROM; this is not a serious limitation, because those wanting higher performance can copy the

Revision 1.6 57 Preliminary 82C480



ROM to shadow RAM, which offers higher performance than 16-bit ROM.

The following ISA signals are not used: ALE, LA23:17, CLK, NMI/, DRQn, DACKn, T/C, MASTER/, MEMCS16/, 0WS/. Only SA addresses are used on chip; these do not need to be latched so ALE is unnecessary.

### Extended Industry Standard Architecture (EISA) Interface

EISA is a superset of the ISA bus. To interface the 82C480 to an EISA bus, use the signal connections as described for the ISA bus. No EISA extension to the ISA architecture are supported.

POS Operations are not supported in ISA/EISA mode.

### Queue

To improve performance, the 82C480 provides a write queue (called just the "queue") for all registers at I/O address 8000h or greater. This includes all graphics processor registers. The only registers whose write data is not queued are CRT controller, palette, interrupt, and extended configuration registers. The queue improves efficiency of writing drawing commands and parameters, as well as for Variable Data---data provided to/from the host via the PIX\_TRANS register while executing a drawing command. This is the mechanism whereby data is copied between the bitmap and system memory. Thousands of pixels may be transferred during a single 82C480 command, so a queue is imperative.

Because drawing parameters are queued, changes to these registers (such as changing the drawing color) will not take effect until any drawing operations in progress are finished. This allows parameters to be set for the next command immediately.

The queue is 8 words by 20 bits (16 data, 4 address). A23:15 and A9:0 are decoded to select the queue for writing; A13:10 go into the queue along with the 16 data bits, and are decoded upon leaving the queue to select the destination register.

The GP\_STAT register at 9AE8h is used to poll the status of the read and write queues:

Bits 7:0 of this register is the Queue State (QS) field which shows the number of words available in the queue. Nicknamed the "thermometer" register, it shows the number of bytes available, encoded linearly. QS tells not only that there are words available, but how many; this can reduce the amount of polling necessary. QS = 0 does not imply the 82C480 graphics processor is idle; it may have consumed all the data from the queue but still be executing a drawing command. Always test the GPBUSY bit to determine if the graphics processor is idle.

The "read queue" is only one word, and is used only for Pixel Transfer Data. The Pixel Transfer Data Ready bit (DATARDY) indicates there is data waiting to be read from the PIX\_TRANS register (E2E8h).

### Interrupts

The interrupt request (IRQ) pin supports interrupts on the MCA or ISA bus. IRQ is normally attached to IRQ9 on either the MCA or ISA bus. In MCA mode, IRQ acts as an active-low open-collector output. In ISA mode, IRQ is 3-stated when no interrupts are enabled, it is driven low when interrupts are enabled but not active, and is driven high when interrupts are enabled and active (this is like the EGA/VGA). IRQ9 may be shared with another adapter on the ISA bus if only one has its interrupts enabled at a time. In either case, IRQ has no internal pull-up or pull-down; it relies on the motherboard to pull IRQ to an inactive state.

IRQ has IOL min = -16 mA. While this does not technically meet the ISA or MCA 24 mA spec, the board designer may still want to drive IRQ9 directly, instead of using an external 74LS125 driver.



There are four internal sources of interrupts:

- IRQ3 Idle (GPIDLE): The 82C480 graphics processor is idle and the queue is empty. The GPIDLE interrupt may be used as a substitute for polling of the GPBUSY bit prior to writing a drawing command and parameters. Once the 82C480 is idle, the next command and parameters may be written to the queue at C000h-FFFFh without polling the Queue State bits.
- IRQ2 Queue over/underflow (INVALIDIO): An attempt has been made to write to the queue when no words were available, or to read PIX\_TRANS when no data was ready.
- IRQ1 Write inside scissor rectangle (PICKFLAG):
  The 82C480 has written the display buffer within the Scissor Rectangle while executing a CMD\_LINE, CMD\_LINEAF, CMD\_RECTV1, CMD\_RECTV1, CMD\_RECTV2, the destination phase of a CMD\_BITBLT command or a SSV. IRQ1 is used for picking operations.
- IRQ0 Vertical Blank (VBLNKFLAG): Vertical blanking is active. IRQ0 may be used to synchronize operations (such as scrolling) to the end of the frame.

Each internal interrupt goes active whenever the specified condition is true. The state of the internal interrupts may be read from the corresponding interrupt field in the Subsystem Status Register. However, the IRQ pin will only be activated when the condition becomes active, and only if that particular internal interrupt was already enabled by the corresponding interrupt enable bit in the Subsystem Control Register. To inactivate IRQ, each active internal interrupt must be cleared by writing 1 to the corresponding interrupt reset bit in the Subsystem Control Register. Interrupts may be cleared individually or in combination.



### 82C480 Memory Interface

### **Memory Architecture**

The 82C480 is designed to use 256K or 1M VRAMs only (not DRAMs). Write-Per-Bit and Enhanced Page Mode features are required. The 82C480 uses a 40-bit VRAM data bus. This bus is called the Pixel Bus, and the pins are labeled PxDy where x = 0-4 and indicates the pixel within the nugget (see next section) and y = 0-7 indicates the bit (plane). Each pixel has its own write enable pin (WE4:0/), and each plane is selectively written using the VRAM Write-Per-Bit mask.

The 82C480 uses a packed pixel architecture. Each pixel is stored in a pair of VRAMs; one holds the lower nibble, one the upper nibble. 4-bpp (bit-perpixel) systems are implemented by simply not populating the upper nibble VRAM locations. Because the VRAMs are four bits wide, the smallest number of bits per pixel for the display buffer is 4. However, by using the Plane Read Mask (RD\_MASK), Plane Write Mask (WRT\_MASK), and Palette Mask (DAC\_MASK) registers, you can effectively divide the 4-bpp display buffer into two 2-bpp buffers or four 1-bpp buffers, each with the same resolution as the original 4-bpp buffer. This does not reduce VRAM requirements or increase resolution compared to 4-bpp, but does allow implementing a double-buffered 2-bpp or quadruplebuffered 1-bpp system using the same display buffer as for a 4-bpp system.

The 82C480 has a separate Memory Clock (MCLK) which may be adjusted to match the speed of the VRAMs used. Maximum frequencies are 40 MHz (for 100 ns VRAMs), 32 MHz (120 ns VRAMs), or 25 MHz (150 ns VRAMs). MCLK is asynchronous to Nugget Clock (NCLK), which controls video timing.

### **Nuggets**

At this point, some terms must be defined: a nugget is the fundamental "word" of the 82C480. A nugget is either four or five pixels, depending on the 5 Pixel Nugget (5PN) bit. A double nugget is two nuggets (eight or ten pixels), from the same row and column address of a horizontally interleaved pair of RAM banks. Double nuggets are the basic unit of all 82C480 horizontal video parameters.

Within a nugget, the pixels are "backwards" order. Pixel 0 (the rightmost pixel when the nugget is viewed as a 40 bit word) appears in the leftmost

position on the screen. Pixels 1, 2, 3, and 4 appear in left-to-right order on the screen. In Across-Planes mode, Pixel Transfer Data (PIX\_TRANS) bits appear in the "correct" order. Only the least significant 5 bits of PIX\_TRANS are used; bit-4 controls pixel-0 (the leftmost pixel of the nugget as it appears on the screen), bits 3, 2, 1, and 0 respectively control pixels 1, 2, 3, and 4.

The two halves of a double nugget are referred to as A and B, where A appears to the left of B on the screen. The IBM 8514/A always uses four banks of RAM, organized as two horizontally-interleaved A/B bank pairs. The banks are called 0A, 0B, 1A, and 1B.

The 82C480 may use one, two, or four RAM banks. The 82C480 VRAM banks are named Bank 0, 1, 2, and 3; if a single bank is used it is Bank 0; if two banks are used they are Banks 0 and 1. It can still interleave between banks using just a single pixel data bus, but it can interleave between any two banks, not just between members of an A/B pair. If a single bank is used, of course no interleaving is possible. If two banks are used, Banks 0 and 1 are interleaved horizontally ("horizontally" refers to the location of words from the same row and column address as they appear on the screen). If four banks are used, Banks 0 and 1 are interleaved horizontally on even scan lines, and Banks 2 and 3 are interleaved horizontally on odd scan lines. Banks 0 and 2 or 1 and 3 are interleaved vertically. Banks 1 and 2 or 0 and 3 may interleave cycles when moving diagonally during line drawing operations.

Variable size nuggets allow efficient support of 1280 horizontal resolution. When configured for 1024 horizontal resolution (32-bit nuggets) using eight 1 Mb VRAMs, the longest scan line which can be shifted out of the standard VRAM shift registers is:

By adding two more 1Mb VRAMs (40-bits, or 5 pixels, per nugget), the maximum horizontal resolution is increased to 1280:

Revision 1.6 60 Preliminary 82C480



Variable size nuggets have the following advantages:

- Each VRAM row has exactly 2048 or 2560 (twice 1024 or 1280) pixels; there are no VRAM words wasted.
- 2. Each scan line is aligned to VRAM row boundaries and is totally contained in the VRAM row. There is no need for split buffer VRAMs nor data transfer cycles "on the fly".

### 1Mb VRAM Support

The 82C480 allows a 1024 x 768 system to be implemented with just four 1Mb VRAMs (for 16 colors) or eight (for 256 colors). Supporting 1M VRAMs reduces overall graphics system chip count and board area requirements. Also, the cost per bit of 1M VRAMs is predicted to fall below that of 256K VRAMs.

When using 1M VRAMs, some registers are interpreted differently to maintain register compatibility with the 8514/A.

### Pseudo 8-Plane Mode

When the 8514/A board is configured for minimum memory (512KB) it normally supports four planes at 640 x 480 or 1024 x 768 resolution. Pseudo 8-plane mode (abbreviated PS8 mode) supports eight planes at 640 x 480 resolution, even though only four planes of the display buffer are populated. In this mode, data is stored as two separate 4-bpp buffers at different addresses, but is displayed together with Buffer 0 appearing as the low nibble and Buffer 1 appearing as the high nibble. During drawing operations, the high and low nibble (i.e. Buffer 1 and 0) are written separately, and the color indices and plane masks are left shifted by four bits when drawing the upper nibble. This mode is entered by setting the Y\_Coordinate Divisor (VRTCFG) to 00, and the buffers are selected by setting the Swap bit; BUFSWP = 1 for Buffer 1 or BUFSWP = 0 for Buffer 0. BUFSWP = 0 always when not in Pseudo 8-Plane mode.

Because a nugget normally contains consecutive pixels from the same scan line, the 8514/A requires programming of VRTCFG = 01 (normal) or 00 (pseudo 8-plane mode). The 82C480 interprets the VRTCFG registers to enable Pseudo 8-Plane mode for software compatibility, but it doesn't use VRTCFG to determine the number of VRAM banks.

The 82C480 finds the number of VRAM banks installed by reading strapping options on the CAS3:2/ pins, which are latched into Extended Configuration register EC2[9:8].

Pseudo 8-plane mode is only allowed in medium resolution (640 x 480). The Pseudo 8-plane logic is incorporated in the 82B484 Video Support Chip.

### **Memory Configurations**

The 82C480 supports 20 possible memory configurations, which may be categorized by the type of VRAM (256 Kb or 1 Mb), number of planes (4 or 8), number of banks (1, 2 or 4), and the nugget width (4 or 5 pixels). To simplify things, the configurations are numbered, with up to four characters as follows:

1, 2, or 4: the number of banks (1 bank is only allowed for 1Mb VRAM)

M: if 1 Mb VRAMs are used

W: if 5 pixel nuggets (wide nuggets)D: if 8 planes are used (deep memory)

The following figure summarizes the configurations:

|      | # of  | Nugget   |        | Memory  | # of  | Bitmap |             |
|------|-------|----------|--------|---------|-------|--------|-------------|
| VRAM | VRAM  | Width    | # of   | Config- | VRAM  | size   | Maximum     |
| Туре | Banks | (pixels) | Planes | uration | Chips | (KB)   | Resolution  |
|      |       | 4        | 4      | 2       | 8     | 256    | 512x384x4   |
|      | 2     |          | 8      | 2D      | 16    | 512    | 512x384x8   |
| [    |       | 3        | 4      | 2W      | 10    | 320    | 640x480x4   |
| 256K |       |          | 8      | 2WD     | 20    | 640    | 640x480x8   |
|      |       | 4        | 4*     | 4       | 16    | 512    | 1024x768x4  |
| i '  | 4     |          | 8*     | 4D      | 32    | 1024   | 1024x768x8  |
|      |       | 5        | 4      | 4W      | 20    | 640    | 1280x1024x4 |
|      |       |          | 8      | 4WD     | 40    | 1280   | 1280x1024x8 |
|      |       | 4        | 4*     | 1M      | 4     | 512    | 1024x768x4  |
|      | 1     | 1        | 8*     | 1MD     | 8     | 1024   | 1024x768x8  |
|      |       | 5        | 4      | 1MW     | 5     | 640    | 1280x1024x4 |
|      |       |          | 8      | 1MWD    | 10    | 1280   | 1280x1024x8 |
|      |       | 4        | 4      | 2M      | 8     | 1024   | 1024x768x4  |
| 1 M  | 2     | l        | 8      | 2MD     | 16    | 2048   | 1024x768x8  |
| ľ    |       | 5        | 4      | 2MW     | 10    | 1280   | 1280x1024x4 |
|      |       | i        | 8      | 2MWD    | 20    | 2560   | 1280x1024x8 |
| 1    |       | 4        | 4      | 4M      | 16    | 2048   | 2048x1536x4 |
| 1    | 4     |          | 8      | 4MD     | 32    | 4096   | 2048x1536x8 |
| 1    |       | 5        | 4      | 4MW     | 20    | 2560   | 2560x2048x4 |
|      |       |          | 8      | 4MWD    | 40    | 5120   | 2560x2048x8 |

<sup>\* 8514/</sup>A register-compatible configurations

Note: Maximum resolutions assume a 4:3 aspect ratio (except 1280 x 1024 which is not 4:3 but is in common use). Maximum horizontal resolution is determined as shown on the previous page, by the combined length of the VRAMs serial buffers.

Memory configurations are selected by strapping options on CAS3:2/ (BANKS), WE4/ (5PN), MA8 (1MVRAM), and P4D7 (8PLANE) pins. All options may be connected to jumpers, or overwritten by software to allow user upgrades (see Initialization section). The most common user upgrade would be from a 4-plane to an 8-plane configuration (e.g. 1M



to 1MD); another upgrade might be from a 1024 x 768 adapter to a 1280 x 1024 one (e.g. 1M to 1MW, or 1MD to 1MWD).

Memory configurations 4 and 4D are identical to the 8514/A's base and extended memory configurations, and are compatible with any 8514/A software, whether it uses AI- or register-level commands. Memory configurations 1M and 1MD are similar to 4 and 4D, respectively, except that they use 1Mb VRAMs instead of 256Kb VRAMs which the 8514/A uses. Modes 1M and 1MD would normally be preferable to Configurations 4 and 4D, because 1M VRAMs offer savings in part count, area, and cost. Normally, using 1M VRAMs would require changing several register values. Extra logic has been added to the 82C480 so that Configurations 1M and 1MD use all the same register values as Configurations 4 and 4D, so they are compatible with all 8514/A software, using either AI or registerlevel interface.

Configurations other than 4, 4D, 1M, or 1MD are referred to as Extended Configurations. Extended Configurations in general will require an extended AI or drivers, although some 8514/A drivers will be compatible with some Extended Configurations.

Whenever possible, the 82C480 interleaves VRAM banks to improve performance. VRAMs are designed so that pixels on the same scan line (i.e. same Y-coordinate) map to the same row address; bank interleaving is very effective in the X-direction because interleaved page-mode cycles can be used across a whole scan line (unless interrupted for RAM refresh). Only 1 to 4 scan lines fall in the same row address, so page mode can only be used for one to four consecutive pixels in the Y direction. This makes interleaving much less effective in the Y direction. Bank interleaving is impossible in Memory Configuration 1M and its variations, which use only one bank.

In two-bank configurations, Bank-0 and Bank-1 are interleaved in the X direction on a nugget basis---four or five pixels in Bank 0, four or five in Bank 1, four or five in Bank 0, ...

In four bank configurations, banks are interleaved in both the X and Y direction. Banks interleave 0/1 or 2/3 in the X direction; Banks interleave 0/2 or 1/3 in the Y direction. Banks interleave 0/3 or 1/2 when movement is on a diagonal, such as for Short Stroke Vectors (SSVs).

Configuration 2 and variants are Extended Configurations allowing very low-cost "entry level" 8514/A systems using 256K VRAMs with up to 640

x 480 resolution, and are user-upgradeable to full 8514/A compatibility (Configuration 4 and 4D).

Configuration 4 and 4D are register-compatible to the 8514/A with minimum (512KB) and maximum (1MB) memory configurations, respectively. These configurations allow resolutions up to 1024 x 768. They may be user-upgraded to Configuration 4W or 4WD (1280 x 1024 resolution), but an extended AI or drivers will be required.

Memory Configurations 1M and 1MD are register compatible to the IBM 8514/A in minimum and maximum memory configurations, respectively, but use 4 or 8 1Mb VRAMs instead of 16 or 32 256Kb VRAMs, resulting in board area and cost savings. They support resolutions up to 1024 x 768 (Note: the maximum resolution possible maintaining a 4:3 aspect ratio from a 1024 x 1024 bitmap is 1024 x 768).

Memory Configurations 1MW and 1MWD are extended configurations which support resolutions up to 1280 x 1024. This is also the maximum resolution available in a 2MW or 2MWD memory configuration. Because a 1280 x 1024 resolution implemented in 1 bank would consume all of the video memory for the display, it may be preferred to use the 2 bank implementation. This would leave some off-screen memory which could be used by the AI or extended 8514 driver.

Memory Configurations 4M and 4MD are extended configurations which support resolutions up to 2048 x 1536.

Memory Configurations 4MW and 4MWD are extended configurations which support resolutions up to 2560 x 2048. This is the highest resolution configuration.

### RAM Cycle Types

The 82C480 performs the following types of VRAM cycles:

- 1. Read (page mode)
- 2. Write (page mode)
- 3. Read-modify-write (page mode)
- 4. RAS-only refresh
- 5. Data Transfer

Read, write, and RMW cycles may be bank interleaved. RAS-only refresh and Data Transfer cycles are performed on all banks simultaneously.

All read, write, or RMW cycles start by writing the VRAM Write-Per-Bit register, used to implement bit plane masking. The mask data comes from the Plane



Write Mask register (WRT\_MASK). The VRAM Write-per-Bit registers are written by holding WE3:0/ all active at the falling edge of RAS/, while driving the WRT\_MASK data on the pixel data bus. Note that because the WRT\_MASK is eight bits wide and VRAMs are only four bits wide, some receive the upper nibble of the WRT\_MASK, and some the lower nibble.

There are three sources of VRAM cycle requests:

- 1. Drawing engine (read, write, and RMW)
- 2. CRT Controller (Data Transfer)
- 3. RAM refresh logic (RAS-only refresh)

Data Transfer cycles have highest priority. All CAS/lines go low simultaneously only during a Data Transfer cycle.

RAM refresh cycles have the next highest priority.

Drawing engine cycles have the lowest priority. These cycles always start by writing the VRAM write-per-bit register. Drawing engine operations will be done in a single page-mode cycle, unless one of the following happens:

- 1. RAM row address boundary is crossed by drawing engine; indicated internally by:
  - a. Y Coordinate bit 2 or above changing.
  - b. Y Coordinate register (CUR\_Y) reloaded by host.
  - Y Coordinate register (CUR\_Y) reloaded internally.
  - d. Changing from source to destination phase of Copy Rectangle (CMD\_BITBLT) command. This may happen many times for a large rectangle. Once each time the internal scratch register is filled.
- The WRT\_MASK register is written by the host (requiring new write-per-bit values to be written to the VRAM).
- 3. A Data Transfer and/or RAM refresh cycle interrupts the page-mode operation.



### 82C480 Video Interface

The Video circuitry controls addressing and timing for the VRAM display and memory refresh functions. It handles high or low resolutions in interlaced or non-interlaced display modes with equal ease, and generates programmable sync polarities for controlling different monitor modes.

The hardware is based around 2 principal counters, the Horizontal Counter (HCNT) and the Vertical Counter (VCNT). The values in the Video Registers are compared with these counters to generate Blanking and Sync signals, as well as VRAM Refresh and Data Transfer cycle requests. Two other counters determine Horizontal and Vertical Sync Pulse Widths. There are no interdependencies on Blank and Sync start times.

The Display Control (DISP\_CNTL) register controls whether the Video Circuitry is enabled or reset, and whether interlacing is enabled. It also controls certain memory configuration parameters for display.

#### **Horizontal Timing**

All horizontal timings and register values are in terms of double-nuggets (8 or 10 pixels). The Horizontal Counter indicates the horizontal double-nugget currently being displayed. 0 corresponds to the leftmost actively displayed double-nugget on the screen. The Horizontal Total (H\_TOTAL) register indicates the total length of a single scan line, including horizontal retrace time.

Between 0 and H\_TOTAL, 4 time events are detected:

- 1. 1/2 H\_TOTAL
- 2. Horizontal Blank Start
- 3. Horizontal Sync Start
- 4. Full H\_TOTAL

At 1/2 H\_TOTAL (usually about 2/3 across the active display area), the following occur:

- 1. Refresh Counter Increments (causing a refresh cycle)
- 2. Vertical Counter Increments (if interlace)
- 3. Vertical Sync Width Counter Increments (if interlace and VSYNC is active)

The Horizontal Displayed (H\_DISP) register specifies the double-nugget at which the internal Horizontal Blank (HBLNK) signal begins. HBLNK is ORed with Vertical Blank (discussed below) to form the BLANK output signal. HBLNK continues through the end of the scan line (Full H\_TOTAL).

VRAM Data Transfer Cycles are triggered by the beginning of HBLNK. For standard VRAMs, all Data Transfers are initiated in this manner.

The Horizontal Sync Start (H\_SYNC\_STRT) register specifies the double-nugget at which the output signal horizontal sync (HSYNC) begins. The Horizontal Sync Width (H\_SYNC\_WID) register specifies the width, in double-nuggets, of the HSYNC signal. Using this scheme, an HSYNC may be programmed to start anywhere within a scan line (even at the end), and generate a full pulse width.

Horizontal Sync Polarity (HSYNCPOL), along with Vertical Sync Polarity (VSYNCPOL) bits indicate the current display resolution to the 8514 monitor:

| HSYNCPOL | VSYNCPOL | Resolution |
|----------|----------|------------|
| 0        | 0        | 1024 x 768 |
| 0        | 1        | 720 x 350  |
| 1        | 0        | 640 x 400  |
| 1        | 1        | 640 x 480  |

At Full H\_TOTAL, the scan line ends, and a new one is ready to begin at the left of the screen. The following events take place:

- Refresh Counter Increments (causing refresh)
- Vertical Counter Increments (always)
- 3) Vertical Sync Width Counter Increments (if VSYNC active)
- 4) Horizontal Blank Ends
- Vertical Blank and certain other signals synchronize
- 6) Horizontal Total Counter Resets to Zero

### Vertical Timing

The Vertical Counter indicates the vertical scan line currently being displayed. 0 corresponds to the top actively displayed scan line on the screen.

The Vertical Total register (V\_TOTAL) indicates the total number of scan lines in a single frame, including vertical retrace time.

Between 0 and V\_TOTAL, 3 time events are detected:

- 1) Vertical Blank Start
- Vertical Sync Start
- 3) Full V\_TOTAL

Revision 1.6 Preliminary 82C480



The Vertical Displayed (V\_DISP) register specifies the scan-line at which the internal vertical blank (VBLNK) request signal begins. This signal is synchronized as VBLNK only at the ends of horizontal scan lines (see interlace discussion below). After synchronization, it is ORed with HBLNK to form the BLANK output signal. VBLNK continues through the end of the frame (V\_TOTAL) when it ends synchronously on full H TOT.

The Vertical Sync Start (V\_SYNC\_STRT) register specifies the scan-line at which the output signal VSYNC begins. The Vertical Sync Width register (V\_SYNC\_WID) specifies the width, in scan-lines (or half-scan-lines for interlace) of the VSYNC signal. Using this scheme, a VSYNC may be programmed to start anywhere within a frame (even at the end), and generate a full pulse width.

At Full V\_TOTAL, the frame ends, and a new one is ready to begin at the top of the screen. The following events take place:

- 1) Vertical Blank Ends Synchronous to H\_TOT
- 2) Vertical Total Counter Resets to Zero

In the V\_TOTAL register, bits 11:3 indicate a number of scan lines, multiplied by a scan line modulus defined in the Display Control (DISP\_CNTL) register; bits 2:0 of V\_TOTAL are an adjustment added to the value in bits 11:3 to allow specifying values that are not an even multiple of the scan line modulus. Bits 11:3 are named Vertical Total Base (VTB) and bits 2:0 are named Vertical Total Adjust (VTADJ).

Similarly, bits 11:3 of V\_DISP are named VDB and bits 2:0 are named VDADJ, and bits 11:3 of V\_SYNC\_STRT are named VSB and bits 2:0 are named VSADJ. If the adjust value is larger than the modulus, the timing is disabled. Actual timings are 1 greater than programmed in the V\_TOTAL, V\_DISP, and V\_SYNC\_STRT registers.

The scan line modulus is determined by the Memory Configuration (MEMCFG) and Double Scan (DBLSCAN) bits of the Display Control register, as shown below. MEMCFG is related to the number of banks of 256K VRAMs installed. DBLSCAN = 1 indicates that each scan line is repeated on the display. These values are the same whether 256Kb or 1Mb VRAMs are used; the 82C480 internally corrects for addressing differences with 1Mb VRAMs.

| MEMCFG | DBLSCAN | Modulus | Notes                     |
|--------|---------|---------|---------------------------|
| 0 0    | 0       | 2       | Indicates PS8 Mode        |
| 0 0    | 1       | 4       | Not allowed with 1M VRAMs |
| 0 1    | 0       | 4       | 8514/A (Not PS8 Mode)     |
| 0 1    | 1       | 8       |                           |
| 1 0    | 0       | 6       |                           |
| 1 0    | 1       | 12      |                           |
| 1 1    | 0       | 8       |                           |
| 1 1    | 1       | 16      |                           |

For example, in 640 x 480 resolution,  $V_TOTAL = 418h$ ; which after splitting into separate fields is VTB = 83h (131d) and VTADJ = 0. The scan line modulus = 4. The resulting number of scan lines is 131\*4 + 0 + 1 = 525.

For another example, in 640 x 480 resolution,  $V_DISP = 3BBh$  which can be separated into VDB = 77h (119d) and VDADJ = 3. The resulting scan line on which BLANK/ goes active is 119\*4 + 3 + 1 = 480, just as expected.

Interlace mode is enabled when the Display Control register INTERLACE bit = 1. Interlace does nothing more than enable the Vertical Counter to count half scan lines rather than full scan lines; all values programmed in interlaced mode must be divided by 2 to get the actual value. For true interlacing to occur, V\_TOTAL must be programmed to output an odd number of half scan lines per field.

As an example, in  $1024 \times 768$  resolution V\_TOTAL = 660h, which separates into VTB = CCh (204d) and VTADJ = 0. The resulting number of scan lines per field is (204\*4 + 0 + 1)/2 = 408.5. The total number of scan lines per frame (two fields) is 817.

As a last example, in  $1024 \times 768$  resolution V\_DISP= 5FBh, which separates into VDB = BFh (191d) and VDADJ = 3. The resulting scan line on which BLANK/ goes active is (191\*4 + 3 + 1)/2 = 384.

Horizontal timing occurs on a full scan line basis only. This means that scan lines have an alternating odd/even relationship with the half-scan-line count in alternate frames. That is, in even frames, the first displayed scan line starts when VCNT = 0. In odd frames, the first displayed scan line starts when VCNT = 1.

On top of the very regular VSYNC period, a slightly irregular VBLANK period occurs. Requests for VBLANK occur on a very regular N/2 + 1/2 basis, but they are synchronized only at the ends of horizontal scan lines. This means VBLANK maintains the same odd/even relationship to the half-scan-line count as does the displayed scan lines.

Revision 1.6 65 Preliminary 82C480



This has a side effect that VBLNK for even frames is one scan line longer than VBLNK for odd frames.

#### Refresh Counter

The Refresh Counter is an independent 9-bit counter which increments every half-scan-line (regardless of interlace mode). Every time its value changes, a VRAM memory refresh cycle is triggered, and the counter value is used as the Row Address.

For refresh to occur, this scheme requires the Video Circuitry to be enabled (using DISP\_CNTL[5]). Also, the Horizontal Total register must be loaded with a value such that, with the current Video Clock input frequency, the VRAM refresh requirements are met.

#### **Serial Bus**

Nugget Clock (NCLK) is 1/8 or 1/10 pixel clock (PCLK) frequency, 30 MHz max. It is used by the 82C480 to generate CRT signals HSYNC, VSYNC, and BLANK/.

The 82C480 chipset can select the video clock from up to eight oscillators, using the CLKSEL2:0 outputs. In a pure 8514/A implementation using the 82C480, only CLKSEL0 is needed to select between the 25.175 MHz and 44.9 MHz clocks.

VRAM Serial Clocks (SCLK1:0) and Serial Output Enables (SOE3:0/) are generated by the 82B484 whenever BLANK/ is inactive; the 82B484 compensates BLANK/ for serial data pipeline delays, so the palette receives data and blanking at the same time. SCLK1:0 are stopped during BLANK/, so the next scan line will start on the correct pixel and no VRAM timings will be violated during the data transfer cycle.

There are two basic Video Configurations, A and B. There will of course be variations in external logic, depending on the video frequencies required, and whether the MCA Video Extension or VESA video pass-thru connector (for VGA video) is supported.

Video Configuration A enables data from only one bank at a time and supports video rates up to approximately 125 MHz. Systems using Video Configuration A would normally use the 82B484 Video Support Chip (for video rates up to 80MHz).

All Memory Configurations but 1M and its variants use two shift clocks (SCLK1:0) and four output enables (SOE3:0/). SOE3:0/ drive banks 3 to 0 respectively. SCLK0 drives banks 0 and 2, SCLK1 drives banks 1 and 3; SCLK1 and SCLK0 run 180° out of phase at 1/8 the video frequency (except in

Pseudo 8-Plane mode); each rising edge of SCLK0 or SCLK1 generates four pixels. SOE0/ and SOE1/ also run 180° out of phase, as do SOE2/ and SOE3/. If there are two banks, Banks 0 and 1 are alternately enabled on nugget boundaries. If there are four banks, Banks 0 and 1 are alternately enabled on even scan lines; Banks 2 and 3 are alternately enabled on odd scan lines ("odd" and "even" assume non-interlaced screens and count from scan line 0 at the top of the screen). In Video Configuration A, serial data from all four banks may be bused together.

Configuration 1M and its variants are a special case, because they use only one bank of VRAM. Only four pixels are output each serial clock cycle, so SCLK0 runs at 1/4 VCLK frequency in this configuration only. NCLK runs at 1/8 VCLK as usual. SOE0/ is active the entire active display time; SOE3:1/ and SCLK1 are inactive.

Video Configuration B enables video from banks 0 and 1 (or 2 and 3) simultaneously and supports In this video rates up to about 300 MHz. Configuration, SCLK0 still drives Banks 0 and 2 and SCLK1 still drives Banks 1 and 3, but they run in phase at 1/8 video frequency, each rising edge producing 8 pixels. The shift registers must be 8 bits long and are loaded only every eighth VCLK. SOE3:0/ still drive Bank 3 through 0 respectively. SOE0/ and SOE1/ are active the entire display time on even scan lines, and SOE2/ and SOE3/ are active the entire display time on odd scan lines. In Video Configuration B, serial data from Banks 0 and 2 must be bused separately from Banks 1 and 3 (making the serial data bus 64/80 bits wide).

Video Configuration B may only be used with 2 or 4 banks of VRAM, but Video Configurations are otherwise not related to Memory Configurations. As a practical matter, however, Memory Configurations using 256K VRAMs (2, 4, and their variants) do not support resolutions high enough to require Video Configuration B. Only Memory Configurations 2M, 4M, and their variants are logical candidates for Video Configuration B; and only if you need more than the 80 MHz video rate the 82B484 supports. In these cases you must use ECL for the serial data and clock logic.

The serial data bus is 40 bits wide (80 wide for Video Configuration B) and numbered similarly to the pixel data bus: SxDy, where x is the pixel position in the (double) nugget (x = 0-4) for Video Configuration A and 0-9 for Video Configuration B) and y is the bit position in the pixel (y = 0-7).

Another option is to use a RAMDAC like the Brooktree Bt451/458 in Video Configuration A. These



accept four pixels at time and multiplex them internally. Such a RAMDAC supports video rates well above 80 MHz and eliminates the need for TTL shift registers. Pseudo 8-Plane mode is not supported by the Bt451/458.

### Alternate Video Registers

The 82C480 maintains two alternate video register sets which may be used to support non-standard display parameters when programmed for one of the two standard 8514/A resolutions. They are called the Alternate High Resolution (AHR) and Alternate Low Resolution (ALR) register sets. These alternate video register sets are intended for use at 1024x768 and 640x480 resolutions respectively. Each of the alternate register sets contains its own copy of the following registers and bit fields:

| H_TOTAL        |
|----------------|
| H_SYNC_STRT    |
| H_SYNC_WID     |
| V_TOTAL        |
| V_SYNC_STRT    |
| V_SYNC_WID     |
| DISP_CNTL[2:1] |
| DISP_CNTL[4]   |
| DISP_CNTL[3]   |
| EC3[10:9]      |
|                |

The alternate video registers/bits overlay the I/O locations of the normal registers/bits. The set of registers which is visible to the system is determined by the alternate register select bits (AHRS and ALRS) of register EC3[5:4]. The register set which is active in the 82C480 is determined by the alternate register enable bits (AHRE and ALRE) of register EC3[7:6].

When writing the alternate registers, AHRS and ALRS act as "paging registers" selecting the register sets as follows:

| AHRS | ALRS | Selects                        |
|------|------|--------------------------------|
| 0    | 0    | Normal Registers               |
| 0    | 1    | Alt. Low-resolution registers  |
| 1    | 0    | Alt. High-resolution registers |
| 1    | 1    | Write Protect Video registers  |

The intention is to load the alternate registers only once, for example under control of a config.sys file. This would then allow the 82C480 to override programs which write the IBM 8514/A values directly to the display registers with values tuned for a specific system. This is useful in systems which have monitors capable of displaying non-interlaced 1024 x 768 resolution or systems requiring a higher vertical refresh frequency than the IBM standard.

The alternate registers are activated by the 8514/A CLKSEL[0] bit in conjunction with AHRE and ALRE as follows:

| CLKSEL | AHRE | ALRE | Video Register Active     |
|--------|------|------|---------------------------|
| 0      | X    | 0    | Normal                    |
| 0      | X    | 1    | Alternate Low-resolution  |
| 1      | 0    | X    | Normal                    |
| 1      | 1    | X    | Alternate High-resolution |

The alternate video registers do not normally need to be saved, however they all are read/write accessible when selected.

Note: Extended Configuration register EC3 should only be written in byte mode. This is because EC3 contains the alternate register selects in its low byte, and several alternate register set bits in its high byte. Writing this register as a word value may yield unpredictable results.



### 82C480 Initialization / Configuration

Many aspects of 82C480 operation are configurable. All of these may be selected by hardware strapping options. These strapping options are latched internally at the falling edge of RESET; other functions may be multiplexed over these pins after reset. Options may be set by jumpers; the jumpers are connected to tristate buffers that drive the option pin when enabled by RESOUT/. Most strapping options may be read and written by software, so jumpers may be omitted in favor of a configuration utility. This method combines the best of hardware and software configuration techniques.

Options are defined so that they all default to a simple 8514/A board configuration, making special 82C480 device drivers unnecessary. Extended (non-8514/A) registers are always visible to the system (there is no enable mechanism).

#### Reset

On reset, all 82C480 pins except RESOUT/ are tristated.

8BITDAC, ROMCS/, MA8, WE4/, CAS3:2/, and P4D7:0 latch configuration options at the falling edge of RESET; they have internal pull-ups to insure they default to 1 unless driven low to select the 0. RDHI/ and RDLO/ have 50K pullups to insure the data transceivers do not drive the system bus during reset. ROMCS/, PALRD/, and RAS/ have 50K pullups to insure the EPROM, RAMDAC, and VRAMs remain in the quiescent state during reset. All internal counters are reset when RESET = 1. Software registers are undefined after reset, unless noted otherwise.

A soft reset may be performed using the Subsystem Control register GPCTRL bits. This has the same effect as a hardware reset, except no pins are tristated, counters are not reset, and configuration options are not loaded.

### **POS Operation**

Micro Channel POS\_ID (100h-101h) are mapped to on-board ROM. When SETUP/ is active, reads of 100h or 101h activate ROMCS/ [POSEN/] and force ROM\_PAGE\_SEL[2:0] = 1. This allows any desired POS\_ID to be burned in ROM. Boards without ROM may use tristate buffers enabled by POSEN/ to provide a POS\_ID.

Register 102H, bit 0 (Card Enable) is implemented in the 82C480 itself. Card Enable is read/write accessible and responds only when SETUP/ is low.

POS registers are accessible as byte registers only and are not accessible in ISA mode.

### **Configuration Options**

### 8/16-bit Bus Interface

The 82C480 configures itself for 8- or 16-bit bus operation. This is possible because BHE/ (SBHE/ on ISA bus) is on the 16-bit bus extension, so it is unconnected when the board is in an 8-bit slot. An internal pullup forces the 82C480 BHE/ pin inactive in this case. A0 and BHE/ are interpreted as follows:

| A0 | BHE/ | MCA/ISA Bus<br>Definition | 82C480 Definition |
|----|------|---------------------------|-------------------|
| 0  | 0    | 16-bit transfer           | 16-bit transfer   |
| 0  | 1    | Even byte on D7:0         | Even byte on D7:0 |
| 1  | 0    | Odd byte on D15:8         | Odd byte on D15:8 |
| 1  | 1    | 8-bit adapter             | Odd byte on D7:0  |

### Strapping Option - MCA/ISA Bus

SETUP/ is only used in MCA systems; the bus always drives SETUP/ high during reset. SETUP/ may be grounded to select ISA bus interface. This option may not be read by software.

### Strapping Option - 1M VRAMs

MA8 is only used by 1Mb VRAMs; if it is 1 on reset 1Mb VRAMs are assumed, if it is 0 256Kb VRAMs are assumed. An internal pull-up makes the pin default to 1Mb VRAMs; drive with RESOUT/ to select 256Kb. This option may be read/written at Extension Configuration register EC2[10].

### Strapping Option - Number of VRAM Banks

CAS3/ and CAS2/ are only used in configurations of more than 2 banks, so may be used to indicate the number of VRAM banks installed on the board to the 82C480. Internal pullup resistors maintain high levels on these pins if unconnected or used to drive VRAM chip CAS/ inputs. In a 1 bank configuration, both CAS2/ and CAS3/ are tied low (or to RESOUT/); in a 2 bank configuration, CAS2/ is tied low and CAS3/ is left unconnected; in a 4 bank configuration, CAS2/ and CAS3/ are connected to bank 2 and 3 VRAM chip CAS/ inputs, respectively. The number of VRAM banks may be read/written at



Extension Configuration register EC2[9:8].

The number of VRAM banks should be reflected in the VRTCFG and HORCFG bits of the Memory Control register (MEM\_CNTL). These bits are interpreted differently for 1Mb VRAMs to maintain register compatibility with the IBM 8514/A board. The least significant bit of HORCFG determines whether 4 or 5 pixel nuggets are used. This bit is related to the depth of the VRAM banks, not the number of banks.

|      |      | 256Kb  | VRAM  | 1Mb V  | RAM   |          |
|------|------|--------|-------|--------|-------|----------|
|      |      | Inter- |       | Inter- |       |          |
| VRT- | HOR- | leave  | Total | leave  | Total |          |
| CFG  | CFG  | VxH    | Banks | VxH    | Banks | Notes    |
| 0.0  | 0 X  | lxl    | 1     | n/a    | n/a   |          |
| 00   | 1 X  | 1x2    | 2     | 1x1    | 1     | PS8 Mode |
| 01   | 0 X  | 2x1    | 2     | 1x2    | 2     |          |
| 0 1  | 1 X  | 2x2    | 4     | 1x1    | 1     | 8514/A   |
| 10   | 0 X  | 3x1    | 3     | 2x2    | 4     |          |
| 10   | 1 X  | 3x2    | 6     | 2x1    | 2     | 1        |
| 11   | 0 X  | 4x1    | 4     | n/a    | n/a   |          |
| 11   | 1 X  | 4x2    | 8     | 3x1    | 3     | 1        |

### Strapping Option - 8/6 bit DACs

The IBM 8514/A uses the Inmos IMSG176 palette/DAC, which has 6-bit DACs. Other boards may use 8-bit DACs. Still others may use palette/DACs such as the Brooktree Bt478, whose DACs may function as either 8- or 6-bit, depending on the state of their 8/6 input. The 8BITDAC pin is provided for such DACs. There is no pull-up on 8BITDAC; a pull-up or pull-down must be provided to select 8 or 6 bit operation on reset; the state of 8BITDAC on the trailing edge of reset will be latched, and driven back out after reset. 8BITDAC may be read or set by software at Extended Configuration register EC2[13].

### **Monitor Options**

The 82C480 reads analog video SENSE from LM339 comparators, just as VGA chips do, via the SENSE pin. The 82C480 also reads the Monitor ID bits from the Video Connector via pins MS2:0. SENSE may be read from the Display Status register DISP\_STAT[0]; Monitor ID bits may be read from the Subsystem Status register SUBSYS\_STAT[6:4]. If ROM paging is not used, P4D6 can be tied low and MS2:0 may be connected directly to the the video connector; if the ROM\_PG outputs are used, MS2:0 must be driven by a tristate buffer enabled by RESOUT/. The state of the ROM PAGING bit may be read/written at EC2[6].

### Other Strapping Options

All remaining options are latched from the pixel bus (P4Dy) on the falling edge of RESET. The P4Dy pixel bus allows 8 possible options, of which only 5 (P4D7–P4D3) are currently implemented. Extension bits currently unused are reserved for future definition. Internal pullups default these options to 1.

To select a 0 option, you should drive that pin with a tristate driver (e.g. 74LS244) enabled by RESOUT/. The inputs to these drivers may be grounded for options which will not change, or to jumpers for user selection. For those PxDy lines which are not to be used by the display buffer, 0 options may be selected by driving the pin directly with RESOUT/. All these options appear in the Extended Configuration Registers and may be read and/or set by software.

### Strapping Option - 8 Bit Planes (8BP)

P4D7 = 1 on the falling edge of RESET (default) indicates that 8 planes of VRAM are installed; 0 indicates 4 planes. Emulates the function of a jumper on the 8514/A board. 8PLANE is latched in Subsystem Status register SUBSYS\_STAT[7]. 8BP may also be read or written at Extended Configuration register EC2[7].

### Strapping Option - ROM Size (ROMSIZE)

If P4D5=1 on the falling edge of RESET (default), an 8K ROM address space is decoded in system memory. If P4D5 is driven low with RESOUT/, a 32K ROM address space is decoded. The size of the ROM also effects its base address (see the ROM Base Address description below). ROMSIZE may be read or written at EC2[5]. If ROMCS/ is sampled low at reset, no ROM is mapped into address space.

### Strapping Option - (ROMBASE)

P4D4:3 are latched on the falling edge of RESET to indicate the ROM base address. This configuration option allows all of the ROM address spaces in system memory to be relocated in case of address conflicts. Address conflicts are possible with any number of peripheral adapters. ROMBASE may be read or written at EC2[4:3]. Care must be taken when writing EC2 not to destroy the configuration information contained therein.

| ROMBASE       | 8K MCA | 8K ISA | 32K    |
|---------------|--------|--------|--------|
| 00            | C8000h | C6000h | D0000h |
| 0 1           | D8000h | D8000h | D8000h |
| 10            | C0000h | C0000h | C0000h |
| 1 1 (default) | C6000h | C8000h | C8000h |

Revision 1.6 69 Preliminary 82C480



### 82C480 Pixel Operations

#### Mixes

The 82C480 supports 30 mixes, or raster ops. These are selected by the FOREMIX bits of FRGD\_MIX or the BACKMIX bits of the BKGD\_MIX register, as shown in the table below. In addition to all 16 possible 2-operand logical mixes, there are 14 arithmetic mixes including min, max, average, sum, and difference (either SRC – DST or DST – SRC). Sum, difference, and average may be saturating (i.e. no sum can be greater than FFh and no difference can be less than 0) or allow overflow (sum and average) and underflow (difference). Saturation prevents unexpected visual results. A fixed or variable (supplied by the host) pattern may be applied to any drawing operation.

| MIX             |                   | RESUL   | Т             |              |             |          |     |
|-----------------|-------------------|---------|---------------|--------------|-------------|----------|-----|
| 0h =            | 00000b =          | ~DST    |               |              |             |          |     |
| 1h =            | 00001b =          | 0       |               |              |             |          |     |
| 2h =            | 00010b =          | 1       |               |              |             |          |     |
| 3h =            | 00011b =          | DST     |               |              |             |          |     |
|                 | 00100b =          |         |               |              |             |          |     |
|                 | 00101b =          |         |               |              | /*          | XOR      | */  |
|                 | 00110b =          |         | ^ DS          | T)           |             |          |     |
|                 | 00111b =          |         |               |              |             |          |     |
| 8h =            | 01000b =          | ~ ( SRC | * DS          | T)           | <b>/*</b> ] | NAND     | */  |
| 9h =            | 01001b =          | ~ ( SRC | * ~DS         | ST)          |             |          |     |
|                 | 01010b =          |         |               |              |             |          |     |
|                 | 01011b =          |         |               |              | /*          | OR       | */  |
|                 | 01100b =          |         |               |              | /*          | AND      | */  |
|                 | 01101b =          |         |               |              |             |          |     |
| Eh =            | 01110b =          | ~SRC *  | DST           |              |             | NOD      | 4.1 |
|                 | 01111b =          |         |               |              | /*          | NOR      | */  |
|                 | 10000b =          |         |               |              |             | α-       |     |
|                 | 10001b =          |         |               |              | -           |          |     |
| 12n =           | 10010b =          | SKC -   | DCT.          | WIL          |             | erflow   |     |
| 13n =           | 10011b =          | SKC +   | C De.         | WIL<br>E     | n ove       | riiow    |     |
|                 | 10100b =          |         |               |              | :4h         | - da-fl  |     |
|                 | 10101b =          |         |               |              |             |          |     |
| 1011 =<br>17h = | 10110b = 10111b = | (SRC -  | DOTA          | /2 \<br>/2 . | willi u     | maetia   | JW  |
| 17II =          | 11000b =          | DOT -   | DOI <i>) </i> | '            | willi U     | mto      | w   |
| 1011 =          | 11000b = 11001b = | DST -   | SDC           | WILL         | h satu      | rato     |     |
|                 | 11001b =          |         |               |              |             |          |     |
|                 | 11010b =          |         |               |              |             |          |     |
|                 | 11100b =          |         |               |              |             |          |     |
| 1Dh =           | 11100b =          | (DST -  | SRC)/         | 2            | with s      | aturate  | •   |
| 1Eh =           | 11101b = 11110b = | (SRC -  | DST)/         | $\tilde{2}$  | with s      | aturat   | •   |
| 1Fh =           | 11111b =          | (SRC+   | DST)          | <sup>2</sup> | with s      | saturate | 9   |
|                 |                   | ·       | //            | _            |             |          | _   |

### **Source Operand Selection**

The destination operand (DST) always comes from the bitmap. However, the source operand (SRC) can come from one of four places based on the Foreground or Background Source Select (FSS or BSS) fields. FSS and BSS are decoded identically, only FSS is shown below:

|     | 6 | 5 | 4 | 3  | 2    | 1  | 0 |
|-----|---|---|---|----|------|----|---|
| FSS |   |   |   | FC | DREM | IX |   |
|     |   |   |   |    |      |    |   |

| FSS | Foreground Source Select        |
|-----|---------------------------------|
| 00  | Background Color (BKGD_COLOR)   |
| 0 1 | Foreground Color (FRGD_COLOR)   |
| 10  | Variable Pixel Data (PIX_TRANS) |
| 1 1 | Bitmap Data                     |

The Background Color (BKGD\_COLOR) and Foreground Color (FRGD\_COLOR) are register values, used to draw in a solid color or pattern of two solid colors.

Pixel Transfer (PIX\_TRANS) is provided by/to the host, one byte per pixel or nugget (see Across Planes vs Through Planes, below). This allows applying any arbitrary pattern to a drawing operation, or copying data to/from system memory.

Bitmap data is from the source rectangle of a CopyRect command. This Source Select should only be used for the CopyRect command; results are undefined for other commands. Bitmap data is commonly referred to as "source" data, but should not be confused with "SRC" data, which is an ALU operand selected by either BSS or FSS. If FSS and BSS = 11, the terms "source" and "SRC" are equivalent.

### Foreground and Background

The 82C480 supports two Source Select/Mix pairs: Foreground and Background. The Foreground Source Select (FSS) is always used with the Foreground Mix (FRGD\_MIX), and the Background Source Select (BSS) is always used with the Background Mix (BKGD\_MIX). The combination of Foreground Source Select and Foreground Mix will be referred to simply as the Foreground; the combination of Background Source Select and Background Mix will be referred to as the Background. There are also registers for the Foreground Color (FRGD\_COLOR) and





Revision 1.6 71 Preliminary 82C480



Background Color (BKGD\_COLOR); these are not associated with the Foreground and Background mix. The Foreground Mix may select either Foreground Color or Background Color, and similarly for the Background Mix. It is observed that the AI associates the Foreground Color with the Foreground and the Background Color with the Background, but as far as the operation of the hardware is concerned, "Foreground Color" and "Background Color" are just words used to distinguish between the two color registers.

Whether the Foreground or Background is used is determined on a pixel-by-pixel basis; even though the Memory Controller operates on four or five pixels at a time, each pixel Arithmetic Logic Unit (ALU) can independently use the Foreground or Background.

### Foreground Select Mode

In one further level of indirection, there are four possible methods of selecting Foreground vs. Background, selected by the mix select (MIXSEL) bits (PIX\_CNTL[7:6]). MIXSEL applies to all ALUs.

### Mix Select Mode (MIXSEL):

- 0 0 = Foreground is always used (most common value)
- 0 1 = PAT\_L/PAT\_H select Foreground (1 selects FRGD\_MIX)
- 1 0 = VAR (Variable datá) selects Foreground (1 selects FRGD\_MIX)
- 1 1 = Transparency selects Foreground

If MIXSEL = 00 (most commonly used option), the Foreground is always selected.

If MIXSEL = 01, PATTERN\_L (PAT\_L) and PATTERN\_H (PAT\_H) select Foreground. PAT\_L and PAT\_H are both nugget-wide registers; PAT\_L for even-numbered nuggets (starting with nugget 0 at the left of the screen), and PAT\_H for odd-numbered nuggets. Bits (0),1, 2, 3, and 4 of PAT\_L and PAT\_H control pixels (4),3, 2, 1, and 0 of the nugget, respectively (5PN=1). These allow applying a fixed destination-aligned pattern. It may be a pattern of the Foreground and Background Color, or a pattern of Foreground and Background Mixes. To apply a 2D pattern, PAT\_L and PAT\_H must be reloaded on each scan line; there is no interrupt mechanism to prompt for reloading.

If MIXSEL =10, PIX\_TRANS selects Foreground. PIX\_TRANS is the variable data from the host. Bits 0,1, 2, 3, and 4 control pixels 4, 3, 2, 1, and 0 of each destination nugget respectively. This operation is described as 'across the planes'.

If MIXSEL = 11, transparency selects Foreground. Transparency is 1 (true) if source data = 1 for every bit where RD\_MASK = 1. RD\_MASK is rotated right one bit for purposes of transparency comparisons. This is to allow the RD\_MASK to specify different planes for transparency and area filling operations. If transparency is true, the Foreground is selected; otherwise the Background is selected. Source data is stored in the scratch register during the bitblt (see next section); the result of the transparency test is stored in place of bit 7 of the source.

MIXSEL = 11 is used to allow "source transparency". Typically, one bit plane is designated as the transparency plane. If that bit is 1, the destination is left unmodified. Visually, the source data appears "transparent" for that pixel (i.e. after copying the source, you still see the old destination data at that pixel).

Should you select MIXSEL = 11 and FSS and/or BSS = 11 (SRC is bitmap data), you would expect to see the source data written to the destination at all the appropriate places. This is not quite what happens, because the foreground select bit overwrites bit 7 of the source, so instead of seeing the source written to the destination, you see the source with bit 7 modified.

MIXSEL = 11 is also used to do a stretch blt--i.e., a bitblt where the source data is stored in only one plane, and during the course of the bitblt it is expanded to eight planes. This is done by selecting (for example) MIXSEL = 11, FSS = 01, FOREMIX = 7, BSS = 00, BACKMIX = 7, and RD\_MASK = 01h. In this case, the source is a monochrome image stored in plane 7 (selected by RD\_MASK>>1 = 80h); every pixel where bit 7 = 1, is drawn in Foreground Color, and every pixel where bit 7 = 0 is drawn in Background Color.

Stretch blts are used for drawing bitmapped characters. Character fonts may be cached with a different character in each plane to conserve memory, and then drawn in the current foreground color. By selecting the mixes, the character cell may be opaque (i.e. Foreground or Background Color) or transparent.

### Color Comparison

The 82C480 can do a magnitude comparison of the destination data to a fixed reference color, stored in the Color Comparison register (COLOR\_CMP). If the comparison is true, the destination is left unchanged; if false, the drawing operation operates normally. The effect is that the certain color(s) in the destination (i.e. "background") appear in front of the source (i.e. "foreground"). IBM refers to this operation as underpainting, meaning that the source pixels appear to be painted under the destination data

Note that Color Comparison compares the destination data to a reference color; this is different than transparency (above), which tests the source data; the 82C480 does both.





† This Mix comes from one of the 5 individual pixel mixes shown in the diagram on the previous page.



The type of magnitude comparison between COLOR\_CMP and DST is determined by the COLCMPOP bits of the Pixel Control register (PIX\_CNTL[5:3]), as defined below:

**COLCMPOP** 

| 5 4 3 | Comparison        | Notes        |
|-------|-------------------|--------------|
| 0 0 0 | 0                 | Always false |
| 0 0 1 | 1                 | Always true  |
| 0 1 0 | $DST >= C\_CMP$   | -            |
| 0 1 1 | $DST < C\_CMP$    |              |
| 1 0 0 | $DST \neq C\_CMP$ | Not equal    |
| 1 0 1 | $DST = C\_CMP$    |              |
| 1 1 0 | DST <= C_CMP      |              |
| 1 1 1 | $DST > C\_CMP$    |              |

By selecting the proper mixes, the Color Comparison logic can implement a Color Exchange operation: all pixels of a specified color are replaced by a different color. This Color Exchange will be done on a rectangle defined by the Clipping Rectangle, or on a Polygon, as defined in <u>Polygon Fill</u>.

#### Plane Masks

The 82C480 has two host-writeable 8-bit plane mask registers: Plane Read Mask (RD\_MASK) and Plane Write Mask (WRT\_MASK). The 82C480 generates a third, the Plane Mix Enable (PME) under control of the PLANEMODE bits (PIX\_CNTL[2:1]). If PLANEMODE = 10, PME = WRT\_MASK \* ~RD MASK; else PME = WRT\_MASK.

A 0 in WRT\_MASK always prevents writing the corresponding plane in memory, using the VRAM write-per-bit capability. A 0 in PME always prevents the corresponding planes from taking part in any mix (i.e. raster op); results are not specified for arithmetic mixes where a non-contiguous set of planes is enabled by PME.

The function of RD\_MASK is more complicated:

During variable data read cycles, RD\_MASK can determine which planes are read by the host depending on the value of the PLANEMODE bits. If PLANEMODE = 00, then the RD\_MASK register has no effect on the data transfer. This is useful for reading the entire bitmap in Through Plane mode (PLANAR=0). If PLANEMODE = 10 or 11, the pixel data returned should be read back in Across Plane mode (PLANAR=1). The RD\_MASK is rotated right one bit and a logical test is performed between the rotated RD\_MASK and bitmap data. Those pixels which have 1s in all planes where rotated RD\_MASK = 1 return a 1. Because the data is returned in Across Planes mode, the drawing

engine is moving one nugget at a time and the data read back will be nugget aligned. This is useful for reading just one plane or color pattern.

In the read phase of a Copy Rectangle (CMD\_BITBLT) command, when MIXSEL = 11 (Bitmap data selects Foreground), RD\_MASK selects which planes to use to determine if the source is transparent. Those pixels which have 1s in all planes where RD\_MASK = 1 are transparent. Plane 7 in the Scratch Register (see below) is used to store the transparency result, so only 128 colors are available when doing this operation.

In both cases above, RD\_MASK is rotated right one bit before being used.

During Polygon Fill, the PLANEMODE bits determine the Boundary Mask. The Boundary Mask selects which plane(s) will describe the boundary of the polygon. Pixels which have 1s in all planes where RD\_MASK = 1 are boundary pixels. In this case, RD\_MASK is not rotated. RD\_MASK bit Functions:

|            | Enabled Plane      |              |  |  |
|------------|--------------------|--------------|--|--|
| RD MASK    | Variable Data Read | Polygon Fill |  |  |
| 0000 0001b | 7                  | 0            |  |  |
| 0000 0010b | 0                  | 1            |  |  |
| 0000 0100b | 1                  | 2            |  |  |
| 0000 1000b | 2                  | 3            |  |  |
| 0001 0000b | 3                  | 4            |  |  |
| 0010 0000b | 4                  | 5            |  |  |
| 0100 0000b | 5                  | 6            |  |  |
| 1000 0000b | 6                  | 7            |  |  |

The following table shows the mask values for the two area fill operations:

| PIX_CNTL<br>[2:1] | Boundary<br>Mask | Plane<br>Mask         |
|-------------------|------------------|-----------------------|
| 1 0               | RD_MASK          | WRT_MASK * (~RD_MASK) |
| 11                | WRT_MASK         | WRT_MASK              |

#### Across Planes vs. Through Planes

In Pixel Data write mode (PCDATA = WRTDATA = 1), the 82C480 will stop before drawing each pixel (or nugget) for the host to write data in the Pixel Data register (PIX\_TRANS). In Pixel Data read mode (PCDATA = 1, WRTDATA = 0), the 82C480 will stop after reading each pixel (or nugget) for the host to read data from PIX\_TRANS. PCDATA = 1 applies to all drawing operations, including lines and short stroke vectors. This allows drawing lines using any arbitrary user-defined line pattern.



When PCDATA = 1, Pixel Data may be read/written across planes (AP) or through planes (TP).

In TP mode (PLANAR = 0), PIX\_TRANS is interpreted as an 8-bit value representing all eight planes of a single pixel. When doing bitblts in this mode, the 82C480 handles data just one pixel at a time, not one nugget at a time.

In TP pixel data read mode (PLANAR = 0, PCDATA = 1, WRTDATA = 0), the drawing engine waits to write the source pixel to PIX\_TRANS before moving on to the next pixel. If necessary, it will wait for the host to read the last pixel from PIX\_TRANS.

In TP pixel data write mode (PLANAR = 0, PCDATA = WRTDATA = 1), the drawing engine waits to receive a new PIX\_TRANS byte from the queue before drawing each pixel. What effect PIX\_TRANS has on the pixel operation is determined by the mix select (MIXSEL) field (PIX\_CNTL[7:6]), and the mix registers (FRGD\_MIX and BKGD\_MIX). It is entirely possible that PIX\_TRANS has no effect on the pixel operation at all, but the drawing engine still must receive pixel data from the host before it will proceed.

In AP mode (PLANAR = 1), PIX\_TRANS is interpreted as a four/(five) bit quantity, where each bit controls one pixel. PIX\_TRANS bits (0),1, 2, 3, and 4 control pixels (4),3, 2, 1, and 0, respectively. WRT\_MASK can be used to control which bit planes are modified. AP mode should not be used with line draw and SSV commands, because these commands inherently operate on pixels, while AP mode works on nuggets, and results are difficult to predict.

In AP pixel data read mode (PLANAR = PCDATA = 1, WRTDATA = 0), PIX\_TRANS bits (0)/1 through 3 contain the transparency result of pixels (4)/3 through 0 of the last nugget read. The Plane Read Mask (RD\_MASK) register can be used to select which planes participate in the transparency test.

In AP pixel data write mode (PLANAR = PCDATA = WRTDATA = 1), each of PIX\_TRANS bits (0)/1 through 3 selects foreground/background for pixels (4)/3 through 0 of the current nugget if MIXSEL =10. If MIXSEL  $\neq$  2, PIX\_TRANS has no effect on pixel operations, but the drawing machine still waits for a new PIX\_TRANS byte before proceeding.

To improve performance in either AP or TP modes, PIX\_TRANS data may be read/written two nuggets or pixels at a time by selecting 16-bit mode (\_16BIT = 1). In this mode, PIX\_TRANS is treated as a 16-bit register, and needs to be read/written only half as

often.

Also to improve performance, writes to PIX\_TRANS are queued; this allows writing up to 8 pixels (16 if \_16BIT = 1) in advance. Reads from PIX\_TRANS are not queued. See separate <u>Queue</u> section for details of Queue operation.

#### Scratch Register

During the source phase of a Copy Rectangle (CMD\_BITBLT) command, up to eight nuggets are read into the Scratch Register. Nuggets are read using page mode (bank-interleaved page mode if there are two or four banks). Pixel alignment is done as the data is written into the scratch register. If the source is nugget-aligned, all reads are done in nugget mode; if the source is not nugget-aligned, the edges are read in pixel mode, and the interior is read in nugget mode.

During the destination phase of the Copy Rectangle command, data is read from the scratch register, combined with the destination data as specified by the FOREMIX or BACKMIX, and written back to the destination address. If the Mix is a function of the destination data, page-mode RMW cycles are used, otherwise simple page-mode write cycles are used. If the destination is nugget-aligned, all writes are done in nugget mode; otherwise the edges are written in pixel mode and the interior of the rectangle is written in nugget mode.



## 82C480 Drawing Operations

The 82C480 supports 6 different drawing algorithms, including 2 for lines and 4 for rectangles. These algorithms define the motion from the current XY position, and are executed in the "drawing engine" circuitry. Other circuitry, the ALU, selects whether certain pixels or image planes are written, which color is written, etc. Marking of pixels takes place only inside the scissor rectangle; the drawing operation proceeds even outside the rectangle, but WE4:0/ are inhibited so no pixels are marked. (The scissor rectangle is defined by the XY coordinates programmed in the four SCISSORS registers).

The choice between Through Planes and Across Planes modes is important for the execution of the drawing algorithms. In general, TP mode is needed only to copy data between system memory and the bitmap. TP mode is relatively slow, requiring that each pixel be accessed in its own VRAM cycle. Most algorithms work faster in AP mode, since a whole nugget (32 or 40 bits) may be accessed in a single VRAM cycle.

The drawing engine can take advantage of AP mode by invoking "nugget" mode. In this mode, the current X coordinate (CUR\_X) can be moved a whole nugget in one machine cycle (a "machine cycle" is the basic cycle of the geometry state machine). "Pixel" mode requires 4 machine cycles for a nugget (even though the entire nugget could be written in one VRAM cycle). Some algorithms (Fast Fill and the Source pass of the Copy Rectangle) assume nugget mode, whereas others invoke it only when appropriate.

The selection of Pixel Data, using the PCDATA bit, controls the geometry engine only. It causes VRAM accesses to be limited by the transfer rate of Pixel Data across the system bus. That is, one byte of Pixel Data enables 1 VRAM access (either pixel or nugget!). PCDATA does not control whether Pixel Data is used as an ALU control or data source! The Mix (FRGD\_MIX, BKGD\_MIX) and Pixel Control (PIX\_CNTL) registers control these aspects.

Note that AP Pixel Data mode for Bresenham lines is tricky if not impossible to implement. This is because each new byte of Pixel Data triggers one VRAM memory cycle. Since every Bresenham "bump" to a new scan line requires a new memory cycle, and since it is difficult to determine how many pixels will appear on each scan line, it is difficult to

synchronize AP Pixel Data bytes with Bresenham drawing. Instead use TP mode.

Command Port bits INC\_X and INC\_Y effect the starting corner of the rectangle/line. If neither is set, the starting corner is the lower right. If INC\_Y is set and INC\_X is not, drawing starts in the upper right corner. All algorithm discussions below assume both bits are set, and drawing starts in the upper left corner.

#### Line

The 82C480 Line command uses the Bresenham algorithm. Bresenham, like most Digital Differential Analysis (DDA) algorithms, first determines the major or independent axis (if the line were projected onto the X and Y-axis, the independent axis is the one with the longer projection). The major axis coordinate (X or Y) is the independent coordinate. The slope of the line is calculated for the other (dependent) coordinate as a function of the independent coordinate. For each pixel drawn the algorithm increments (or decrements) the independent coordinate, and adds the slope to the dependent coordinate, and if the fractional remainder (the error term) is greater than 0.5, the dependent coordinate is incremented; otherwise it stays the same.

The method above requires a division to compute the slope. This division can be avoided, however, since the algorithm is unaffected by multiplying by a constant.

The algorithm may be expressed by the C pseudocode on the following page. The major axis is indicated by the 82C480 Y Major Axis (YMAJAXIS) bit; if YMAJAXIS = 1, Y is the major axis. Before drawing the line, the image space is decomposed into eight octants, and the octant in which the line is drawn is encoded by the INC\_Y, YMAJAXIS, and INC\_X bits (CMD[7:5]).

#### SSV Drawing

Short Stroke Vector (SSV) is another line drawing function. SSV involves much less overhead than Line Draw (CMD\_LINE); only one byte is required per vector, compared to four (or more) 16-bit words per vector if drawn by the Line command. Two SSVs may be generated with a single 16-bit write to the SSV Register. This lends itself well for character/text drawing.



```
/* 82C480 Implementation of Bresenham algorithm.
  The following registers must be initialized by software before issuing a CMD_LINE command:
     CUR X
                                             Initial x-axis coordinate
     CUR_Y
                                   =
                                             Initial y-axis coordinate
     MAJ_AXIS_PCNT
                                   =
                                             Length of line projected onto major axis (dmajor)
     DESTX_DIASTP
DESTY_AXSTP
ERROR_TERM
                                              2*dminor – 2*dmajor
                                   =
                                   =
                                              2*dminor
                                             2*dminor – dmajor
          Where:
                    dminor
                                             length of minor axis projection
                                    =
                    dmajor
                                             length of major axis projection
     CMD_LINE()
     int xstep,ystep;

if (INC_Y) {ystep = 1} else {ystep = -1}

if (INC_X) {xstep = 1} else {xstep = -1}

for (i=0; i < MAJ_AXIS_PCNT; i++)
```

/\* Plot the pixel at the current x,y position \*/

/\* Make a diagonal step \*/

```
}
    }
When using SSVs, the Command Register must first
be set for no drawing command (CMD_NOP) and
Short Stroke Vectors Enabled (LINETYPE = 1).
LASTPIX and BYTSEQ Command Register bits are
used by the SSV command. After the Command
Register is set, a series of SSV drawing orders may
be written to the SHORT_STROKE Register. This
series may be padded with Null SSV bytes (all 0's).
```

CUR\_X += xstep; /\* Make a diago CUR\_Y += ystep; ERROR\_TERM += DESTX\_DIASTP;

plot(CUR\_X,CUR\_Y);

if  $(ERROR\_TERM > 0)$ 

else

Each SSV specifies a length (0 to 15 pixels), a direction (multiple of 45°), and a bit to indicate whether the SSV is drawn (visible) or not (invisible).

In all SSVs, the Current Position (CUR\_X,CUR\_Y) is moved from the starting position to a position which is N pixels (Length) away from the starting position, in the direction specified. A length of "0" will cause no movement. If drawing is not specified (SSVDRAW=0), no writes to memory are performed.

If drawing is specified, writes to memory take place as the current position is moved. The first pixel is always drawn at the Current Position. If LASTPIX is set, N pixels are written. If LASTPIX is not set, N + 1 pixels are written. If LASTPIX = 1 and LENGTH = 0, one pixel is drawn at the Current Position.

See the SSV register description for more details.

#### Rectangle

The 82C480 has one form of bitblt called Copy Rectangle (CMD\_BITBLT), and three forms of rectangle fill called Fast Rectangle (CMD\_RECTV2), Rectangle X (CMD\_RECT), and Rectangle Y (CMD\_RECTV1). Each of these is selected by the Draw Command bits in the Command Register CMD[15:13].



#### Copy Rectangle

The Copy Rectangle (CMD\_BITBLT) command is a 2-pass algorithm used for copying one region of image bitmap memory into another in foreground or background.

In TP mode, it may also be used to conditionally blit system memory data into the Destination rectangle, contingent upon Source rectangle data. This setup would require PLANAR = 0 and MIXSEL = 11. This is not a standard usage of Through Plane mode according to IBM. This usage implies switching between Foreground and Background Mixes (based on Source data), whereas IBM claims TP mode uses only the Foreground Mix!

The first pass of the algorithm reads data from the Source image bitmap rectangle into the scratch register. The motion algorithm used for reading is identical to the Rectangle X algorithm in Across Plane mode (below) taking advantage of Nugget mode when possible. During this pass, pixel data is realigned through a barrel shifter into its Destination Intra-Nugget Pixel Position (INPP) alignment. The ALU is not used in this pass. If Command register DRAW bit (CMD[4]) is clear, Pixel Data may be read from the Source rectangle during this pass, but Across Planes is the only viable format. Data read this way is in the original INPP alignment, not realigned.

The second pass of the algorithm writes data from the scratch register into the Destination rectangle. The ALU is used to mix the Destination data with Pixel Data (if TP = WRTDATA = 1), Fixed Data, or Source Data, as chosen by the Mix. The algorithm used is identical to Rectangle X, using either Across or Through Plane mode. Across Plane mode is the fastest mode, using 1 bit-per pixel Variable Data (if AP = WRTDATA = 1), Pattern Register Data, or Source Data as the Mix select. The Color Comparators may always be used to control Underpaint.

#### Fast Rectangle

CMD\_RECTV2 uses a left-to-right alternating updown sweep algorithm, and always draws a nugget at a time where possible. This is not the fastest rectangle command, but it is the faster of the two Y-direction rectangle commands.

If the left edge of the rectangle is nugget-aligned, drawing starts in nugget mode. Otherwise, drawing starts as follows: drawing starts in pixel mode at the upper-left corner of the rectangle. One pixel at a time is drawn, going to the right until a nugget boundary

is reached; a maximum of three pixels (four for fivepixel nuggets) are drawn this way. Drawing proceeds downwards, drawing one partial nugget at a time until the bottom of the rectangle is reached. The write enables are used to write only the pixels of the nugget that fall inside the rectangle. The Current Position moves right to the next nugget, and drawing proceeds upwards in nugget mode. Drawing continues in nugget mode, alternating up and down directions, until the right edge of the rectangle to be drawn is less than a nugget wide.

If the right edge of the rectangle is nugget-aligned, drawing ends in nugget mode. Otherwise, the right edge is drawn exactly as described above for the left edge; one pixel at a time, until the right edge of the rectangle is reached.

The pixel-mode operations at the left and right edges seem to be required because the 8514/A lacks the logic to detect if the left and right edges of a rectangle both fall within the same nugget.

Fast Rectangle assumes Across Plane operation. The selection of Across Plane or Through Plane modes by the PLANAR Command register bit is ignored.

#### X Rectangle

The Rectangle X (CMD\_RECT) drawing command is used for drawing or reading a rectangle in a horizontal orientation. This may be used in either TP or AP modes. In TP mode, it may be used most effectively for copying Variable Data between system memory and image memory. In AP mode, it is the fastest drawing command for large area fills, since it makes optimum use of page mode. It is also the drawing command used for area fills and floods (see below).

Motion starts in the upper left-hand corner of the rectangle (assuming INC\_X and INC\_Y are set in the command register), and proceeds to the right. Once the right end of the rectangle is reached, the Y position is incremented, and X position is reset to the left edge of the rectangle. Motion then repeats as in the first row, continuing until the whole rectangle is drawn.

When a full nugget (4/5 adjacent pixels aligned on a nugget boundary) can be written, this drawing algorithm will take full advantage of "nugget mode". All 4/5 pixels will be drawn by the drawing engine in one machine cycle. Otherwise, pixels in less than full nuggets (e.g. at the left and right edges or rectangles) will be drawn in "pixel mode", accumulating Write Enables one pixel at a time.



Nugget mode is never used in TP mode, because TP requires one memory cycle per pixel.

#### Y Rectangle

Rectangle Y (CMD\_RECTV1) is used for drawing or reading a rectangle one pixel at a time in a vertical orientation. This type of drawing motion is useful for TP data manipulation, particularly copying Pixel Data between the system memory and bitmap when the data is vertically oriented. While it may be used in AP mode, it offers no speed advantage. Motion starts in the upper left-hand corner of the rectangle (assuming INC\_X and INC\_Y are set in the Command register) and proceeds downward in a 1pixel-wide column. Once at the bottom of the rectangle, the X position is moved right by one pixel, and the Y position is reset to the top of the rectangle. This motion repeats for all columns, and the process continues until the whole rectangle is drawn.

#### Polygon Fill

The 82C480 contains hardware to perform Polygon Fills using the CMD\_RECT command with the proper PLANEMODE bit values. Polygon Fill is defined as filling an arbitrary area using any available mix, where the area is defined by a continuous boundary of the specified boundary color(s). The area may be concave or contain holes, and is filled using an "odd/even" algorithm. The area is filled by setting up a destination rectangle which encloses the polygon, setting PLANEMODE = 1Xb, and performing a CMD\_RECT command. The 82C480 fills the polygon in AP mode, four pixels at a time, at full speed.

Inside detection is done by defining the left edge of the destination rectangle as "outside". For each scan line, each time a pixel of the boundary color is crossed, the inside/outside state is toggled. The 82C480 can handle multiple inside/outside transitions per nugget.

There are two methods of defining the boundary color(s), selected by PLANEMODE bit 0:

If PLANEMODE[0] = 0, the boundary is defined to be those pixels having 1s in all bit positions where there are 1s in the Plane Read Mask (RD\_MASK). The Plane Mask applied during the fill operation is:

Plane Mask = WRT\_MASK \*  $\sim$ (RD\_MASK)

Usually, a single plane would be used to mark the boundary, and if this plane is masked off from the palette, the boundary would be invisible; this limits the system to 128 colors. When filling the polygon,

the left boundary is marked but not the right; this allows producing a filled polygon that is only one pixel wide.

If PLANEMODE[0] = 1, the boundary is defined to be those pixels having 1s in all bit positions where there are 1s in the Plane Write Mask (WRT\_MASK) register. For example, if WRT\_MASK = FFh, the boundary would be marked in color FFh. The Plane Mask applied during the fill operation is:

#### Plane Mask = WRT MASK

When filling the polygon, both the right and left boundaries are overwritten with the selected color. The advantage of this method is it does not require a separate plane to mark the boundary, so it is the only one that works with a 256 color system.

To facilitate drawing outlines of areas, the 82C480 provides an Outline command. This is similar to the Line command, but after drawing the first pixel of the line, it draws a pixel only when the Y coordinate increments. This produces a boundary of the enclosed area which is compatible with the Area Fill algorithm. Area filling may produce the wrong results if the boundary is self-intersecting. Using XOR mix with the Outline command will eliminate some errors, but not all. Careful orientation of the outline commands can ensure a correct result.

There is a variation of the area fill function which may be called the Fill/BitBlt. This allows a BitBlt to be done to the interior of a polygon. The Fill/BitBlt uses the RD\_MASK and WRT\_MASK exactly the same as the standard Fill operation.

#### **Text Modes**

There is no hardware text mode as in the VGA. The AI supports two types of fonts: bitmapped fonts and stroke fonts. Bitmap fonts are stored in system memory as bitmaps, and stroke fonts are stored as a sequence of SSVs. The AI maintains a most-recently-used cache of four fonts of either type in a non-displayed area of the bitmap. If the character is in the cache, it can be drawn by just blitting; if it is not cached, the AI takes care of generating an image of the character and adding it to the cache.



This page was intentionally left blank



## **Application Schematic Examples**

This section includes schematic examples showing how to connect the 82C480 chip. The schematics are broken down into three main groups for discussion:

1) System Bus Interface

82C480 PC/AT (ISA) Bus Circuit Example Interfacing the 82C480 to the PC Bus requires buffering of the data bus (74LS245) and optional connection of an EPROM/ROM. All other connections between the PC Bus and the 82C480 are direct and do not require any additional components. If a 32K ROM is used and paging into an 8K address space is desired, then the Monitor ID bits must be driven onto pins MS2:0 by a 74LS244 or 74LS125.

82C480 Micro Channel Bus Circuit Example Interfacing the 82C480 to the Micro Channel requires buffering of the data bus (74LS245) and optional connection of an EPROM/ROM. If a ROM is used, the ROM addresses need to be latched using 74LS373 octal latches or equivalent. All other connections between the PC Bus and the 82C480 are direct and do not require any additional components. If a 32K ROM is used and paging into an 8K address space is desired, then the Monitor ID bits must be driven onto pins MS2:0 by a 74LS244 or 74LS125.

2) Display Memory Interface

82C480 Memory Configuration A

This is the memory configuration which is most commonly implemented for the lower resolutions supported by the 82C480 (1280x1024 or below). In this configuration, the memory banks are interleaved horizontally and share the same 32/40 bit serial data path.

82C480 Memory Configuration B

This memory configuration is used in high resolution implementations. It allows the highest possible serial data output (64/80 bit per serial clock). This memory configuration is not compatible with the 82C484 support chip.

3) Video Interface

82C480 Video Interface Using an InMOS IMSG176/178 Color RAMDAC

The IMSG176 is used on the IBM 8514/A adapter card. It has a triple 6-bit DAC output and requires a current reference. An IMSG178 may be used to obtain the extended color definition offered by a triple 8-bit DAC output. An LM339 is required for Monitor Sense. Applications implementing 5-pixel nuggets must use a 74F374 to multiplex the 8514 and VGA video data paths.

82C480 Video Interface Using a Brooktree Bt471/478 Color RAMDAC

The Bt471/478 are similar in function to the IMSG176/178. The Bt471/478 are shown using a voltage reference (44-pin PLCC). An LM339 is required for Monitor Sense unless Bt475/477 RAMDACs are used. These RAMDACs implement the voltage comparators internally eliminating the need for the LM339. Applications implementing 5-pixel nuggets must use a 74F374 to multiplex the 8514 and VGA video data paths.





Revision 1.6 82 Preliminary 82C480





Revision 1.6 83 Preliminary 82C480



















This page was intentionally left blank



# 82C480 Electrical Specifications

#### 82C480 ABSOLUTE MAXIMUM CONDITIONS

| Symbol           | Parameter                       | Min             | Max                  | Units |
|------------------|---------------------------------|-----------------|----------------------|-------|
| $P_{D}$          | Power Dissipation               | -               | 0.5                  | W     |
| $v_{cc}$         | Supply Voltage                  | -0.5            | 6.5                  | V     |
| V <sub>I</sub>   | Input Voltage                   |                 | V <sub>CC</sub> +0.5 | V     |
| $v_{o}$          | Output Voltage                  | -0.5            | V <sub>CC</sub> +0.5 | V     |
| T <sub>OP</sub>  | Operating Temperature (Ambient) | -25             | 85                   | °C    |
| T <sub>STG</sub> | Storage Temperature             | <del>-4</del> 0 | 125                  | °C    |

Note: Permanent device damage may occur if Absolute Maximum Ratings are exceeded. Functional operation should be restricted to the conditions described under Normal Operating Conditions.

#### 82C480 NORMAL OPERATING CONDITIONS

| Symbol          | Parameter           | Min  | Тур          | Max  | Units_ |
|-----------------|---------------------|------|--------------|------|--------|
| V <sub>CC</sub> | Supply Voltage      | 4.75 | 5            | 5.25 | V      |
| TA              | Ambient Temperature | 0    | <del>-</del> | 70   | °C     |

#### 82C480 DC CHARACTERISTICS

(Under Normal Operating Conditions Unless Noted Otherwise)

| Symbol                                  | Parameter              | Notes                                            | Min  | Max                  | Units  |
|-----------------------------------------|------------------------|--------------------------------------------------|------|----------------------|--------|
| I <sub>CC1</sub>                        | Power Supply Current   | @40 MHz CLK, 0°C                                 | -    | -                    | mA     |
| I <sub>IL</sub>                         | Input Leakage Current  | Input, Tristate and Bidirectional Pins           | -    | 10                   | uA     |
| *************************************** |                        | $@V_{IL} = -0.5V$ for pins with internal pullups | _    | 300                  | uA     |
| $I_{OZ}$                                | Output Leakage Current | High Impedance                                   | -100 | +100                 | uA     |
| $V_{IL}$                                | Input Low Voltage      |                                                  | -0.5 | 0.8                  | V      |
|                                         |                        | 8BITDAC pin only                                 | 0    | 0.3                  | V      |
| $V_{IH}$                                | Input High Voltage     |                                                  | 2.0  | V <sub>CC</sub> +0.5 | V      |
|                                         |                        | 8BITDAC pin only                                 | 0.7  | $v_{cc}$             | V      |
| $V_{OL}$                                | Output Low Voltage     | $I_{OL} = -16 \text{ mA (IRQ)}$                  | _    | 0.4                  | •••••• |
|                                         |                        | $I_{OL} = -12 \text{ mA ( HSYNC, VSYNC)}$        | _    | 0.4                  | V      |
|                                         |                        | $I_{OL} = -4 \text{ mA (all others)}$            | _    | 0.4                  | V      |
| V <sub>OH</sub>                         | Output High Voltage    | I <sub>OH</sub> = 8 mA (IRQ)                     | 2.4  | _                    | V      |
|                                         |                        | I <sub>OH</sub> = 0.5 mA (all others)            | 2.4  | -                    | V      |

Electrical specifications contained herein are preliminary and subject to change without notice.



#### 82C480 AC TIMING CHARACTERISTICS - NUGGET CLOCK TIMING

| Symbol             | Parameter                      | Notes        | Min | Max          | Units |
|--------------------|--------------------------------|--------------|-----|--------------|-------|
| T <sub>NCLK</sub>  | Nugget Clock Cycle Time        | 30 MHz., max | 33  | Note 1       | nS    |
| T <sub>NCLKH</sub> | Nugget Clock High Time         |              | 15  | _            | nS    |
| T <sub>NCLKL</sub> | Nugget Clock Low Time          |              | 15  | _            | nS    |
| T <sub>BLV</sub>   | Nugget Clock to Blank Valid    |              | _   | 25           | nS    |
| TAPCV              | Nugget Clock to AF, CSEL valid |              | _   | 25           | nS    |
| T <sub>BLHLD</sub> | Blank hold from NCLK high      |              | 2   | <del>-</del> | nS    |
| TAPCHLD            | AF, CSEL Hold from NCLK High   |              | 2   | _            | nS    |

Note 1: The Nugget Clock frequency must be high enough to satisfy the refresh requirements of the VRAMs. The limiting display mode will be the one for which the horizontal total value is greatest. Refresh is performed for two VRAM rows each horizontal scan line. Therefore, for 256K VRAMs, the Refresh Period = TNCLK\*(horizontal total)\*256; and twice this value for 1M VRAMs.



#### 82C480 AC TIMING CHARACTERISTICS - RESET TIMING

| Symbol             | Parameter           | Notes                    | Min                  | Max | Units |
|--------------------|---------------------|--------------------------|----------------------|-----|-------|
| _                  | RESET Pulse Width   |                          | 64 T <sub>MCLK</sub> | _   | nS    |
| T <sub>MCLK</sub>  | Memory Clock period | Dependant on VRAM access | 25                   |     | nS    |
|                    |                     | time.                    |                      |     |       |
| T <sub>MCLKH</sub> | Memory Clock High   |                          | 11                   | _   | nS    |
| T <sub>MCLKL</sub> | Memory Clock Low    |                          | 11                   | _   | nS    |

Output load  $C_L = 50 pF$  unless otherwise noted.



#### 82C480 AC TIMING CHARACTERISTICS - ISA BUS TIMING

| Symbol | Parameter                                     | Notes           | Min                 | Max | Units |
|--------|-----------------------------------------------|-----------------|---------------------|-----|-------|
| T1     | IOR/, IOW/ Pulse Width                        | Video registers | 3*T <sub>NCLK</sub> | _   | nS    |
|        |                                               | All others      | 4*T <sub>MCLK</sub> | _   | nS    |
| T2     | RDY tristate (high-z) from IOR/,IOW/ inactive | Note 2          | -                   | 25  | nS    |
| Т3     | A19:0, RFSH/, AEN setup to command            |                 | 40                  | _   | nS    |
| Т4     | A19:0, RFSH/, AEN hold from command           |                 | 20                  | -   | nS    |
| Т6     | I/O Read Data valid from IOR/ active          |                 |                     | 50  | nS    |
| T7     | I/O Read Data hold from IOR/ inactive         |                 | 0                   | 40  | nS    |
| Т8     | IOW/ active to Data in Valid                  |                 | -                   | 15  | nS    |
| Т9     | I/O Write Data hold from IOW/ inactive        |                 | 0                   | _   | nS    |
| T12    | IOR/, IOW/ to RDY inactive (Low)              |                 | -                   | 25  | nS    |
| T16    | ROMCS/, PALRD/ active from MEMR/, IOR/        | Note 3          | 0                   | 45  | nS    |
| T17    | RDLO/, RDHI/ active from MEMR/, IOR/          |                 | -                   | 45  | nS    |
| T18    | RDLO/, RDHI/ inactive from MEMR/, IOR/        |                 | _                   | 45  | nS    |
| T19    | ROMCS/, PALRD/ inactive from MEMR/, IOR/      | Note 3          | 0                   | 25  | nS    |
| T20    | IOCS16/ active from Address Valid             |                 | _                   | 25  | nS    |
| T21    | IOCS16/ inactive from Address Valid           |                 | -                   | 25  | nS    |
| T22    | PALWR/ active from IOW/                       | Note 3          | -                   | 25  | nS    |
| T23    | PALWR/ inactive from IOW/                     | Note 3          | -                   | 25  | nS    |
| T25    | IOR/, IOW/ recovery time                      |                 | 80                  | _   | nS    |
| T26    | BHE/ valid to IOR/, IOW/ active               |                 | 25                  | _   | nS    |
| T27    | BHE/ hold from IOR/, IOW/ inactive            |                 | 30                  | _   | nS    |
| T28    | ROMPG[2:0] valid from MEMR/ active            |                 | -                   | 25  | nS    |
| T29    | ROMPG[2:0] hold from MEMR/ inactive           |                 | 0                   | _   | nS    |

Note 2: The 82C480 will asynchronously bring RDY active (high-z) if the current command cycle ends while ready is inactive (low).

Note 3: The 82C480 extends palette I/O read/write accesses (asynchronously) with RDY.

Output load  $C_L$ = 50pF unless otherwise noted.









ISA Bus Palette I/O Cycle Timing









ISA Bus ROM Memory Cycle Timing



#### 82C480 AC TIMING CHARACTERISTICS - MCA BUS TIMING

| Symbol | Parameter                                  | Notes           | Min                 | Max                  | Units |
|--------|--------------------------------------------|-----------------|---------------------|----------------------|-------|
| T40    | Status hold from CMD/ inactive             |                 | 20                  | -                    | nS    |
| T42    | Address hold from CMD/inactive             |                 | 30                  | -                    | nS    |
| T43    | Status setup to CMD/ active                |                 | 45                  | _                    | nS    |
| T44    | Address Valid setup to CMD/ active         |                 | 55                  | -                    | nS    |
| T45    | CMD/ Pulse Width                           | Video registers | 3*T <sub>NCLK</sub> | -                    | nS    |
|        |                                            | All others      | 4*T <sub>MCLK</sub> | -                    | nS    |
| T46    | CMD/ inactive to next CMD/ active          |                 | 80                  | -                    | nS    |
| T47    | CMD/ active to Write Data Valid            |                 | -                   | 15                   | nS    |
| T48    | Write data hold from CMD/ inactive         |                 | 0                   | -                    | nS    |
| T49    | Read data valid from CMD/ active           |                 | -                   | 50                   | nS    |
| T50    | Read data hold from CMD/ inactive          |                 | 0                   | 40                   | nS    |
| T52    | CSFB/ active from Address valid            |                 | -                   | 25                   | nS    |
| T53    | RDY active from CMD/ active                |                 | _                   | 64*T <sub>MCLK</sub> | nS    |
| T54    | Read data valid from RDY active (high)     |                 | _                   | 50                   | nS    |
| T55    | RDY inactive (low) from Address valid      |                 | <del>-</del>        | 25                   | nS    |
| T56    | PALWR/ delay from CMD/ active              |                 | _                   | 25                   | nS    |
| T57    | ROMCS/, PALRD/ active from CMD/ active     |                 | <del>-</del>        | 45                   | nS    |
| T59    | ROMPG[2:0] Valid from CMD/ active          |                 | -                   | 40                   | nS    |
| T60    | CSFB/ inactive from Address invalid        |                 | -                   | 25                   | nS    |
| T61    | PALWR/inactive from CMD/inactive           |                 | _                   | 25                   | nS    |
| T62    | BHE/ valid to CMD/ active                  |                 | 25                  |                      | nS    |
| Т63    | BHE/ hold from CMD/ active                 |                 | 30                  | -                    | nS    |
| T64    | ROMCS/, PALRD/ inactive from CMD/ inactive |                 | _                   | 25                   | nS    |
| T65    | DS16/ active from Address valid            |                 | _                   | 25                   | nS    |
| T66    | DS16/ inactive from Address invalid        |                 | -                   | 25                   | nS    |
| Т67    | POSEN/ active from CMD/ active             |                 | _                   | 45                   | nS    |
| T68    | POSEN/ inactive from CMD/ inactive         |                 | -                   | 25                   | nS    |
| T69    | RDLO/, RDHI/ active from CMD/ active       |                 | _                   | 45                   | nS    |
| T70    | RDLO/, RDHI/ inactive from CMD/ inactive   |                 | _                   | 45                   | nS    |
| T71    | ROMPG[2:0] valid from CMD/ active          |                 | -                   | 25                   | nS    |
| T72    | ROMPG[2:0] hold from CMD/ inactive         |                 | 0                   | _                    | nS    |

Output load  $C_L$ = 50pF unless otherwise noted.











#### 82C480 AC CHARACTERISTICS

#### **VRAM TIMING - SWITCHING CHARACTERISTICS**

| Symbol           | Parameter                            | Min | Тур | Max | Units |
|------------------|--------------------------------------|-----|-----|-----|-------|
| T <sub>RAC</sub> | Data Access Time from RAS/           |     |     | 100 | nS    |
| T <sub>CAC</sub> | Data Access Time from CAS/           |     |     | 30  | nS    |
| T <sub>AA</sub>  | Access time from Column Address      |     |     | 60  | nS    |
| T <sub>ACP</sub> | Access time from rising edge of CAS/ |     |     | 60  | nS    |
| T <sub>OEA</sub> | Access time from OE/                 |     |     | 30  | nS    |
| T <sub>OFF</sub> | Output disable time from CAS/ high   |     |     | 30  | nS    |
| T <sub>OEZ</sub> | Output disable time from OE/ high    |     |     | 30  | nS    |

Note: All VRAM timing characteristics are preliminary values referenced to a 40 MHz MCLK.

#### **VRAM TIMING - TIMING REQUIREMENTS**

| Symbol            | Parameter                              | Min | Тур                      | Max                                     | Units |
|-------------------|----------------------------------------|-----|--------------------------|-----------------------------------------|-------|
| T <sub>RC</sub>   | Random read or write cycle time        | 200 |                          |                                         | nS    |
| T <sub>RWC</sub>  | Read-modify-write cycle time           | 300 |                          |                                         | nS    |
| T <sub>PC</sub>   | Fast-page cycle time                   | 75  |                          |                                         | nS    |
| T <sub>PRWC</sub> | Fast-page read-modify-write cycle time | 150 |                          |                                         | nS    |
| T <sub>T</sub>    | Transition time (rise and fall)        | 3   |                          |                                         | nS    |
| T <sub>RP</sub>   | RAS/ precharge                         | 80  |                          |                                         | nS    |
| T <sub>RAS</sub>  | RAS/ pulse width                       | 100 | T <sub>NCLK</sub> *(H_TO | ΓAL+1)/2                                | nS    |
| T <sub>RASP</sub> | Fast-page RAS/ pulse width             | 100 | T <sub>NCLK</sub> *(H_TO | ΓAL+1)/2                                | nS    |
| T <sub>RSH</sub>  | RAS/ hold from CAS/                    | 35  |                          |                                         | nS    |
| T <sub>CPN</sub>  | CAS/ precharge                         | 15  |                          |                                         | nS    |
| T <sub>CP</sub>   | Fast-page CAS/ precharge time          | 15  |                          |                                         | nS    |
| T <sub>CAS</sub>  | CAS/ pulse width                       | 50  |                          |                                         | nS    |
| T <sub>CSH</sub>  | CAS/ hold from RAS/                    | 110 |                          | *************************************** | nS    |
| $T_{RCD}$         | RAS/ to CAS/ delay                     | 50  |                          |                                         | nS    |
| T <sub>CRP</sub>  | CAS/ high to RAS/ low precharge        | 25  |                          |                                         | nS    |
| T <sub>ASR</sub>  | Row Address setup time                 | 5   |                          |                                         | nS    |
| T <sub>RAH</sub>  | Row Address hold time                  | 15  |                          |                                         | nS    |
| T <sub>ASC</sub>  | Column Address setup to CAS/           | 10  |                          | 25                                      | nS    |
| T <sub>CAH</sub>  | Column Address hold time               | 20  |                          |                                         | nS    |



#### 82C480 AC CHARACTERISTICS

## VRAM TIMING - TIMING REQUIREMENTS (continued)

| Symbol           | Parameter                              | Min                              | Тур                                     | Max      | Units |
|------------------|----------------------------------------|----------------------------------|-----------------------------------------|----------|-------|
| T <sub>RAD</sub> | RAS/ to Column Address delay time 25   |                                  |                                         |          | nS    |
| T <sub>RAL</sub> | Column Address to RAS/lead time        | 25                               |                                         |          | nS    |
| T <sub>RCS</sub> | Read command setup time                | 10                               |                                         |          | nS    |
| T <sub>RRH</sub> | Read command hold time after RAS/ high | 15                               |                                         |          | nS    |
| $T_{RCH}$        | Read command hold time after CAS/ high | 10                               |                                         |          | nS    |
| T <sub>WCS</sub> | Write command setup time               | N/A                              |                                         | <u> </u> | nS    |
| T <sub>WCH</sub> | Write command hold time                | N/A                              | ••••••                                  | <u>+</u> | nS    |
| $T_{WP}$         | Write command pulse width              | 50                               |                                         |          | nS    |
| $T_{RWL}$        | Write command to RAS/lead time 50      |                                  |                                         |          | nS    |
| $T_{CWL}$        | Write command to CAS/lead time         | 50                               |                                         |          | nS    |
| T <sub>DS</sub>  | Data-in setup time                     | 10                               |                                         |          | nS    |
| T <sub>DH</sub>  | Data-in hold time                      | 25                               |                                         |          | nS    |
| $T_{AWD}$        | Column Address to WE/ delay            | 100                              |                                         |          | nS    |
| $T_{CWD}$        | CAS/ to WE/ delay                      | 100                              |                                         |          | nS    |
| $T_{RWD}$        | RAS/ to WE/ delay                      | 150                              |                                         |          | nS    |
| $T_{OED}$        | OE/ high to data-in setup delay        | 15                               | *************************************** |          | nS    |
| T <sub>OEH</sub> | OE/ high hold time after WE/ low       | 35                               | ••••••                                  |          | nS    |
| $T_{RPC}$        | RAS/ high to CAS/ low precharge time   | 25                               |                                         |          | nS    |
| T <sub>REF</sub> | Refresh time interval                  | T <sub>NCLK</sub> *(H_TOTAL+1)/2 |                                         |          | mS    |
| T <sub>DLS</sub> | DT/ low setup time                     | 5                                | <del></del>                             |          | nS    |
| $T_{RDH}$        | DT/ low hold time after RAS/ low       | 100                              | ······································  |          | nS    |
| $T_{CDH}$        | DT/ low hold time after CAS/ low       | 40                               |                                         |          | nS    |
| T <sub>DHS</sub> | DT/ high setup time                    | 25                               |                                         |          | nS    |
| T <sub>DHH</sub> | DT/ high hold time                     | 25                               |                                         |          | nS    |
| $T_{DTR}$        | DT/ high to RAS/ high delay            | 10                               |                                         |          | nS    |
| T <sub>DTC</sub> | DT/ high to CAS/ high delay            | 10                               |                                         |          | nS    |
| T <sub>WBS</sub> | Write-per-bit setup time               | 5                                |                                         |          | nS    |
| T <sub>WBH</sub> | Write-per-bit hold time                | 25                               |                                         |          | nS    |
| $T_{WS}$         | Write bit selection setup time         | 5                                |                                         |          | nS    |
| $T_{WH}$         | Write bit selection hold time          | 25                               |                                         |          | nS    |
| T <sub>DTH</sub> | DT/ high hold time after RAS/ high     | 25                               |                                         |          | nS    |





VRAM Fast-page Read Cycle Timing





VRAM Fast-page Write Cycle Timing





VRAM Fast-page Read-Modify-Write Cycle Timing





VRAM Data Transfer Cycle Timing





VRAM Refresh Cycle Timing



#### 82C480 AC TIMING CHARACTERISTICS - VIDEO TIMING

| Symbol | Parameter               | Notes | Min | Max | Units |
|--------|-------------------------|-------|-----|-----|-------|
| T80    | VSYNC delay from PCLK   |       | -   | 25  | nS    |
| T81    | VSYNC delay from VVSYNC |       | -   | 25  | nS    |
| T82    | HSYNC delay from NCLK   |       | -   | 25  | nS    |
|        | HSYNC delay from VHSYNC |       | -   | 25  | nS    |

Output load  $C_L$ = 50pF unless otherwise noted.



82C480 Video Timing



# Video Register Parameters

|              |         | Video Mode       |          |              |                  |              |
|--------------|---------|------------------|----------|--------------|------------------|--------------|
| Register     | I/O     | 640x480          | 640x480  | 1024x768     | 1024x768         | 1280x1024    |
| Name         | Address | (Non-Interlaced) | Pseudo-8 | (Interlaced) | (Non-Interlaced) | (Interlaced) |
| ADVFUNC_CNTL | 4AE8    | 0003             | 0003     | 0007         | 0001             | 0001         |
| DISP_CNTL    | 22E8    | 0023             | 0021     | 0033         | 0023             | 0033         |
| MEM_CNTL     | BEE8[5] | 5006             | 5002     | 5006         | 5006             | 5006         |
| H_TOTAL      | 02E8    | 0063             | 0063     | 009D         | 009D             | 00C3         |
| H_DISP       | 06E8    | 004F             | 004F     | 007F         | 007F             | 009F         |
| H_SYNC_STRT  | 0AE8    | 0052             | 0052     | 0081         | 0081             | 00A1         |
| H_SYNC_WID   | 0EE8    | 002C             | 002C     | 0016         | 0016             | 001B         |
| V_TOTAL      | 12E8    | 0418             | 0830     | 0660         | 0660             | 0918         |
| V_DISP       | 16E8    | 03BB             | 0779     | 05FB         | 05FB             | 07FB         |
| V_SYNC_STRT  | 1AE8    | 03D2             | 07A8     | 0600         | 0600             | 0800         |
| V_SYNC_WID   | 1EE8    | 0022             | 0022     | 0008         | 0008             | 000C         |
| SCISSORS_T   | BEE8[1] | 1000             | 1000     | 1000         | 1000             | 1000         |
| SCISSORS_L   | BEE8[2] | 2000             | 2000     | 2000         | 2000             | 2000         |
| SCISSORS_B   | BEE8[3] | 31DF             | 31DF     | 32FF         | 32FF             | 33FF         |



This page was intentionally left blank



## 82C480 Mechanical Specifications



Note 1: Package Body Size = 28 ±0.2 (1.102 ±0.008) Note 2: Lead Length = 0.8 ±0.2 (0.031 ±0.008)

## 82C480 Suggested PCB Pad Layout

