

WD9500 (PWGA) Enhanced 8514/A Compatible Chip Set



## TABLE OF CONTENTS

| Section                         | Title |                                                                                                              | Page             |  |  |  |
|---------------------------------|-------|--------------------------------------------------------------------------------------------------------------|------------------|--|--|--|
| 1.0                             | INTR  |                                                                                                              |                  |  |  |  |
|                                 | 1.1   | FEATURES                                                                                                     |                  |  |  |  |
|                                 | 1.2   | DESCRIPTION                                                                                                  |                  |  |  |  |
| 2.0                             | ARCI  |                                                                                                              |                  |  |  |  |
|                                 | 2.1   | FUNCTIONAL ORGANIZATION                                                                                      |                  |  |  |  |
|                                 | 2.2   | BOARD OPERATION OVERVIEW                                                                                     |                  |  |  |  |
| 1.0<br>2.0<br>3.0<br>4.0<br>5.0 | WD9   | 00 INTERFACES                                                                                                |                  |  |  |  |
|                                 | 3.1   | CPU INTERFACE                                                                                                |                  |  |  |  |
|                                 | 3.2   | VRAM DESIGN AND INTERFACE                                                                                    |                  |  |  |  |
|                                 |       | 3.2.1 INTEGRATED BACK-END VRAM DESIGN                                                                        |                  |  |  |  |
|                                 |       | 3.2.2 EXTERNAL BACK-END VRAM DESIGN                                                                          |                  |  |  |  |
|                                 | 3.3   | VIDEO DAC AND INTERFACE SUBSYSTEM                                                                            |                  |  |  |  |
|                                 | 3.4   | OTHER BOARD DESIGN ELEMENTS                                                                                  |                  |  |  |  |
|                                 |       | 3.4.1 EPROM                                                                                                  |                  |  |  |  |
|                                 |       | 3.4.2 PAM-PDM INTERFACE                                                                                      |                  |  |  |  |
|                                 |       | 3.4.3 CONFIGURATION STRAPPING                                                                                |                  |  |  |  |
|                                 |       | 3.4.4 CLOCK CONSIDERATIONS                                                                                   |                  |  |  |  |
| 4.0                             | ABSC  | 3.4.4       CLOCK CONSIDERATIONS       25-14         LUTE MAXIMUM RATINGS AND DC CHARACTERISTICS       25-17 |                  |  |  |  |
| 5.0                             | AC T  | ING CHARACTERISTICS                                                                                          |                  |  |  |  |
| 6.0                             | WD9   | 00 REGISTERS                                                                                                 |                  |  |  |  |
|                                 | 6.1   | DAC INTERFACE REGISTERS                                                                                      |                  |  |  |  |
|                                 | 6.2   | ADVANCED FUNCTION CONTROL REGISTER (WRITE ONL                                                                | Y - 4AE8H) 25-22 |  |  |  |
|                                 | 6.3   | VIDEO TIMING SETUP REGISTERS                                                                                 |                  |  |  |  |
|                                 |       | 6.3.1 HORIZONTAL TOTAL REGISTER (WRITE ONLY -                                                                |                  |  |  |  |
|                                 |       | ADDRESS 02E8H)                                                                                               |                  |  |  |  |
|                                 |       | 6.3.2 HORIZONTAL DISPLAYED (WRITE ONLY -                                                                     |                  |  |  |  |
|                                 |       | ADDRESS 06E8H)                                                                                               |                  |  |  |  |
|                                 |       | 6.3.3 HORIZONTAL SYNC START REGISTER (WRITE OF                                                               |                  |  |  |  |
|                                 |       | ADDRESS 0AE8H)                                                                                               |                  |  |  |  |
|                                 |       | 6.3.4 HORIZONTAL SYNC WIDTH REGISTER (WRITE OF ADDRESS 0EE8H)                                                |                  |  |  |  |
|                                 |       | 6.3.5 VERTICAL TOTAL REGISTER (WRITE ONLY - ADD                                                              |                  |  |  |  |
|                                 |       | 6.3.6 VERTICAL DISPLAYED REGISTER (WRITE ONLY - ADD                                                          | ,                |  |  |  |
|                                 |       | ADDRESS 16E8H)                                                                                               |                  |  |  |  |
|                                 |       | 6.3.7 VERTICAL SYNC START REGISTER (WRITE ONLY                                                               |                  |  |  |  |
|                                 |       | ADDRESS 1AE8H)                                                                                               |                  |  |  |  |
|                                 |       | 6.3.8 VERTICAL SYNC WIDTH POLARITY REGISTER (W                                                               |                  |  |  |  |
|                                 |       | ADDRESS 1EE8H)                                                                                               |                  |  |  |  |
|                                 |       | 6.3.9 DISPLAY CONTROL REGISTER (WRITE ONLY - AD                                                              |                  |  |  |  |
|                                 | 6.4   | ROM PAGE SELECT REGISTER (WRITE ONLY -                                                                       | ,                |  |  |  |
|                                 |       | ADDRESS 46E8 MC/36E8 AT)                                                                                     |                  |  |  |  |
|                                 | 6.5   | SUBSYSTEM CONTROL REGISTER (WRITE ONLY - ADDRI                                                               | ESS 42E8H) 25-26 |  |  |  |

| Section | Title |        |                                                                                                             | Page    |
|---------|-------|--------|-------------------------------------------------------------------------------------------------------------|---------|
|         | 6.6   | DRAWI  | NG CONTROL REGISTERS                                                                                        | 25-27   |
|         |       | 6.6.1  | CURRENT Y POSITION REGISTER (READ/WRITE -                                                                   |         |
|         |       |        | ADDRESS 82E8H)                                                                                              |         |
|         |       | 6.6.2  | CURRENT X REGISTER (READ/WRITE - ADDRESS 86E8H)                                                             | 25-27   |
|         |       | 6.6.3  | DESTINATION Y POSITION/AXIAL STEP CONSTANT REGISTER<br>(WRITE ONLY - ADDRESS 8AE8H)                         |         |
|         |       | 6.6.4  | DESTINATION X POSITION/DIAGONAL STEP CONSTANT REGISTI<br>(WRITE ONLY - ADDRESS 8EE8H)                       |         |
|         |       | 6.6.5  | ERROR TERM REGISTER (READ/WRITE - 92E8H)                                                                    |         |
|         |       | 6.6.6  | MAJOR AXIS PIXEL COUNT REGISTER (WRITE ONLY -<br>ADDRESS 96E8H)                                             | 25-28   |
|         |       | 6.6.7  | COMMAND REGISTER (WRITE ONLY - ADDRESS 9AE8H)                                                               |         |
|         |       | 6.6.8  | COMMAND REGISTER (WRITE ONLY - ADDRESS 9AE8H)                                                               | 25-28   |
|         |       | 6.6.9  | SHORT STROKE VECTOR TRANSFER REGISTER (WRITE ONLY - ADDRESS 9EE8H)                                          |         |
|         |       | 6.6.10 | BACKGROUND COLOR REGISTER (WRITE ONLY -                                                                     |         |
|         |       |        | ADDRESS A2E8H)                                                                                              | 25-30   |
|         |       | 6.6.11 | FOREGROUND COLOR REGISTER (WRITE ONLY -<br>ADDRESS A6E8H)                                                   |         |
|         |       | 6.6.12 | WRITE MASK REGISTER (WRITE ONLY - ADDRESS AAE8H)                                                            | 25-30   |
|         |       | 6.6.13 | READ MASK REGISTER (WRITE ONLY - ADDRESS AEE8H)                                                             | 25-30   |
|         |       | 6.6.14 | COLOR COMPARE REGISTER (WRITE ONLY -<br>ADDRESS B2E8H)                                                      | 25-30   |
|         |       | 6.6.15 | BACKGROUND MIX REGISTER (WRITE ONLY -<br>ADDRESS B6E8H)                                                     | 25-30   |
|         |       | 6.6.16 | FOREGROUND MIX REGISTER (WRITE ONLY -<br>ADDRESS BAE8H)                                                     | 25-30   |
|         |       | 6.6.17 | MULTIFUNCTION CONTROL REGISTER (WRITE ONLY -<br>ADDRESS BEE8-0,1,2,3,4)                                     |         |
|         |       | 6.6.18 | MEMORY CONTROL INDEX REGISTER (WRITE ONLY -<br>ADDRESS BEE8-5)                                              |         |
|         |       | 6.6.19 | FIXED PATTERN LOW INDEX REGISTER FIXED PATTERN HIGH<br>INDEX REGISTER (WRITE ONLY - ADDRESS BEE8-8, BEE8-9) |         |
|         |       | 6.6.20 | PIXEL CONTROL INDEX REGISTER (WRITE ONLY -                                                                  |         |
|         |       | 6.6.21 | ADDRESS BEE8-A) PIXEL DATA TRANSFER REGISTER (READ/WRITE -                                                  |         |
|         | 07    | OTATU  |                                                                                                             |         |
|         | 6.7   | 6.7.1  | S REGISTERS                                                                                                 | 25-33   |
|         |       |        | ADDRESS 42E8H)                                                                                              | 25-33   |
|         |       | 6.7.2  | GRAPHICS PROCESSOR STATUS REGISTER (READ ONLY -<br>ADDRESS 9AE8H)                                           | 25-35   |
|         |       | 6.7.3  | DISPLAY STATUS REGISTER (READ ONLY -<br>ADDRESS 02E8H)                                                      | . 25-35 |

|      | 6.8.1 | WESTERN DIGITAL ESCAPE REGISTER (READ ONLY -                        |
|------|-------|---------------------------------------------------------------------|
|      | 6.8.2 | ADDRESS 28E9)                                                       |
|      | 6.8.3 | WESTERN DIGITAL CONTROL REGISTER (WRITE ONLY -<br>ADDRESS 96E8)     |
|      | 6.8.4 | TEXTURE PATTERN START/END REGISTER (WRITE ONLY -<br>ADDRESS 96E8-3) |
| 6.9  | ENHA  | NCED SOLID LINE DRAWING 25-4                                        |
| 6.10 | TEXTU | JRED-LINE DRAWING 25-4                                              |
| 6 11 | FLICK | ER-FREE PALETTE LOADING 25-4                                        |

## Figure Title

Section

Title

| 1 - | Architecture                                    | 25-3  |
|-----|-------------------------------------------------|-------|
| 2   | Functional Organization                         | 25-4  |
| 3   | CPU Interface Logic - AT Bus                    |       |
| 4   | Bit Plane Read Mask Register                    |       |
| 5   | Method of Identifying WD9500 Chip Set           | 25-36 |
| 6   | WD Enhanced Mode Usage in 1024 x 768 Resolution | 25-37 |
| 7   | WD Enhanced Mode Usage in 640 x 480 Resolution  | 25-38 |

## LIST OF TABLES

| Table | Title                                      | Page   |
|-------|--------------------------------------------|--------|
| 1     | CPU Interface Pins (PAM) for Micro Channel | . 25-6 |
| 2     | CPU Interface Pins (PAM) for AT Bus        |        |
| 3     | VRAM Parameters                            |        |
| 4     | PAM Pin Interface to VRAM                  | 25-10  |
| 5     | PDM Pin Interface to VRAM                  | 25-11  |
| 6     | PDM Pin Interface to Video Subsystem       | 25-12  |
| 7     | EPROM Interface Pins                       | 25-13  |
| 8     | BIOS EPROM Address Mapping                 | 25-13  |
| 9     | Interchip Interface Pins                   | 25-14  |
| 10    | Configuration Strapping Pins               | 25-15  |
| 11    | Chip Count Strapping                       | 25-15  |
| 12    | Monitor Selection                          | 25-15  |
| 13    | Monitor ID Interpretation                  | 25-16  |
| 14    | Pixel Clock Frequency Derivation           | 25-16  |

25

## WD9500

#### Table Title Page 15 16 17 18 19 20 POS Register Interface (Micro Channel Only) ..... 25-21 21 22 23 CRT Control Register Parameters and Timing ..... 25-25 24 25 IBM 8514/A Compatible Registers ...... 25-43 26

## 1.0 INTRODUCTION

The Western Digital Imaging WD9500-SET1 is a set of two proprietary VLSI chips (Pixel Address Manager and Pixel Data Manager). These chips are designed to serve as the primary components of intelligent high-resolution graphics add-in boards and motherboards for PC/AT, PS/2 Micro Channel and E.I.S.A. computer systems and compatibles. When the remaining board-level components and software are properly selected and integrated, the WD9500-SET1 will provide full compatibility with the IBM 8514/A Display Adapter with superior performance plus functional enhancements (Western Digital Extensions). In order to take full advantage of all features, including the unique extensions. Western Digital supplies key software drivers, with specific performance improvements including 8514/A Adapter compatible interface, Microsoft Windows 286 and 386 drivers, and Display List drivers for AutoCAD.

## 1.1 FEATURES

Full functional compatibility with the IBM 8514/A Display Adapter, including hardware compatibility with the registers that any application would access.

- Integrated bus interface: PC/AT, PS/2 Micro Channel and E.I.S.A.
- Transparently runs software written for 8514/A interlaced monitors on non-interlaced monitors.
- Performance averages 30% to 100% faster than 8514/A on graphics operations.
- BITBLT performance 4.5 times that of IBM 8514/A in Turbo 4-bit mode. Turbo 4-bit BITBLT is two times faster than regular 4-bit or 8-bit BITBLT.
- Enhanced resolution: one page of 1280x1024 pixels 256 colors; two pages of 1024x768 pixels 256 colors; two pages of 640x480 pixels 256 colors.
- Enhanced graphics commands for high-speed hardware generation of textured lines and enhanced solid lines.
- Flicker-free video DAC programming.
- 60MHz Graphics Processor Clock Rate.
- All features, including most extensions, are supported by Western Digital Imaging Adapter Interface (A.I.) driver software.
- Performance enhanced software drivers for key software packages including Windows 286/386 and AutoCAD.

- Supports 256Kx4 VRAM in different speed grades (120ns or faster) with programmable VRAM timing to minimize wait states.
- · Independent Video and Data Clocks.
- Supports both INMOS and Brooktree video DACs and compatibles, with back-end integration to minimize external glue logic.
- Supports both interlaced and non-interlaced monitors up to 70Hz vertical refresh rate.
   Software written for 8514/A interlaced monitors needs no modification for non-interlaced monitors.
- 132-Pin JEDEC Plastic Quad Fine Pitch Flat Pack.
- 1.25 Micron CMOS Technology.

## 1.2 DESCRIPTION

In addition to full compatibility with the IBM 8514/A, which provides intelligent graphics functions such as polyline drawing, pattern fill for rectangles, "areas" (polygons), and "scissoring" (clipping), the WD9500-SET1 provides several functional enhancements and options as well as superior performance.

A major enhancement is the support of higher screen resolution, 1280x1024 pixels with 256 simultaneously displayable colors, as opposed to the 1024x768 maximum for the IBM 8514/A. Alternatively, the WD9500-SET1 can support a second screen page at the highest 8514/A resolution.

The WD9500-SET1 will give end user dramatic speed improvement in almost all graphics operation. In regular 4-bit mode, the WD9500-SET1 performs Bit Block Transfers (BITBLTs) twice as fast as the IBM 8514/A. In Turbo 4-bit mode, it is 4.5 times as fast. In particular, enhanced performance will be obvious when moving large images on the screen (e.g. scrolling). Under turbo mode all horizontal data movement will be twice as fast. This includes BITBLT, rectangle fill, horizontal line, and polygon search and fill.

Users will also notice considerable performance improvement with the WD9500-SET1 in all new line-drawing operations, because it directly performs several functions that the IBM 8514/A must perform in much slower CPU software. One such improvement is the direct generation of textured line; another is the automatic, high-speed calculation of line parameters by the WD9500-SET1, replacing the tedious CPU software procedures with simple specifications of only the beginning and ending points of any line.

Whereas the IBM Display Adapter 8514/A is designed only for use in the PS/2 computer models that use the Micro Channel bus, the WD9500-SET1 provides an alternate interface to allow full 8514/A functionality (with extensions) for the Micro Channel, and more importantly, for all PC/AT computers and compatibles. The interface selection is made with a single device pin that is "strapped" at board design time.

Many graphics applications result in noticeable screen flickering when the software steals refresh cycles to modify the color palette in the video DAC. A unique low-cost board design option will provide flicker-free display operation by allowing the WD9500-SET1 to buffer the new palette values and apply them during the monitor's horizontal retrace (flyback).

WD9500-SET1 based boards can accommodate both interlaced display monitors, such as the IBM 8514, and non-interlaced monitors; the WD9500-SET1 will drive either, automatically configuring itself at reset time based on the signals in the monitor interface cable (for IBM-compatible interlaced monitors) or on user selection through onboard switches or on user selection through a software utility. End users can thus exploit cost/performance tradeoffs that are not available with the IBM 8514/A board.

Software written directly to 8514/A registers programs the video registers to IBM 8514/A display interlaced timing for 1024x768 resolution. To achieve maximum flexibility for driving different monitors, two sets of video registers are provided; one for 1024x768 resolution and one for 640x480 resolution. These registers can be programmed by the BIOS EPROM at power up and their values locked in so that direct access by software later will not affect the preset video timing.

For the board designer, the WD9500-SET1 provides several further cost/function/performance trade-off opportunities, and also saves design time, board space, and component costs by integrating much of the peripheral logic into its design. The designer can choose among several

video memory (VRAM) architectures, using 256Kx4 VRAM chips, with back-end logic integrated into the WD9500-SET1 for 8514/A emulation and extension to two pages of 1024x768x8 (1280x1024 extended resolution requires off-chip logic support). The designer may also exploit the use of different clock rates for the drawing process and the screen refresh process; and bypass design of video data multiplexing and serializing, as these functions are integrated into the WD9500-SET1 chips.

## 2.0 ARCHITECTURE

Figure 1 illustrates the logical architecture of a WD9500-SET1 based board in block diagram style. Each of its major elements, which for now are presented as functional "black boxes", is discussed below.

The WD9500-SET1 consists of two 132-pin chips: the PAM (Pixel Address Manager) and the PDM (Pixel Data Manager).

The VRAM block in Figure 1 represents the video memory subsystem, used to store screen images generated in the WD9500-SET1 (as a result of CPU drawing instructions) or sent from the CPU (typically for the purpose of restoring previously drawn images that had been stored elsewhere in the system). The WD9500-SET1 then accesses these images for automatic display-screen refresh. Drawing operations take place within a pixel coordinate space of 2K by 2K; similar to the 8514/A, remaining VRAM storage is available to the WD9500-SET1 and the CPU for "off-screen" use, including storage of fill patters and scratchpad data. Section 3.2 describes VRAM operation and defines the detailed interface of the VRAM subsystem to the WD9500-SET1 chip set.

In the standard board configuration, the WD9500-SET1 is responsible for serializing and multiplexing data extracted form VRAM for screen refresh, and then forwarding the data to the DAC via the video interface logic block. In VRAM architectures using external back-end support, which is necessary to achieve 1280x1024 pixel resolution, serializing and multiplexing is done within the VRAM block, and the resultant screen refresh data bypasses the WD9500-SET1, as shown in Figure 1.

 ${\prime \prime}$ 



FIGURE 1. ARCHITECTURE

The video DAC (Digital-to-Analog Converter) has the primary function of generating analog intensity signals for the red, green, and blue guns of the display monitor, carrying these values in synchronization with pixel coordinates as the guns sweep across the screen. The source of these values is the "pixel data" that the WD9500-SET1 reads out of VRAM in its screen refresh operation. With external back-end support, extra intelligence is required in the DAC to assist in the data formatting begun in the serializing and multiplexing logic within the VRAM block. The DAC contains the color palette, a small memory that maps a given pixel data valued into a specific combination of RGB intensities according to the contents of each of the cells in palette memory. For example, in a 256-color arrangement, an eight- bit pixel data value select one of 256 palette memory cells. Each of the latter have been loaded with an 18-bit datum partitioned into three 6-bit fields whose values are in turn converted into red. green, and blue signal intensities when that cell is

selected. Palette values may be loaded directly from the CPU, or with the Western Digital flickerfree option, indirectly through the WD9500-SET1.

The video DAC and its interfaces, the auxiliary video extension (used to drive the monitor from an off-board source, normally the system VGA), the monitor interface, and other related logic and interfaces together comprise the "video DAC and interface subsystem", described in detail in Chapter. Note that the small block in Figure 1 labeled "Video Interface Logic" represents only a modest amount of logic and, in fact, consists largely of pass-through routing of signals; the block is drawn chiefly for convenience in explanation.

The CPU Interface Logic block contains the bus transceivers and TTL glue logic necessary to interface the WD9500-SET1 chips to the system bus (either the IBM PS/2 Micro Channel of the IBM PC/AT bus, or compatible busses). This block also provides a data path to the DAC used by the CPU to directly access palette values, and to the



**FIGURE 2. FUNCTIONAL ORGANIZATION** 

EPROM. The CPU interface logic is described in detail in Section 3.1.

The remaining board elements are the EPROM (containing Western Digital-supplied BIOS extension firmware), the clock generators, and a group of minor components (pull-up/down logic and DIP switches) used by the WD9500-SET1 to sense its environmental configuration; whether Micro Channel or AT bus, VRAM organization, etc. These elements are described in Section 3.0, together with the inter-chip (PAM-PDM) connections.

Finally, the WD9500-SET1 contains a set of useraccessible internal register that are compatible with those on the IBM 8514/A board, plus certain extra registers to support Western Digital extensions. From the user's point of view, these registers exist chiefly as destinations for software commands ("orders" in IBM terminology) and their parameters.

## 2.1 FUNCTIONAL ORGANIZATION

Figure 2 introduces the internal functional blocks of the PAM and PDM chips. Communication between the two chips is mediated by two Internal Bus Interface Units (IBIUs); they are transparent to user operations, and are not shown in the diagram.

In addition to the internal registers and the IBIUs, the functional modules within the WD9500-SET1 are as follows:

Within the **PAM**:

- CIU: CPU Interface Unit
- GP: Graphics Processor
- MIC: Memory Interface Controller

Within the PDM:

- **DP:** Data Processor
- DSP: Display Processor

The **CIU** controls communication with the system bus (via the CPU interface logic block external to the chip set), and passes data to and from all the other units on the chip set. It also performs certain miscellaneous functions, such as forwarding addresses from the system bus to the EPROM.

The **GP** performs the actual drawing computations; it supports all 8514/A graphics modes, plus Western Digital extensions. The modes include line drawing, area fill area outline drawing (arbitrary polygons), rectangle drawing, image transfer from the CPU, BITBLT copying (Bit Block Transfer within VRAM), and scissoring. The GP receives its drawing instructions form the CIU and sends the resulting pixel coordinates to the MIC.

The **MIC** controls VRAM addressing and access. In a typical drawing operation, it will convert the DP supplied pixel coordinates into VRAM addresses, cause the VRAM to send the addressed data (pixel color values) to the DP for modification, and then rewrite back into VRAM. When not involved in a drawing or special-purpose access, the MIC manages the VRAM addressing portion of the constantly on-going screen refresh process. The MIC gives screen refresh the highest priority for VRAM access; next is timer-based VRAM chip refresh, with DP-requested drawing access given the lowest priority.

The **DP** is responsible for updating VRAM in support of drawing and data transfer operations and altering pixel data (color values) according to masks and parameters, including "mix" specifications supplied in shared internal registers by the DP and GP. The DP receives pixel data on a bidirectional bus from the VRAM, modifies it, and then writes it back to the VRAM on the same bus.

The **DSP** manages the DAC and monitor, coordinating its role in the screen refresh process with the MIC. With an integrated back-end VRAM design, the DSP serializes and multiplexes pixel data, "pumped" out of VRAM by the MIC, to the DAC, in synchronization with the timing of the monitor's sweep across the display screen. (With external back-end support, this DSP function is assumed by external logic within the VRAM block and the DAC).

## 2.2 BOARD OPERATION OVERVIEW

The functions of any WD9500-SET1 based board, as well as those of the IBM 8514/A, can be summarized as follows:

**A. Screen refresh:** A key function is driving the display monitor. The board reads data form its VRAM stored representation of the screen image, and then converts the data, pixel by pixel, into RGB signal for the display monitor, in synchronization with the sweeping of the monitor's RGB guns across its screen.

**B. Drawing:** The other major board function , less time-critical then screen refresh, is the generation of new lines and areas within VRAM in response to commands from the system CPU. In this context, "drawing" includes filling polygon shapes with patters, establishing boundaries for "scissoring" (clipping), and similar operations. Drawing operations can involve complex algorithms, and they require correspondingly sophisticated processing by the WD9500-SET1.

**C. Image transfer:** In most graphics work, it is common to save board-drawn images (e.g. popup menus) elsewhere in main system memory and/or on disk for later restoration to on-board video memory and thence to the display screen.

**D. VGA input:** The host CPU may request that the monitor be driven by the VGA (Video Graphics Array), a similar but less sophisticated graphics facility located elsewhere in the system; in this case the WD9500-SET1 based board (or the 8514/A) essentially becomes a passive pass-through channel, taking video data and sync signals from the "auxiliary video extension" bus connector. Note that another monitor can be attached directly to the VGA; if the WD9500-SET1 based board (or 8514/A) is not in pass-through mode, then the two monitors can simultaneously display different images.

**E. Palette loading:** Pixel color interpretation is mediated by a small "palette" memory in the video DAC on the board. The CPU can very rapidly effect changes on the screen by changing the contents of this memory, as distinct from issuing drawing commands.

| PIN NUMBER     | PIN SYMBOL | TYPE                                                                                                                                                            | DESCRIPTION                                               |  |
|----------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|--|
| 62-69, 71-82   | A0-A19     | 1                                                                                                                                                               | CPU addaress bits 0 through 19                            |  |
| 85             | AUP        | I Decoding of upper CPU address bits 23-20, p<br>MADE24; all these should be 0 if the lower 20<br>address are to be considered valid for the WE<br>based board. |                                                           |  |
| 57             | M/ĪO       |                                                                                                                                                                 | Distinguishes memory access from I/O access               |  |
| 59             | S0         | 1                                                                                                                                                               | Status Bit 0                                              |  |
| 58             | S1         | 1                                                                                                                                                               | Status Bit 1                                              |  |
| 61             | ADL        | 1                                                                                                                                                               | Address Latch                                             |  |
| 60             | CMD        | I                                                                                                                                                               | Command                                                   |  |
| 56             | SBHE       | 1                                                                                                                                                               | System Byte High Enable                                   |  |
| 52             | RESET      | 1                                                                                                                                                               | Channel Reset                                             |  |
| 86             | CDSETUP    | 1                                                                                                                                                               | Card Setup                                                |  |
| 90             | CD CHRDY   | 0                                                                                                                                                               | Channel Ready                                             |  |
| 88             | IRQ        | 0                                                                                                                                                               | Interrupt Request; tied to Micro Channel IRQ 9            |  |
| 89             | CD SFFBK   | 0                                                                                                                                                               | Card Selected Feedback                                    |  |
| 55             | CD DS16    | 0                                                                                                                                                               | Card Data Size 16                                         |  |
| 91             | DBEN       | 0                                                                                                                                                               | Data Bus Enable                                           |  |
| 94-98, 100-110 | D0-D15     | I/O                                                                                                                                                             | CPU Data Bus Bits 0 through 16                            |  |
| 92             | DBDIR      | 0                                                                                                                                                               | Data Bus Direction (high for CPU read, low for CPU write) |  |

## TABLE 1. CPU INTERFACE PINS (PAM) FOR MICRO CHANNEL

**F. EPROM access:** The board includes a small EPROM containing a BIOS extension available to the CPU. The EPROM is mainly for initialization an diagnostic testing during power up. (Note that a portion of EPROM contains certain board configuration information read by the WD9500-SET1 upon power up.)

**G.** *Other:* Finally, the board design must provide for customary CPU handshaking, interrupts, and miscellaneous bus interface signals.

## 3.0 WD9500 INTERFACES

## 3.1 CPU INTERFACE

The PAM provides interface pins to connect to either the IBM PS/2 Micro Channel of the AT bus via a small amount of external logic, illustrated in Figures 1 and 2. The CIO configures itself for one of the two different interfaces according to the value of a configuration strapping pin, described later in this chapter (Table 12).

Because of the two possible external environments, most of these CPU interface pins have two alternate interpretations, as shown in the following tables. In both cases, however, the names and uses of most of these pins correspond precisely to the IBM specifications for theMicro Channel or AT bus, and so do not need special explanation.

| PIN NUMBER     | PIN SYMBOL | TYPE                                                                                                                                                            | DESCRIPTION                                               |
|----------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|
| 62-69, 71-82   | SA0-SA19   | 1                                                                                                                                                               | CPU addaress bits 0 through 19                            |
| 85             | AUP        | I Decoding of upper CPU address bits 23-20, p<br>MADE24; all these should be 0 if the lower 20<br>address are to be considered valid for the WE<br>based board. |                                                           |
| 56             | SBHE       | <u> </u>                                                                                                                                                        | System Byte High Enable                                   |
| 57             | MEMR       |                                                                                                                                                                 | Memory Read                                               |
| 59             | MEMW       | 1                                                                                                                                                               | Memory Write                                              |
| 58             | IOR        | 1                                                                                                                                                               | I/O Read                                                  |
| 60             | IOW        | 1                                                                                                                                                               | I/O Write                                                 |
| 61             | BALE       | 1                                                                                                                                                               | Buffered Address Latch Enable                             |
| 86             | AEN        | 1                                                                                                                                                               | Address Enable                                            |
| 52             | RESET      | 1                                                                                                                                                               | System Reset                                              |
| 88             | IRQ        | 0                                                                                                                                                               | Interrupt Request; tied to any AT bus interrupt           |
| 55             | CD CS16    | 0                                                                                                                                                               | I/O 16-bit Chip Select                                    |
| 91             | DBEN       | 0                                                                                                                                                               | Data Bus Enable                                           |
| 94-98, 100-110 | SD0-SD15   | I/O                                                                                                                                                             | CPU Data Bus Bits 0 through 16                            |
| 92             | DBDIR      | 0                                                                                                                                                               | Data Bus Direction (high for CPU read, low for CPU write) |
| 84             | ATCLK      |                                                                                                                                                                 | AT Bus Clock                                              |

## TABLE 2. CPU INTERFACE PINS (PAM) FOR AT BUS



FIGURE 3. CPU INTERFACE LOGIC - AT BUS

| I/E* | NUMBER OF<br>CHIPS | PIXEL<br>RESOLUTION | PIXEL DEPTH | NUMBER OF<br>SCREEN<br>PAGES | S/W** |
|------|--------------------|---------------------|-------------|------------------------------|-------|
| 1    | 4                  | 1024x768            | 4           | 1                            | S     |
|      |                    | 640x480             | 4           | 2                            | S     |
|      | 8                  | 1024x768            | 8           | 1                            | S     |
|      |                    | 1024x768            | 4           | 2                            | W     |
|      |                    | 640x480             | 8           | 1                            | S     |
|      | 16                 | 1024x768            | 8           | 2                            | W     |
|      |                    | 1024x768            | 4           | 2                            | W     |
|      |                    | 640x480             | 8           | 2                            | W     |
| Е    | 8                  | 1280X1024           | 4           | 1                            | W     |
|      |                    | 1024x768            | 8           | 1                            | S     |
|      |                    | 1024x768            | 4           | 2                            | W     |
|      |                    | 640x480             | 8           | 1                            | S     |
|      | 16                 | 1280x1024           | 8           | 1                            | W     |
|      |                    | 1024x768            | 8           | 2                            | W     |
|      |                    | 1024x768            | 4           | 2                            | W     |
|      |                    | 640x480             | 8           | 2                            | W     |

\*I = Integrated Back-end Support

E = External Back-end Support

\*\*S = Standard capability within 8514/A emulation

W = Western Digital extension to 8514/A capability

## TABLE 3. VRAM PARAMETERS

## 3.2 VRAM DESIGN AND INTERFACE

The WD9500-SET1 supports two VRAM designs. Each of these in turn can be implemented with two or three levels of chip population, for a total of five implementations. The design choice depends on the desired combination of the following criteria (with only certain combinations possible):

- pixel resolution: 640x480, 1024x768, 1280x1024
- pixel depth: 4 or 8 bits per pixel
- number of screen pages: one or two
- number of VRAM chips (and hence board size)
- field upgradeability
- type of design: with back-end (serializing and multiplexing of pixel data for screen refresh) integrated within the WD9500-SET1, or with external back-end support

External back-end support: includes the use of a more sophisticated DAC - is required to achieve 1280x1024 resolution.

## 3.2.1 INTEGRATED BACK-END VRAM DESIGN

The capabilities of the various VRAM designs, with their several levels of chip population, are shown in Table 3. Note: Although not shown, each level of chip loading for a given design includes the capabilities of the smaller chip population(s).

If maximum IBM 8514/A resolution is desired, this design should be implemented to at least the 8-chip level; implementation at the 16-chip level provides for the extended capability of doubling the number of screen pages supported by the 8-

| PIN NUMBER | PIN SYMBOL | DESCRIPTION                                                                                                                                                                          |
|------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19, 16-10  | MA7-MA0    | Low order address lines, into all quads.                                                                                                                                             |
| 34         | LA13       | Used as high-order address bit (MA8) for quads Q1, Q3, and their counterparts, in all designs.                                                                                       |
| 35         | LA24       | Used as high-order address bit (MA8) for quads Q2, Q4, and their counterparts, in all designs.                                                                                       |
| 22         | RAS0       | Row Address Strobe 0 (Quads 1 & 2)                                                                                                                                                   |
| 23         | RAS1       | Row Address Strobe 1 (Quads 3 & 4)                                                                                                                                                   |
| 20         | CAS12      | Column Address Strobe 1 (Quads 1 & 2)                                                                                                                                                |
| 21         | CAS34      | Column Address Strobe (Quads 3 & 4)                                                                                                                                                  |
| 31-24      | WE7-WE0    | Pixel data Write Enable lines to enable writing<br>into VRAM on the PD bus (bidirectional Parallel<br>Data bus, between VRAM and DP; A given quad<br>receives either WE0-3 or WE4-7. |
| 32         | DT/OE      | Transfer cycle control and serial data output<br>enable, used by all quads.                                                                                                          |

## TABLE 4. PAM PIN INTERFACE TO VRAM

chip version. See Appendix A for an illustration of the 16-chip version with indications of which chips should be left unpopulated if field upgradeable 4chip and/or 16-chip versions are to be produced. The same diagram can also serve as the basis for an 8-chip design, with half of those chips omitted for future field upgrade if desired.

See Appendix A for a detailed connection drawing for VRAM to PAM and PDM.

Tables 4 and 5 show the PAM and PDM pins used to form the VRAM interface. See Appendix A for VRAM design diagrams.

All the Pins in Table 4 drive control signals generated by the MIC.

The PD Pixel Data bus is managed by the Data Processor module (DP); all other pins in Table 5 are managed by the Display Processor (DSP).

WE0-3 are for pixel positions 0-3, respectively. In turbo mode, WE4-7 are for positions 4-7. For x8 mode, WE4-7 are the same as WE0-3.

In the VRAM design diagrams (see Appendix A), the PD lines connect to the parallel data ports of the VRAM chips, while the SD lines connect to their serial data ports. The different resolution modes require different memory addressing schemes to configure the display memory properly for screen pixel position.

#### 3.2.2 EXTERNAL BACK-END VRAM DESIGN

See Appendix A for an illustration of the 16-chip version with external back-end support. A Brooktree 8-bit video DAC BT458 is used.

## 3.3 VIDEO DAC AND INTERFACE SUB-SYSTEM

This section includes the following information for the board designer:

Routing of VRAM pixel data to the DAC. This involves two alternative designs, depending on weather back-end support is performed by the WD9500-SET1 or by external components.

Routing of control information from the WD9500-SET1 to the DAC and the monitor.

Signal routing in support of "VGA modes", in which the monitor is driven by control and data signals originating off-board, in the system VGA, and passed through to the monitor from the auxiliary extension connector.

| PIN NUMBER                        | PIN SYMBOL                    | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 90-93, 95-98, 100-114,<br>117-125 | PD31-PD0                      | Parallel Data bus connecting the DP module to<br>the VRAM block; data is bidirectional. (This is the<br>path through which the DP first reads, then<br>rewrites pixels in support of drawing operations).                                                                                                                                                                                                                                                                                                                                                                                                             |
| 46-49, 52-67, 71-82               | SD31-SD0                      | Serial Data bus, in VRAM designs with integrated<br>back-end support, this is the path by which<br>screen refresh data is extracted (by a transfer<br>cycle) from the serial ports of the VRAM chips<br>and then moved to the DSP module for serializing<br>and multiplexing before being sent to the DAC. In<br>VRAM designs with external back-end support,<br>the serial data bus to the DSP is not used; in-<br>stead, the DSP reconfigures itself to use some of<br>these pins (SD0, SD1, SD4, SD5, SD6) as output<br>drivers for additional control signals to the VRAM<br>(see External Back-End VRAM Design). |
| 87,85,86,84                       | SE12A, SE34A,<br>SE12B, SE34B | Serial Data Output Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 88                                | SC13                          | Serial Data Clock 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 89                                | SC24                          | Serial Data Clock 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| The following pins are ch         | nanged for external back-e    | nd support:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 82                                | SC3 (SD0)                     | Serial Data Clock 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 81                                | SC2(SD1)                      | Serial Data Clock 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 78                                | SEL0(SD4)                     | Mux Select 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 77                                | SEL1(SD5)                     | Mux Select 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 76                                | LDCLK (SD6)                   | LDCLK signal to the DAC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

## TABLE 5. PDM PIN INTERFACE TO VRAM

Palette access, with the board design option of implementing "flicker-free mode", a Western Digital extension.

Note that a related topic, WD9500-SET1 recognition of monitor type, is grouped with other configuration strapping issues, and is discussed later in this chapter.

The PDM pins associated with the video interface subsystem are all outputs from the DSP, and are shown in Table 6.

Appendix B describes board implementation of the video DAC and interface subsystem with integrated and external back-end support. The flicker-free option applies to both and is discussed later. The WD9500-SET1 chip set supports INMOS IMS G171/176/178, Brooktree BT471/478 and compatible video DACs for 8514/A modes. It also supports Brooktree BT451/458 and compatible DACs for Western Digital enhanced 1280x1024 mode. The Brooktree BT471 DACs include a 256x18 palette, loaded with 6-bit R, G, and B color intensity values; the high two bits of the 8-bit data lines supplying these values are ignored. The BT478 substitute a 256x24 palette, with all eight bits used for finer control of color. The DAC8 pin from the PAM can be used to select 6-bit or 8-bit palette fields. Note that the palette overlay capabilities are not used; the DAC's RS2 and OL0-OL3 pins should be tied down. Without the flicker-free option, CPU software writes data into the DAC's color palette on the low eight bits of the system CPU data bus.

| PIN NUMBER   | PIN SYMBOL | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                           |
|--------------|------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30-27, 24-21 | VDATA0-7   | 0    | With integrated back-end support, these<br>pins output the video data for the DAC. With<br>external back-end support, they are not<br>used for this purpose, since the DAC<br>receives its data from the external logic<br>within the VRAM block. In both cases, how-<br>ever, these same pins are the source of<br>palette-loading data in flicker-free mode. (tri-<br>state output) |
| 132          | SELVD      | 0    | With the flicker-free design option, this pin<br>selects the source of palette-loading data to<br>be either the low eight bits of the PC data<br>bus (normal mode) or VDATA0-7 (flicker-free<br>mode). SELVD is also the tri-state control<br>signal for DACRD and DACWR from the<br>PAM. When high, PAM DACRD and<br>DACWR signals are disabled.                                     |
| 25           | VCLK       | 0    | Video clock for the DAC (tri-state output)                                                                                                                                                                                                                                                                                                                                            |
| 20           | BLANK      | 0    | Video blank signal for the DAC (tri-state out-<br>put)                                                                                                                                                                                                                                                                                                                                |
| 31           | DACRD      | 0    | DAC palette read. Note that data read from<br>the palette is always routed to the PC data<br>bus in the CPU interface logic.                                                                                                                                                                                                                                                          |
| 32           | DACWR      | 0    | DAC palette write (see SELVD above)                                                                                                                                                                                                                                                                                                                                                   |
| 33           | HSYNC      | 0    | Horizontal sync to the monitor (tri-state out-<br>put).                                                                                                                                                                                                                                                                                                                               |
| 34           | VSYNC      | 0    | Vertical sync to the monitor (tri-state output)                                                                                                                                                                                                                                                                                                                                       |
| 42           | ENVGA      | 0    | Enables VGA pass-through mode. This sig-<br>nal selects the source of video data to the<br>DAC (either VDATA0-7 from the PDM or P0-<br>7 from the auxiliary vedeo extension). It also<br>selects the control sitgnals to the DAC<br>(either VCLK and BLANK from the PDM, or<br>HSYNC and VSYNC from the PDM, or<br>HSYNC and VSYNC from the auxiliary video<br>extension).            |
| 76           | LDCLK      | 0    | For external back-end support. This output<br>signal drives the LD (load) input of the<br>BT458/451 DAC, where it synchronizes the<br>serialization of the 32 bits of pixel data from<br>the VRAM into four 8-bit pixel color selec-<br>tions. With integrated back-end support this<br>pin is SD6 of the serial data bus from VRAM.                                                  |

## TABLE 6. PDM PIN INTERFACE TO VIDEO SUBSYSTEM

25

| PIN NUMBER    | PIN SYMBOL | I/O | DESCRIPTION              |
|---------------|------------|-----|--------------------------|
| 54, 53, 49-37 | BSA0-BSA14 | 0   | EPROM BIOS address lines |
| 36            | BSOE       | 0   | EPROM BIOS output enable |

## TABLE 7. EPROM INTERFACE PINS

|                      | MICRO CHANNEL | AT BUS      |             |
|----------------------|---------------|-------------|-------------|
|                      |               | IAD5 = 0*   | IAD5 = 1*   |
| 2K (Fixed)           | C6800-C6FFF   | C8800-C8FFF | D8800-D8FFF |
| 4K (Bank Selectable) | C7000-C7FFF   | C9000-C9FFF | D9000-D9FFF |
| 2K (Fixed)           | CA000-CA7FFF  | N/A         | N/A         |

## TABLE 8. BIOS EPROM ADDRESS MAPPING

The WD9500-SET1 intercepts CPU addressing and controls DAC access using the low two bits of its EPROM address bus, BIOSA1 and BIOSA0. When the flicker-free option is incorporated into the board design, as shown in Appendix B, the CPU software can invoke flicker-free mode. In this mode, palette data is buffered by the WD9500-SET1 and released to the DAC over the VDATA0-7 lines, with the SELD control signal activated to select the VDATA lines in preference to the system data bus. Routing of the latter lines to the DAC via the SELD multiplexer is still required, both to allow for non-flicker- free mode (8514/A emulation) and for palette reads.

Appendix B shows the implementation of 1280x1024 resolution with external back-end support and two DACs. The fast DAC BT451/458 is used for 1280x1024 and 1024x768 resolutions. The slow DAC BT471/478 is used for VGA pass-through. The flicker-free capabilities do not apply to that DAC.

#### 3.4 OTHER BOARD DESIGN ELEMENTS 3.4.1 EPROM

A 27256 32K UV EPROM is used on the Micro Channel board to store the Western Digital BIOS extension plus two configuration parameters that the WD9500-SET1 loads into internal registers upon board reset: the POS ID (for PS/2 Micro Channel system integration), chosen by the customer, and a VRAM wait-state control parameter (dependant upon characteristics of the VRAM chips chosen for the board, and automatically selected from among four choices depending on how two configuration parameter pins are strapped); see Appendix C.

The EPROM is remapped for the AT bus board because of VGA conflict and widespread use of Shadow RAM in 80386 machines. BIOS EPROM Address mapping for WD9500-SET1 chip set is as stated in Table 7.

For PC/AT and compatibles, 2 sets of addresses that minimize memory conflict with other products have been selected, i.e. C8800-C9FFF or D8800-D9FFF. Either address can be selected by a jumper in a board design.

The EPROM is accessed through the CIU on the PAM, which generates addressing for the EPROM and activated an output enable line. Data from EPROM ties to both the CIU and the system data bus through an 8-bit connection to the internal data bus. (See Figures 1 and 2). The PAM pins involved are shown in Table 8.

## 3.4.2 PAM-PDM INTERFACE

The PAM and PDM are connected to each other through a 22-pin interface. Both chips include an internal bus interface unit (IBIU) which controls inter-chip communication; one of its functions is to buffer data transfers larger than eight bits, since the general purpose inter-chip bus is eight-bits wide due to pin count constraints. Inter-chip communication is transparent to the user. See Table 9.

| PAM PIN NUMBER | SIGNAL DIRECTION  | PDM PIN NUMBER | PIN SYMBOL |
|----------------|-------------------|----------------|------------|
| PAM 125-132    | $\leftrightarrow$ | PDM 9-2        | IAD0-7     |
| . PAM 124      | $\rightarrow$     | PDM 10         | IADSTAT    |
| PAM 8          | $\rightarrow$     | PDM 126        | RWCAS      |
| PAM 123        | $\rightarrow$     | PDM 11         | RD/WR      |
| PAM 122        | $\rightarrow$     | PDM 12         | AS         |
| PAM 121        | $\rightarrow$     | PDM 13         | DS         |
| PAM 114        | ←                 | PDM 19         | RMWE       |
| PAM 2          | ←                 | PDM 132        | SELVD      |
| PAM 119        | ←                 | PDM 15         | SLC        |
| PAM 118        | <i>←</i>          | PDM 16         | SLD        |
| PAM 6          | $\rightarrow$     | PDM 128        | WROE       |
| PAM 3          | $\rightarrow$     | PDM 131        | MDT0       |
| PAM 4          | $\rightarrow$     | PDM 130        | MDT1       |

## TABLE 9. INTERCHIP INTERFACE PINS

## 3.4.3 CONFIGURATION STRAPPING

The WD9500-SET1 configures itself to its board design environment by latching the values of certain strapped input pins on the rising edge of the CPU's RESET signal. (It also reads two parameters from the EPROM, as mentioned earlier). One of these pins, which distinguishes between the Micro Channel and PC/AT bus CPU interfaces, is dedicated to this purpose. Three other dedicated pins receive monitor type information. The remaining pins, which all deal with VRAM configuration information, are actually part of the inter-chip communication interface; the strapped values are driven to the inter-chip lines through tri-state buffers. See Tables 10 - 13.

Note: If a field-upgradeable VRAM design is selected (with the VRAM chips partially populated), the appropriate strappings should be implemented with jumpers, switches or some other method that allows the use to change the strapped values in the course of field upgrade.

## 3.4.4 CLOCK CONSIDERATIONS

A major design element of the WD9500-SET1 is the provision for two separate and independent clock rates; one for drawing operations, the other for screen refresh. In particular, faster monitors can be used without changing the clock rate of the drawing facilities within the WD9500-SET1, and conversely, use of slower monitors will not degrade drawing speed.

The system clock signal, provided by an external 60MHz oscillator, drives the drawing process within the WD9500-SET1, and is used to generated VRAM timing. The pixel clock, used to drive the screen refresh process, is selected from among eight oscillator outputs to accommodate different types of monitors. Three PDM output signals, CLKSEL2, CLKSEL1, and CLKSEL0, are provided to make the selection.

In the United States, non-interlaced video monitors use a vertical refresh frequency of 60Hz; in Europe, the standard is 70Hz. Including the interlaced IBM 8514 monitor (vertical frequency 43.48Hz) produces Table 14, in which the "Pixel Frequency" is the frequency of the oscillator selected by CLKSEL2, CLKSEL1, and CLKSEL0 as input to the PDM's PCLK pin.

The typical WD9500-SET1 board will therefore be configured with oscillators at 25.28, 44.90 and 64.37MHz for use with U.S. standard monitors, or with oscillators at 31.40, 44.90, and 74.16MHz for use with European standard monitors. A more am-

25

| PAM PIN<br>NUMBER | PDM PIN<br>NUMBER | PIN SYMBOL | DESCRIPTION                                                                                                                                                                                            |
|-------------------|-------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 120               |                   | MC/AT      | High if Micro Channel; low if PC/AT bus                                                                                                                                                                |
|                   | 36-38             | MID2-MID0  | Monitor ID Bits 2-0                                                                                                                                                                                    |
| 130               | 3                 | IAD5       | EPROM location for AT bus design (not used in<br>Micro Channel); low for EPROM memory ad-<br>dress at C8800H-C9FFFH, high for address at<br>D8800H-D9FFFH.                                             |
| 131               | 3                 | IAD6       | Test Mode. Low for test mode; high for normal operation.                                                                                                                                               |
| 132               | 2                 | IAD7       | DAC Type.Low foar 6-bit DAC; high for 8-bit DAC.                                                                                                                                                       |
| 129               | 5                 | IAD4       | VRAM Chip Speed. Low for -8 spec; high for -10 spec.                                                                                                                                                   |
| 128               | 6                 | IAD3       | External Back-End. This pin specifies the maxi-<br>mum resolution allowed by VRAM design: low for<br>1280 x 1024 resolution (external back-end re-<br>quired), high for 1024 x 768 (internal back-end) |
| 125               | 9                 | IAD0       | VRAM Chip Type. Must be tied high.                                                                                                                                                                     |
| 126               | 8                 | IAD1       | Chip Count 0. Low order bit of 2-bit VRAM chip<br>count field (see below)                                                                                                                              |
| 127               | 7                 | IAD2       | Chip Count 1. High order bit of 2-bit VRAM chip count field (see below.                                                                                                                                |
| 122               | 12                | ĀS         | Monitor Type 0 (see below)                                                                                                                                                                             |
| 123               | 11                | RD/WR      | Monitor Type 1 (see below)                                                                                                                                                                             |

TABLE 10. CONFIGURATION STRAPPING PINS

|          | Chip Count 1 | Chip Count 0 |
|----------|--------------|--------------|
| 4 Chips  | 0            | 0            |
| 8 Chips  | 0            | 1            |
| 16 Chips | 1            | 0            |
| Reserved | 1            | 1            |

## TABLE 11. CHIP COUNT STRAPPING

| Type of<br>Monitor | Monitor Type 0 | Monitor Type 1 |
|--------------------|----------------|----------------|
| 8514 Display       | 0              | 0              |
| 60 Hz monitor      | 0              | 1              |
| Reserved           | 1              | 0              |
| 70 Hz monitor      | 1              | 1              |

## TABLE 12. MONITOR SELECTION

bitious design might include all seven clock frequencies, with the MID2-MID0 inputs (as per "Configuration Strapping" earlier in this chapter) aiding in the selection.

The WD9500-SET1 pins involved in clock signal generation and use are summarized in Table 14.

| MID2 | MID1 | MID0          | MONITOR TYPE                                          |  |
|------|------|---------------|-------------------------------------------------------|--|
| 0    | 0    | 0 Not Defined |                                                       |  |
| 0    | 0    | 1             | Not Defined                                           |  |
| 0    | 1    | 0             | IBM 8514 (color monitor, 1024 x 768 interlaced)       |  |
| 0    | 1    | 1             | Not defined                                           |  |
| 1    | 0    | 0             | Not defined                                           |  |
| 1    | 0    | 1             | IBM 8503 (monochrome, 640 x 480, non-inter-<br>laced) |  |
| 1    | 1    | 0             | IBM 8513 (color, 640 x 480, non-interlaced & 8514     |  |
| 1    | 1    | 1             | Other display*                                        |  |

Note: MID2-0 have internal pull-up resistors. During reset, MID2-0 can also be used to test PDM internal counters. For in-circuit board test, MID2-0 should be high when REST is asserted.

## TABLE 13. MONITOR ID INTERPRETATION

|   | CLKSEL |   | <b>RESOLUTION*</b> | VERTICAL FRE- | HORIZONTAL | PIXEL        |  |
|---|--------|---|--------------------|---------------|------------|--------------|--|
| 2 | 1      | 0 |                    | QUENCY        | FREQUENCY  | FREQUENCY    |  |
| 0 | 0      | 0 | 640 X 480N         | 60 Hz         | 31.47 KHz  | 25.18 MHz    |  |
| 1 | 0      | 0 | 640 X 480N         | 70 Hz         | 37.28 KHz  | 31.32 MHz    |  |
| 0 | 0      | 1 | 1024 X 768I        | 43.48 Hz      | 35.52 KHz  | 44.90 MHz    |  |
| 1 | 0      | 1 | 1280 X 1024N       | 60 Hz         | 63.78 KHz  | 109.64 MHz** |  |
| 0 | 1      | 0 | 1280 X 1024N       | 70 Hz         | 74.83 KHz  | 136.71 MHz** |  |
| 0 | 1      | 1 | 1024 X 768N        | 60 Hz         | 49.06 KHz  | 63.98 MHz    |  |
| 1 | 1      | 1 | 1024 X 768N        | 70 Hz         | 56.17 KHz  | 74.16 MHz    |  |

## \*N = Non-interlaced

## I = Interlaced

\*\* In these cases the oscillator frequency must be halved (to 54.82 MHz or 68.36 MHz) before being connected to the PCLK input pin of the PDM. Since this resolution requires external back-end support, however, the original frequency, as shown, must remain intact to drive the

## TABLE 14. PIXEL CLOCK FREQUENCY DERIVATION

| NAME        | PAM/PDM PIN#   | I/O | DESCRIPTION                                               |
|-------------|----------------|-----|-----------------------------------------------------------|
| SCLK        | PAM 113/PDM 39 | 1   | System clock input; requires 60 MHz                       |
| CLKSEL2     | PDM 43         | 0   | Selects from seven frequencies for PCLK (see Table 14)    |
| CLKSEL1     | PDM 44         | 0   | See Table 14                                              |
| CLKSEL0     | PDM 45         | 0   | See Table 14                                              |
| PCLK        | PDM 68         | 1   | Pixel clock input                                         |
| VCLK        | PDM 25         | 0   | DAC clock source                                          |
| LDCLK (SD6) | PDM 76         | 0   | LD signal for BT451/458 DAC for external back-end support |

## TABLE 15. CLOCK PIN SUMMARY

## 4.0 ABSOLUTE MAXIMUM RATINGS AND DC CHARACTERISTICS

| PAM ELECTRICAL SPECIFICATIONS                   |            |                                     |               |
|-------------------------------------------------|------------|-------------------------------------|---------------|
| PAM AC Specifications                           |            |                                     |               |
| CLK period: 16 ns minimum, 16.7 ns atypica      |            |                                     |               |
| CLK rise and fall time (0.4 v to 2.4 v): 2.5 ns | maximum    |                                     |               |
| All outputs rise and fall time (10% to 90%): t. | b.d.       |                                     |               |
| Input capacitance: 10 pF maximum                |            |                                     |               |
|                                                 |            |                                     |               |
| PAM DC SPECIFICATIONS                           |            |                                     |               |
| Absolute maximum ratings:                       |            |                                     |               |
| Voltages on all inputs and outputs with respe   | ect to GND | -0.3 V to 7.0 V                     | V             |
| Operating ambient temperature                   |            | $0^{\circ}C \le TA \le 65^{\circ}C$ |               |
| Storage temperature                             |            | -65°C to 150°C                      |               |
|                                                 |            |                                     |               |
| DC Characteristics                              |            |                                     |               |
|                                                 | Minimum    | Maximum                             | Unit          |
| Supply voltage (VCC)                            | 4.75       | 5.25                                | Volts         |
| Input low voltage (VIL)                         | -0.3       | 0.8                                 | Volts         |
| Input high voltage (VIH)                        | 2.0        | VCC                                 | Volts         |
| Output low voltage (VOL)                        |            | 0.4                                 | Volts         |
| Output high voltagae (VOH)                      | 2.4        |                                     |               |
| Input leakage current (ILI)                     |            | ± 10                                | μ <b>A</b> *  |
| Tri-state output leakage current (IOL)          |            | ± 10                                | μ <b>A</b> ** |
| Power supply current (ICC)                      |            | t.b.d.                              | mA            |

\*VIN = 0 to VCC \*\*VOUT = 0.4V to VCC

Note: All inputs have static charge and latch up protection circuits. All inputs, including bi-directional pads, have 20K ohm pull-up resistors.

## **TABLE 16. PAM ELECTRICAL SPECIFICATIONS**

| SIGNAL NAME | I/O | IOL (Min) @0.4V | IOH (Min) @ 2.4V | Capacitive Load-<br>ing |
|-------------|-----|-----------------|------------------|-------------------------|
| D15-0       | I/O | 1.0 mA          | 200 μA           | 75 pF                   |
| CDDS16      | 0   | 2.0 mA          | 200 μA           | 250 pF                  |
| ĪRQ         | 0   | 2.0 mA          | 200 μA           | 250 pF                  |
| CHRDY       | 0   | 2.0 mA          | 200 μA           | 250 pF                  |
| SFDBK       | 0   | 2.0 mA          | 200 μA           | 250 pF                  |
| BIOSOE      | 0   | 1.0 mA          | 200 μA           | 50 pF                   |
| BIOSA14-0   | 0   | 1.0 mA          | 200 μA           | 50 pF                   |
| DBEN        | 0   | 1.0 mA          | 200 μA           | 50 pF                   |
| DBDIR       | 0   | 1.0 mA          | 200 μA           | 50 pF                   |
| WROE        | 0   | 1.0 mA          | 200 μA           | 50 pF                   |
| DACWR       | 0   | 1.0 mA          | 200 μA           | 100 pF                  |
| DACRD       | 0   | 1.0 mA          | 200 μA           | 100 pF                  |
| DAC8        | 0   | 0.5 mA          | 200 μA           | 50 pF                   |
| RWCAS       | 0   | 1.0 mA          | 200 μA           | 50 pF                   |
| IADSTAT     | 0   | 1.0 mA          | 200 μA           | 50 pF                   |
| IAD7-0      | I/O | 1.0 mA          | 200 μA           | 50 pF                   |
| RD/WR       | 0   | 1.0 mA          | 200 μA           | 50 pF                   |
| ĀS          | 0   | 1.0 mA          | 200 μA           | 50 pF                   |
| DS          | 0   | 1.0 mA          | 200 μA           | 50 pF                   |
| SWAP        | 0   | 1.0 mA          | 200 μA           | 50 pF                   |
| MDT2-0      | 0   | 1.0 mA          | 200 μA           | 50 pF                   |
| MA7-0       | 0   | 1.0 mA          | 200 μA           | 130 pF                  |
| LA13        | 0   | 1.0 mA          | 200 μA           | 80 pF                   |
| LA24        | 0   | 1.0 mA          | 200 μA           | 80 pF                   |
| LA24        | 0   | 1.0 mA          | 200 μA           | 100 pF                  |
| RAS1        | 0   | 1.0 mA          | 200 μA           | 100 pF                  |
| RAS0        | 0   | 1.0 mA          | 200 μA           | 100 pF                  |
| CAS12       | 0   | 1.0 mA          | 200 μA           | 100 pF                  |
| CAS34       | 0   | 1.0 mA          | 200 μA           | 100 pF                  |
| WE7-0       | 0   | 1.0 mA          | 200 μA           | 50 pF                   |
| DTOE        | 0   | 1.0 mA          | 200 μA           | 160 pF                  |

TABLE 17. PAM OUTPUT SPECIFICATIONS

## PDM ELECTRICAL SPECIFICATIONS

PAM AC Specifications

SCLK period: 16 ns minimum, 16.7 ns atypical.

PCLK PERIOD: 13.5 ns minimum; 15.4 OR 22.2 ns typical.

All outputs rise and fall time (10% to 90%): t.b.d.

Input capacitance: 10 pF maximum

## PDM DC SPECIFICATIONS

Absolute maximum ratings:

| Voltages on all inputs and outputs with respect to GND | -0.3 V to 7.0 V  |
|--------------------------------------------------------|------------------|
| Operating ambient temperature                          | 0°C ≤ TA ≤ 65° C |
| Storage temperature                                    | -65°C to 150°C   |

#### **DC** Characteristics

|                                        | Minimum | Maximum | Unit         |
|----------------------------------------|---------|---------|--------------|
| Supply voltage (VCC)                   | 4.75    | 5.25    | Volts        |
| Input low voltage (VIL)                | -0.3    | 0.8     | Volts        |
| Input high voltage (VIH)               | 2.0     | VCC     | Volts        |
| Output low voltage (VOL)               |         | 0.4     | Volts        |
| Output high voltagae (VOH)             | 2.4     |         |              |
| Input leakage current (ILI)            |         | ± 10    | μ <b>A</b> * |
| Tri-state output leakage current (IOL) |         | ± 10    | μΑ**         |
| Power supply current (ICC)             |         | t.b.d.  | mA           |

\*VIN = 0 to VCC \*\*VOUT = 0.4V to VCC

Note: All inputs have static charge and latch up protection circuits. All inputs, including bi-directional pads, have 20K ohm pull-up resistors.

## TABLE 18. PDM ELECTRICAL SPECIFICATIONS

2 5

| SIGNAL NAME                   | I/O | IOL (Min) @0.4V | IOH (Min) @ 2.4V | Capacitive Load-<br>ing |
|-------------------------------|-----|-----------------|------------------|-------------------------|
| IAD7-IAD0                     | I/O | 4.20 mA         | 200 μA           | 50                      |
| RMWE                          | 0   | 1.00 mA         | 200 µA           | 50                      |
| SLC                           | 0   | 4.20 mA         | 200 µA           | 50                      |
| SLD/TOUT                      | 0   | 4.20 mA         | 200 μA           | 50                      |
| PD31-PD0                      | I/O | 4.20 mA         | 200 μA           | 50                      |
| VCLK                          | 0   | 4.20 mA         | 200 μA           | 30                      |
| HSYNC                         | 0   | 4.20 mA         | 200 μA           | 50                      |
| VSYNC                         | 0   | 4.20 mA         | 200 μA           | 70                      |
| BLANK                         | 0   | 4.20 mA         | 200 μA           | 70                      |
| VDATA7-VDATA0                 | 0   | 4.20 mA         | 200 μA           | 30                      |
| DACWR<br>(DACWE)              | 0   | 4.20 mA         | 200 μA           | 30                      |
| DACRD<br>DACRD)               | 0   | 4.20 mA         | 200 μA           | 50                      |
| SELVD                         | 0   | 4.20 mA         | 200 μA           | 50                      |
| CLKSEL2-<br>CLKSEL0           | 0   | 0.80            | 200 μA           | 50                      |
| ENVGA                         | 0   | 4.80 mA         | 200 μA           | 100                     |
| SE12A, SE34A,<br>SE12B, SE34B | 0   | 4.20 mA         | <u>200 μ</u> Α   | 70                      |
| SC13, SC24                    | 0   | 4.20 mA         | 200 μA           | 70                      |
| SD6, SD5                      | I/O | 4.20 mA         | 200 μA           | 100                     |

## TABLE 19. PDM OUTPUT SPECIFICATIONS

## 5.0 AC TIMING CHARACTERISTICS

To be supplied.

25

## 6.0 WD9500 REGISTERS

Although a WD9500 based board is significantly more capable than the IBM 8514/A, especially when configured with sufficient VRAM, the base mode of the board's operations is that of exact 8514/A emulation, including exact compatibility with the 8514/A's user-accessible registers.

The WD9500 internal registers that are compatible with the IBM 8514/A are defined in this section. A summary of 8514/A compatible registers is shown in Table 25 and Table 26 respectively. All WD9500 registers, except DAC interface registers, are 16-bit word-addressed. The unused bits are either not shown or marked the letter U in the description of the register definitions below. The reserved bits are marked with the letter R both unused and reserved bits default to 0.

## 6.1 DAC INTERFACE REGISTERS

The 8-bit registers in Table 21 are used to program the external video DAC. It is possible to write and read the DAC. Once the read/write index is written, multiple read/write operations can be performed without having to set the index for each entry.

| POS                                                                                                                                                          | register interface (Micro Channel | only)             |  |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-------------------|--|--|--|--|--|--|--|--|
| The POS registers are used to identify the WD9500 to IBM's setup program. They operate only when the CDSETUP pin goes low. Returns POS ID LSByte from EPROM. |                                   |                   |  |  |  |  |  |  |  |  |
| SETUP MODE<br>IDENTIFICATION                                                                                                                                 |                                   |                   |  |  |  |  |  |  |  |  |
| Read only                                                                                                                                                    |                                   | Setup address 100 |  |  |  |  |  |  |  |  |
| Returns POS ID LSByte from EPROM                                                                                                                             |                                   |                   |  |  |  |  |  |  |  |  |
| SETUP MODE<br>IDENTIFICATION                                                                                                                                 |                                   |                   |  |  |  |  |  |  |  |  |
| Returns POS ID MSByte from EF                                                                                                                                | PROM                              |                   |  |  |  |  |  |  |  |  |
| SETUP MODE<br>IDENTIFICATION                                                                                                                                 | SETUP_OPT                         | BYTE ACCESSIBLE   |  |  |  |  |  |  |  |  |
| Bit 0 of the Setup Mode Option Select register can be used by the host PC to disable the PWGA in case of an address conflict.                                |                                   |                   |  |  |  |  |  |  |  |  |
| Bit 0 = 1 Enable WD9500 registe                                                                                                                              | rs                                |                   |  |  |  |  |  |  |  |  |
| Bit 0 = 0 Disable WD9500 registe                                                                                                                             | ers                               |                   |  |  |  |  |  |  |  |  |

## TABLE 20. POS REGISTER INTERFACE (MICRO CHANNEL ONLY)

| COLOR<br>PROGRAMMING                         |     |                            | 8514/A       | VGA                                   |
|----------------------------------------------|-----|----------------------------|--------------|---------------------------------------|
| DAC Mask                                     | R/W | DAC_MASK                   | 02EA         | 03C6                                  |
| DAC Read Index                               | R/W | DAC_R_INDEX                | 02EB         | 03C7 (Write Only)<br>03C7 (Read Only) |
| DAC Write Indes                              | R/W | DAC_W_INDEX                | 02EC         | 03C8                                  |
| DAC Data                                     | R/W | DAC_DATA                   | 02ED         | 03C9                                  |
| The 851114/A DAC ca<br>mode (4AE8 bit 0 = 0) |     | out not read at the VGA ac | dresses when | in VGA pass-through                   |

## TABLE 21. DAC COLOR PROGRAMMING REGISTERS

Procedure to write to the DAC: (1) Set start write color index at 02ECH; (2) Write three bytes [RGB values] at 02EDH [The index auto increments the next write entry]; (3) Repeat step 2 until the desired number of entries have been programmed.

Procedure to read from the DAC: (1) Set start read color index at 02EBH. (2) Write three bytes [R. G. B. values] at 02EDH [The index auto increments to the next read entry]. (3) Repeat step 2 until the desired number of entries have been read.

## 6.2 ADVANCED FUNCTION CONTROL REGISTER (WRITE ONLY - 4AE8H)

Graphics mode is selected by writing to the Advanced Function Control (ADVFUNC\_CTL). This register is used by all modules within the WD9500.

| BIT  | FUNCTION                                                                                            |
|------|-----------------------------------------------------------------------------------------------------|
| 0    | Set to 0 for VGA pass-through<br>mode<br>Set to 1 for 8514/A graphics<br>mode                       |
| 1    | Mode extension - set to 1                                                                           |
| 2    | Screen Resolution<br>Set to 0 for 640 x 480 (25.18<br>MHz)<br>Set to 1 for 1024 x 768 (44.9<br>MHz) |
| 3    | Reserved for Mode Extension<br>Default = 0                                                          |
| 4-15 | Unused - Default = 0                                                                                |

| MNEMONIC     | NAME                           | ADDRESSS |
|--------------|--------------------------------|----------|
| H_TOTAL      | Horizontal Total Register      | 02E8     |
| H_DISP       | Horizontal Displayed Register  | 06E8     |
| H_SYNC_START | Horizontal Sync Start Register | 0AE8     |
| H_SYNC_WID   | Horizontal Sync Width Register | 0EE8     |
| V_TOTAL      | Vertical Total Register        | 12E8     |
| V_DISP       | Vertical Displayed Register    | 16E8     |
| V_SYNC_START | Vertical Sync Start Register   | 1AE8     |
| V_SYNC_WID   | Vertical Sync Width Register   | 1EE8     |
| DISP_CNTL    | Display Control Register       | 22E8     |

## TABLE 22. VIDEO TIMING SETUP REGISTER

## 6.3 VIDEO TIMING SETUP REGISTERS

There are nine registers for setting up video timing: four for horizontal, four for vertical, and one for control. Two sets of these registers (Table 3) are provided by WD9500 to allow video timing parameters to be pre-programmed and locked in for 640x480 and 1024x768 resolutions by Western Digital's BIOS. This extended feature is designed for interfacing with different monitors requiring different timing parameters. Once the timing parameters are locked in, application software that writes directly to the video registers will not need to be changed for different monitors. e.g. interlaced vs. non-interlaced. These registers affect the DSP module of the WD9500. The horizontal and vertical registers are set by the selected resolution. For example, 1024x768 is the graphics mode selected by the ADVFUNC\_CNTL Register, then the horizontal and vertical registers are set accordingly. The following tables show the format for the horizontal and vertical registers. Vertical timing is programmed in line resolution. Horizontal timing is programmed in 8-pixel resolution.

## 6.3.1 HORIZONTAL TOTAL REGISTER (WRITE ONLY - ADDRESS 02E8H)

| 7                                                                           | 6     | 5        | 4       | 3       | 2      | 1       | 0    |  |  |  |  |
|-----------------------------------------------------------------------------|-------|----------|---------|---------|--------|---------|------|--|--|--|--|
| Set                                                                         | numbe | or of ni | vols na | or lino | includ | ing bla | ank- |  |  |  |  |
| Set number of pixels per line, including blank-<br>ing. Eight pixel blocks. |       |          |         |         |        |         |      |  |  |  |  |

## 6.3.2 HORIZONTAL DISPLAYED (WRITE ONLY - ADDRESS 06E8H)

| 7 | 6                | 5 | 4 | 3        | 2      | 1       | 0    |
|---|------------------|---|---|----------|--------|---------|------|
| 0 |                  |   |   |          |        |         |      |
|   | numbe<br>Eight j |   |   | er line, | includ | ing bla | ank- |

#### 6.3.3 HORIZONTAL SYNC START REGISTER (WRITE ONLY -ADDRESS 0AE8H)

| 7                                             | 6   | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|-----------------------------------------------|-----|---|---|---|---|---|---|--|--|--|
|                                               |     |   |   |   |   |   |   |  |  |  |
| Set Horizontal Sync Start. Eight pixel incre- |     |   |   |   |   |   |   |  |  |  |
| men                                           | ts. |   |   |   |   |   |   |  |  |  |

#### 6.3.4 HORIZONTAL SYNC WIDTH REGISTER (WRITE ONLY -ADDRESS 0EE8H)

| 7    | 6 | 5      | 4       | 3 | 2 | 1                   | 0 |
|------|---|--------|---------|---|---|---------------------|---|
| 0    | 0 |        |         |   |   |                     |   |
| Bits |   | Set Ho | prizont |   |   | ositive)<br>h. Eigh |   |

## 6.3.5 VERTICAL TOTAL REGISTER (WRITE ONLY - ADDRESS 12E8H)

| 11 | 10    | 9   | 8     | 7     | 6     | 5      | 4   | 3 | 2 | 1 | 0 |
|----|-------|-----|-------|-------|-------|--------|-----|---|---|---|---|
|    |       |     |       |       |       |        |     |   |   |   |   |
| Se | et nu | mbe | er of | lines | s per | r frar | ne. |   |   |   |   |

#### 6.3.6 VERTICAL DISPLAYED REGISTER (WRITE ONLY - ADDRESS 16E8H)

| 11 | 10                            | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|----|-------------------------------|---|---|---|---|---|---|---|---|---|---|--|--|
|    |                               |   |   |   |   |   |   |   |   |   |   |  |  |
| Se | Set number of lines displayed |   |   |   |   |   |   |   |   |   |   |  |  |

Set number of lines displayed.

## 6.3.7 VERTICAL SYNC START REGISTER (WRITE ONLY - ADDRESS 1AE8H)

| 11 | 10                      | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|----|-------------------------|---|---|---|---|---|---|---|---|---|---|--|--|
|    |                         |   |   |   |   |   |   |   |   |   |   |  |  |
| Se | Set vertical sync start |   |   |   |   |   |   |   |   |   |   |  |  |

Set vertical sync start.

## 6.3.8 VERTICAL SYNC WIDTH POLARITY REGISTER (WRITE ONLY -ADDRESS 1EE8H)

| 7                                                                                    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------------------------------------------------------------------------------|---|---|---|---|---|---|---|
| 0                                                                                    | 0 |   |   |   |   |   |   |
| Bit 5 = Polarity (1 = negative; 0 = positive)<br>Bits 0-4 = Set Vertical Sync Width. |   |   |   |   |   |   |   |

## 6.3.9 DISPLAY CONTROL REGISTER (WRITE ONLY - ADDRESS 22E8H)

The Display Control DISP\_CNTL Register sets various control features for the display functions.

| BIT | POSITION                                                                                                                                                                                                                                |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1&2 | Specify resolution. These bits should match bits 2 and 3 of BEE8-5.                                                                                                                                                                     |
| 3   | Scan. Set to specifies a<br>double scan; 0 specifies a<br>single scan.                                                                                                                                                                  |
| 4   | Interlace. Set to 1 specifies in-<br>terlaced mode; 0 specifies<br>non-interlaced mode.                                                                                                                                                 |
| 5&6 | Enable Display. Together<br>these bits enable/reset the dis-<br>play. The display is enabled<br>when bits 5 and 6 are set to<br>01; and reset when set to 10.<br>These bits are not affected by<br>the locked-in extended fea-<br>ture. |

|                | 1024 x 768       |                                   |                     |                     | 640 x 480 (4 or 8)  |                     |
|----------------|------------------|-----------------------------------|---------------------|---------------------|---------------------|---------------------|
| Frame<br>Rate  |                  | 43 Hz<br>I                        | 60 Hz<br>NI         | 70 Hz<br>NI         | 60 Hz<br>NI         | 70 Hz<br>NI         |
| pclk           |                  | 44.90MHz<br>22.27ns               | 63.98MHz<br>15.63ns | 74.16MHz<br>13.46ns | 25.18MHz<br>39.92ns | 31.32MHz<br>31.93ns |
| 02EH           | Htotal           | 9d                                | a2                  | a4                  | 63                  | 68                  |
| 06E8           | Hdisplay         | 7f                                | 7f                  | 7f                  | 4f                  | 4f                  |
| 0AE8           | Hsync position   | 81                                | 83                  | 83                  | 52                  | 54                  |
| 0EE8           | Hsync & polarity | 16                                | 16                  | 16                  | 2c                  | 2c                  |
| 12E8           | Vtotal           | 660                               | 660                 | 642                 | 830(4)<br>418 (8)   | 848 (4)<br>426 (8)  |
| 16E8           | Vdisplay         | 5fb                               | 5fb                 | 5fb                 | 779(4)<br>3bb(8)    | 779 (4)<br>3bb (8)  |
| 1AE8           | Vsync position   | 600                               | 600                 | 600                 | 7a8 (4)<br>3d2 (8)  | 7b8 (4)<br>3de (8)  |
| 1EE8           | Vsync & polarity | 8                                 | 8                   | 8                   | 22                  | 22                  |
| 22E8           | Control          | 33                                | 23                  | 23                  | 21 (4)<br>23 (8)    | 21 (4)<br>23 (8)    |
| Htotal         | μ                | 28.25                             | 20.38               | 17.80               | 31.78               | 26.82               |
| Hdisp.         | μ                | 22.89                             | 16.00               | 13.81               | 25.42               | 20.44               |
| Hblank         | μ                | 5.37                              | 4.376               | 3.99                | 6.355               | 6.39                |
| Hsync          | μ                | 3.93                              | 2.751               | 2.373               | 3.813               | 3.07                |
| Hfporch        | μ                | 0.178                             | 0.375               | 0.323               | 0.636               | 1.02                |
| Hbporch        | μ                | 1.25                              | 1.250               | 1.294               | 1.906               | 2.30                |
| Vtotal         | ms               | 23.08                             | 16.65               | 14.29               | 16.68               | 14.24               |
| Vdisp.         | ms               | 21.70                             | 15.65               | 13.67               | 15.25               | 12.87               |
| Vblank         | ms               | 0.706<br>(even)<br>0.678<br>(odd) | 0.999               | 0.623               | 1.430               | 1.368               |
| Vsync          | ms               | 0.113                             | 0.082               | 0.071               | 0.079               | 0.067               |
| Vfporch        | ms               | 0.0141<br>(even)<br>0 (odd)       | 0.020               | 0.018               | 0.350               | 0.402               |
| Vbporch        | ms               | 0.579<br>(even)<br>0.565<br>(odd) | 0.897               | 0.534               | 1.00                | 0.898               |
| HS<br>polarity | ms               | +                                 | +                   | +                   | -                   | -                   |
| VS<br>polarity | ms               | +                                 | +                   | +                   | -                   | -                   |

## TABLE 23. CRT CONTROL REGISTER PARAMETERS AND TIMING

#### 6.4 ROM PAGE SELECT REGISTER (WRITE ONLY - ADDRESS 46E8 MC/36E8 AT)

The ROM Page Select (ROM\_PAGE\_SEL) Register is used by the C!U to enable ROM bank selection and select a bank of ROM. The register format for bank selection is shown below. Bit 3 enables/disables bank selection. This register is remapped to 36E8h for AT Bus because VGA used the 46E8h register.

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
| U | U | U | U | 1 |   |   |   |

Bits 0-2 select the ROM bank

| 210 | Select Bank |
|-----|-------------|
| 000 | 0           |
| 001 | 1           |
| 010 | 2           |
| 111 | 3           |
| 100 | 4           |
| 101 | 5           |
| 110 | 6           |
| 111 | 7           |

## 6.5 SUBSYSTEM CONTROL REGISTER (WRITE ONLY - ADDRESS 42E8H)

The Subsystem Control (SYBSYS\_CNTL) Register is used for interrupt and reset control of the WD9500 FIFO and other CPU interface functions. This register affects Bits 3-0 of the Subsystem status (SUBSYS\_CNTL) Register (see "Subsystem Status Register").

| BIT | POSITION                                                                                                                              |
|-----|---------------------------------------------------------------------------------------------------------------------------------------|
| 0   | Puts a 0 in the vertical sync<br>status bit of the IS Register<br>that can be read at address<br>42E8h. (1 = clear; 0 = no<br>change) |
| 1   | Puts a 0 in the GE busy<br>status bit of the IS Register;<br>readable at address 42E8h.<br>(1 = clear; 0 = no change)                 |

| BIT     | POSITION (CONT'D)                                                                                                                                                                                                 |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2       | Puts a 0 in the FIFO overflow<br>status bit of the IS Register;<br>readable at address 42E8h.<br>This bit is cleared at the end<br>of every line during a reac<br>across the plane. (1 = clear;<br>0 = no change) |
| 3       | Puts a 0 in the FIFO empty<br>status bit of the IS Register;<br>readable at address 42E8h.<br>(1 = clear; 0 = no change)                                                                                          |
| 8       | Enables/disables the vertical<br>sync interrupt. (1 = enable; 0<br>= disable)                                                                                                                                     |
| 9       | Enables/disables the GE busy interrupt. (1 = enable; 0 = disable)                                                                                                                                                 |
| 10      | Enables/disables the FIFO<br>overflow interrupt. (1 =<br>enable; 0 = disable)                                                                                                                                     |
| 11      | Enables/disables the FIFO<br>empty interrupt. (1 = enable;<br>0 = disable)                                                                                                                                        |
| 12 & 13 | Selects normal mode or test mode.                                                                                                                                                                                 |
| 14 & 15 | Graphic Engine Reset - Used to switch between normal mode and reset.                                                                                                                                              |

| Bit 13 | Bit 12     |           |
|--------|------------|-----------|
| 0      | <b>0</b> · | No Change |
| 0      | 1          | Normal    |
| 1      | 0          | Test      |

| Bit 15 | Bit 14 |           |
|--------|--------|-----------|
| 0      | 1      | Normal    |
| 1      | 0      | Reset     |
| 0      | 0      | No Change |

## 6.6 DRAWING CONTROL REGISTERS

There are sixteen registers involved in drawing control. These registers affect the operation of the GP, DP, MIC and CIU Current Y Position Register.

#### 6.6.1 CURRENT Y POSITION REGISTER (READ/WRITE - ADDRESS 82E8H)

The 16-bit CUR\_Y Register at address 82E8h uses Bits 10-0 to define the current position of Y for the pixel being drawn. The value is 11 bits unsigned. Bit 11 is reserved for higher resolution. WD9500's enhanced resolution (1280x1024) mode does not use this bit.

| BIT   | POSITION                         |
|-------|----------------------------------|
| 0-10  | Current Y of drawing point value |
| 11    | Reserved                         |
| 12-15 | Unused                           |

## 6.6.2 CURRENT X REGISTER (READ/WRITE - ADDRESS 86E8H)

The CUR\_X Register at address 82E8h uses Bits 10-0 to define the current position of X for the pixel being drawn. The value is 11 bits unsigned. Note that Bit 11 is reserved for higher resolution. WD9500's enhanced resolution (1280x1024) mode does not use this bit. The status of this register can be read.

| BIT   | POSITION                         |
|-------|----------------------------------|
| 0-10  | Current X of drawing point value |
| 11    | Reserved                         |
| 12-15 | Unused                           |

### 6.6.3 DESTINATION Y POSITION/AXIAL STEP CONSTANT REGISTER (WRITE ONLY - ADDRESS 8AE8H)

The command performed is specified by the Command (CMD) Register. Value is 12 bits unsigned when line drawing is specified. The minterm for the line drawing is: (Increment  $1 = 2^{*}(\min(|dx|,dy|))$ ).

| BIT                                     | POSITION                                    |  |  |
|-----------------------------------------|---------------------------------------------|--|--|
| Line Drawing N                          | Line Drawing Mode: Increment line parameter |  |  |
| 1.                                      |                                             |  |  |
| 0-11                                    | Defines increment 1 value                   |  |  |
| 12-15                                   | Unused                                      |  |  |
| BITBLT Copying Mode: Copy Y Destination |                                             |  |  |
| 0-10                                    | Defines Y destination                       |  |  |
| 11                                      | Reserved                                    |  |  |
| 12-15                                   | Unused                                      |  |  |

#### 6.6.4 DESTINATION X POSI-TION/DIAGONAL STEP CONSTANT REGISTER (WRITE ONLY -ADDRESS 8EE8H)

The command performed is specified by the Command (CMD) Register. Value is 12 bits unsigned when line drawing is specified. The minterm for the line drawing is: (Increment  $1 = 2^{*}(\min(|dx|,dy|))$ .

| BIT                  | POSITION                       |  |  |  |
|----------------------|--------------------------------|--|--|--|
| Line Drawing N<br>2. | Node: Increment line parameter |  |  |  |
| 0-11                 | Defines increment 2 value      |  |  |  |
| 12-15                | Unused                         |  |  |  |
| BITBLT Copyir        | ng Mode: Copy X Destination    |  |  |  |
| 0-10                 | Defines X destination          |  |  |  |
| 11                   | Reserved                       |  |  |  |
| 12-15                | Unused                         |  |  |  |

## 6.6.5 ERROR TERM REGISTER (READ/WRITE - 92E8H)

The minterm for the line drawing is: 2\*[min(dx|,|dy)]-max(|dx,dy|)-1 if starting x ending x, and 2\*[min(|dx,|dy|)] - max(|dk|,|dy|) if starting x = ending x. The status of this register, when read after line drawing, is sign extended to 16 bits.

| BIT   | POSITION                                                                                        |
|-------|-------------------------------------------------------------------------------------------------|
| 0-12  | Defines the delta for the cur-<br>rent line drawing. Value is 13<br>bits signed 2's complement. |
| 13-15 | Sign extension.                                                                                 |

#### 6.6.6 MAJOR AXIS PIXEL COUNT REGISTER (WRITE ONLY -ADDRESS 96E8H)

This parameter is used for line drawing. BITBLT, or rectangle commands. The value is 11 bits unsigned. When line drawing is specified, the minterm for the line drawing is: Line Parameter = max(|dx|,|dy|). For BITBLT or rectangle commands, Rectangle Width Value = Rectangle Width -1.

| BIT   | POSITION                                                                                                                  |
|-------|---------------------------------------------------------------------------------------------------------------------------|
| 0-10  | Defines either the width for a rectangle in BITBLT or rec-<br>tangle mode or defines the length of a line in a line draw. |
| 11-15 | Unused                                                                                                                    |

## 6.6.7 COMMAND REGISTER (WRITE ONLY - ADDRESS 9AE8H)

The CMD Register at Address 9AE8h provides commands for drawing. All parameters have to be set before this command is sent to activate the drawing.

| BIT   | POSITION                           |
|-------|------------------------------------|
| 0     | R/W: 1 = Write; 0 = Read.          |
| 1     | Pixel mode: 1 = multi; 0 = single. |
| 2     | Last pixel: $1 = off; 0 = on.$     |
| 3     | DIR type: 1 = deg; 0 = XY          |
| 4     | Draw: 1 = yes; 0 = no.             |
| 5-7   | Drawing Direction                  |
| 8     | Wait: 1 = yes; 0 = no.             |
| 9     | Bus select: 1 = 16; 0 = 8.         |
| 10    | Don't care                         |
| 11    | Reserved                           |
| 12    | Swap MSB/LSB: 1 = yes; 0 = no.     |
| 13-15 | Drawing function command           |

| BITS | DRAWING D   | IRECTION              |
|------|-------------|-----------------------|
| 765  | Bit 3 = 1   | Bit 3 = 0             |
| 000  | 0 degrees   | Y neg, X major, X neg |
| 001  | 45 degrees  | Y neg, X major, X pos |
| 010  | 90 degrees  | Y neg, Y major, X neg |
| 011  | 135 degrees | Y neg, Y major, X pos |
| 100  | 180 degrees | Y pos, X major, X neg |
| 101  | 225 degrees | Y pos, X major, X pos |
| 110  | 270 degrees | Y pos, Y major, X neg |
| 111  | 315 degrees | Y pos, Y major, X pos |

| BITS | DRAWING FUNCTION COMMAND                                                  |
|------|---------------------------------------------------------------------------|
| 765  |                                                                           |
| 000  | No operation                                                              |
| 001  | Draw line                                                                 |
| 010  | Fill rectangle (Hor. 1st by 4 hor.<br>pixels); Search & fill (see BEE8-A) |
| 011  | Fill rectangle (Vert. 1st by 2 vert.<br>pixels - see BEE8-A)              |
| 100  | Fill rectangle (vert. 1st by 4 hor. pixels)                               |
| 101  | Draw line (polygon boundary)                                              |
| 110  | BITBLT                                                                    |
| 111  | Not defined                                                               |

# 6.6.8 COMMAND REGISTER (WRITE ONLY - ADDRESS 9AE8H)

| BIT | FUNCTION                                                                                                  |
|-----|-----------------------------------------------------------------------------------------------------------|
| 0   | R/W: specifies a read operation<br>when set to 0 or a write operation<br>when set to 1.                   |
| 1   | Pixel Mode: specifies single pixel<br>mode when set to 0 or a multi-<br>pixel mode when set to 1.         |
| 2   | Last pixel Off: specifies the last<br>pixel drawn when set to 0; turned<br>off when set to 1.             |
| 3   | Dir type: specifies the type of line drawing direction as either radial                                   |
| 4   | Draw: Specifies draw when set to<br>1 and updates the drawing point<br>only when set to 0.                |
| 5-7 | Drawing Direction: Specifies the<br>direction of the draw using the<br>direction type indicated by Bit 3. |

1

25

|        |         |         |         |         | •       |         |         |         |                 |
|--------|---------|---------|---------|---------|---------|---------|---------|---------|-----------------|
|        |         |         |         | 4       | 3       | 2       | 1       | 0       |                 |
|        |         |         |         | Plane 3 | Plane 2 | Plane 1 | Plane 0 |         | 4-bit Bit Plane |
| 1      |         |         |         |         |         |         |         |         |                 |
| BITBLT | 7       | 6       | 5       | 4       |         |         |         |         |                 |
|        | Plane 6 | Plane 5 | Plane 4 | Plane 3 | Plane 2 | Plane 1 | Plane 0 | Plane 7 | 8-bit Bit Plane |
|        |         |         |         |         |         |         |         |         |                 |
|        | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |                 |
|        | Plane 7 | Plane 6 | Plane 5 | Plane 4 | Plane 3 | Plane 2 | Plane 1 | Plane 0 |                 |
|        |         |         |         |         |         |         |         |         |                 |

\* = Plane number corresponds to bit number for search and fill

For each plane: 1 = use source; 0 = do not use source

## FIGURE 4. BIT PLANE READ MASK REGISTER

| BIT   | FUNCTION (CONT'D)                                                                                                                                                                                                                                       |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8     | Wait: Provides a wait state when<br>set to 1 to allow waiting for CPU<br>data during functions such as<br>image transfer and texture line<br>drawing.                                                                                                   |
| 9     | Bus Select: Specifies that the 16-<br>bit data bus is selected when set<br>to 1; the 8-bit data bus is selected<br>when set to 0.                                                                                                                       |
| 10    | Future: Allows the PAM to inter-<br>face with two PDM chips. This<br>capability is not currently sup-<br>ported.                                                                                                                                        |
| 12    | Swap MSB/LSB: When set to 1,<br>specifies that the most significant<br>byte (MSB) be swapped with the<br>least significant byte (LSB) when<br>the 16-bit data bus is selected. Bit<br>12 is normally set to 0; the MSB<br>is drawn first, then the LSB. |
| 13-15 | Command type: Specify the com-<br>mands for drawing.                                                                                                                                                                                                    |

### 6.6.9 SHORT STROKE VECTOR TRANS-FER REGISTER (WRITE ONLY -ADDRESS 9EE8H)

Provides two types of data. Each byte specifies the length, direction, and move draw control for a short vector.

| BITS           | FUNCTION                                                                                                                                                                  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-3, 8-11      | Pixel line length                                                                                                                                                         |
| 4, 12          | Move/Draw: Indicates a drraw<br>function when set to 1; indicates a<br>move function when set to 0.                                                                       |
| 5-7, 13-<br>15 | Drawing direction: Specifies the direction of the draw when using the direction type, either radial-based or coordinate-based, as specified by Bit 3 of the CMD register. |

| BITS     | DRAWING DIRECTION                  |
|----------|------------------------------------|
| 15 14 13 | Command Register:                  |
| 765      | Bit 3 = 1 Bit 3 = 0                |
| 000      | 0 degrees X major, X neg (Left)    |
| 001      | 45 degrees X major, X pos (Right)  |
| 010      | 90 degrees Y major, Y neg (Up)     |
| 011      | 135 degrees Y major, Y neg (Up)    |
| 100      | 180 degrees X major, X neg (Left)  |
| 101      | 225 degrees X major, X pos (Right) |
| 110      | 270 degrees Y major, Y pos(Down)   |
| 111      | 315 degrees Y major, Y pos(Down)   |

## 6.6.10 BACKGROUND COLOR REGISTER (WRITE ONLY - ADDRESS A2E8H)

The BKGD\_COLOR Register specifies the background color. The MSB in this 8-bit word is not used.

## 6.6.11 FOREGROUND COLOR REGISTER (WRITE ONLY - ADDRESS A6E8H)

The FRGD\_COLOR Register specifies the foreground color. The MSB in this 8-bit word is not used

## 6.6.12 WRITE MASK REGISTER (WRITE ONLY - ADDRESS AAE8H)

Specifies the bit-plane selected for graphics or text update. The MSB in this word is not used.

| BIT | FUNCTION   |
|-----|------------|
| 0-7 | Planes 0-7 |

## 6.6.13 READ MASK REGISTER (WRITE ONLY - ADDRESS AEE8H)

Specifies the read source mask for Image read or fill operations. The value is the true mask rotated left one bit. Bit 0 is the mask for plane 7 and bits 1-7 are the mask bits for planes 0-6, respectively. However, for polygon fill, bits 2, 3, and 4 are for planes 2, 3, and 4, respectively. The MSB in this word is not used. See Figure 4.

## 6.6.14 COLOR COMPARE REGISTER (WRITE ONLY - ADDRESS B2E8H)

Specifies the comparison color. The MSB in this 8-bit word is not used.

## 6.6.15 BACKGROUND MIX REGISTER (WRITE ONLY - ADDRESS B6E8H)

Specifies the background mix. The MSB in this word is not used.

| BIT | FUNCTION               |
|-----|------------------------|
| 0-4 | Background mix command |
| 5,6 | Color select           |

| BITS<br>65 | BACKGROUND<br>SOURCE SELECT |  |
|------------|-----------------------------|--|
| 0 0        | BGC                         |  |
| 0 1        | FGC                         |  |
| 1 0        | CPU data                    |  |
| 1 1        | Display memory              |  |

## 6.6.16 FOREGROUND MIX REGISTER (WRITE ONLY - ADDRESS BAE8H)

Specifies the foreground mix. The MSB in this 16-bit word is not used.

| BIT  | FUNCTION               |  |
|------|------------------------|--|
| 0-4  | Foreground mix command |  |
| 5,6  | Color select           |  |
| 7-15 | Unused                 |  |

| BITS<br>6 5 | FOREGROUND<br>SOURCE SELECT |  |
|-------------|-----------------------------|--|
| 0 0         | BGC                         |  |
| 0 1         | FGC                         |  |
| 1 0         | CPU data                    |  |
| 1 1         | Display memory              |  |

| BITS 4-0 | FOREGROUND MIX COMMAND        |  |
|----------|-------------------------------|--|
| 00       | Not screen                    |  |
| 01       | Zero                          |  |
| 02       | One                           |  |
| 03       | Leave alone                   |  |
| 04       | Not new                       |  |
| 05       | Xor                           |  |
| 06       | Not screen xor new            |  |
| 07       | Overpaint                     |  |
| 08       | Not screen or not new         |  |
| 09       | Screen or not new             |  |
| 0A       | Not screen or new             |  |
| 0B       | Screen or new                 |  |
| 0C       | Screen and new                |  |
| 0D       | Not screen and new            |  |
| 0E       | Screen and not new            |  |
| 0F       | Not screen and not new        |  |
| 10       | Minimum                       |  |
| 11       | (Screen-new) without saturate |  |
| 12       | (New-screen) without saturate |  |

| BITS 4-0                     | FOREGROUND MIX COMMAND                     |  |
|------------------------------|--------------------------------------------|--|
| 13                           | (New+screen) without saturate              |  |
| 14                           | Maximum                                    |  |
| 15                           | (Screen-new)/2 without saturate            |  |
| 16                           | (New-screen)/2 without saturate*           |  |
| 17                           | Average = (new + screen)/2 w/o<br>saturate |  |
| 18                           | (Screen-new) with saturate                 |  |
| 19                           | (Screen-new) with saturate                 |  |
| 1A                           | (New-screen) with saturate                 |  |
| 1B                           | (New+screen) with saturate                 |  |
| 1C                           | (Screen-new)/2 with saturate               |  |
| 1D                           | (Screen-new)/2 with saturate               |  |
| 1E                           | (New-screen)/2 with saturate**             |  |
| 1F                           | (Screen + new)/2 with saturate             |  |
| *Borrow included in shifting |                                            |  |
| **Set to 0                   | n borrow = 1                               |  |

## 6.6.17 MULTIFUNCTION CONTROL REGISTER (WRITE ONLY -ADDRESS BEE8-0,1,2,3,4)

Specifies several drawing control parameters. Bits 15-12 control the use of this register when these bits are changed, the register changes function.

| BIT   | FUNCTION                           |
|-------|------------------------------------|
| 0-10  | Rectangle/clipping parameter value |
| 11    | Reserved (don't care for BEE8-0)   |
| 12-15 | Drawing select                     |

| 15 14 13 12 | ADDR   | PARAMETER                       |
|-------------|--------|---------------------------------|
| 0 0 0 0     | BEE8-0 | Minor Axis Pixel<br>Count Index |
| 0001        | BEE8-1 | Top Scissors<br>Index           |
| 0 0 1 0     | BEE8-2 | Left Scissors<br>Index          |
| 0011        | BEE8-3 | Bottom Scissors<br>Index        |
| 0 1 0 0     | BEE8-4 | Right Scissors<br>Index         |

| Minor Axis Pixel Count Index                     |  |  |
|--------------------------------------------------|--|--|
| (MIN_AXIS_PCNT) - When bits 15-12 are set        |  |  |
| to 0, the value of bits 10-0 specifies the rec-  |  |  |
| tangle height. Value = rectangle height - 1      |  |  |
| Top Scissors Index (SCISSORS_T) - When           |  |  |
| bits 15-12 are set to 1, the value of bits 10-0  |  |  |
| specifies the clipping window top limit.         |  |  |
| Left Scissors Index (SCISSORS_L) - When          |  |  |
| bits 15-12 are set to 3, the value in bits 10-0  |  |  |
| specifies the clipping window left limit.        |  |  |
| Bottom Scissors Index ((SCISSORS_B) -            |  |  |
| When bits 15-12 are set to 3, the value of bits  |  |  |
| 10-0 specifies the clipping window bottom limit. |  |  |
| Right Scissors Index (SCISSORS_R) - When         |  |  |
| bits 15-12 are set to 4, the value in bits 10-0  |  |  |
| specifies the clipping window right limit.       |  |  |
| Note: Reading display memory outside of the      |  |  |
| clipping window returns the content of that      |  |  |
| memory location.                                 |  |  |

## 6.6.18 MEMORY CONTROL INDEX REGISTER (WRITE ONLY -ADDRESS BEE8-5)

| BIT   | FUNCTION                                                                                                           |  |
|-------|--------------------------------------------------------------------------------------------------------------------|--|
| 0,1   | X coordinate control: Reserved,<br>Bit 0 should be set to 0. Bit 1<br>should be set to 1. X coordinate<br>control. |  |
| 2,3   | Specifies resolution- Y coordinate<br>control.                                                                     |  |
| 4     | Specifies planes for drawing: 0<br>specifies lower 4 planes; 1<br>specifies upper 4 planes.                        |  |
| 5-7   | Reserved                                                                                                           |  |
| 8-11  | Unused                                                                                                             |  |
| 15-12 | Selects memory configuration when set to 0101.                                                                     |  |

| Y Coordinate<br>Control | 32  | Resolution                                 |
|-------------------------|-----|--------------------------------------------|
| Skip Z & Yl             | 0 0 | 640x480x4 (Bit<br>1 of 22E8H must<br>be 0) |
| Skip Y2                 | 01  | 1024x768 or<br>640x480x8                   |
| Not used                | 10  | Not defined                                |
| Not used                | 1 1 | Not defined                                |
### 6.6.19 FIXED PATTERN LOW INDEX REGISTER FIXED PATTERN HIGH INDEX REGISTER (WRITE ONLY -ADDRESS BEE8-8, BEE8-9)

| BIT                     | POSITION                                                                                                                                                                                                          |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                       | Bit 0 = 0                                                                                                                                                                                                         |
| 5-11                    | Unused                                                                                                                                                                                                            |
| Fixed Patte<br>(PATTERN | ern Low Index Register                                                                                                                                                                                            |
| 4-1                     | Specifies pixel position mix control<br>for pixels 0-3. A 0 selects the back-<br>ground color source; 1 selects the<br>foreground color source (if<br>enabled by bits 6,7 of the Pixel<br>Control Index Register. |
| 15-12                   | When set to 8, Fixed Pattern Low is selected.                                                                                                                                                                     |
| Fixed Patt<br>(PATTERN  | ern High Index Register<br>J_H):                                                                                                                                                                                  |
| 4-1                     | Specifies pixel position mix control<br>for pixels 4-7. A 0 selects the back-<br>ground color source; 1 selects the<br>foreground color source (if<br>enabled by bits 6,7 of the Pixel<br>Control Index Register. |
| 15-12                   | When set to 9, Fixed Pattern High is selected.                                                                                                                                                                    |

# 6.6.20 PIXEL CONTROL INDEX REGISTER (WRITE ONLY - ADDRESS BEE8-A)

| BIT   | POSITION                                                                                                     |
|-------|--------------------------------------------------------------------------------------------------------------|
| 0     | Bit 0 = 0                                                                                                    |
| 1     | Mask select poly-fill operations.<br>Read mask = 0; write mask = 1.                                          |
| 2     | Packed Data/Search Enable                                                                                    |
| 3-5   | Data compare                                                                                                 |
| 6-7   | These bits define the source of<br>the bit pattern used to select color<br>and the mix operation to be used. |
| 11-8  | 0000                                                                                                         |
| 15-12 | 1010                                                                                                         |

| Bit<br>2 | Packed Data   |       | Use                   |
|----------|---------------|-------|-----------------------|
| 1        | Enabled       | Read  | Read pack-<br>ed data |
|          |               | Write | Search and fill mode  |
| 0        | No Read/Write |       | Normal                |

| BITS 3-5 | COMPARISON TYPE           |
|----------|---------------------------|
| 0        | False (always draw)       |
| 1        | True (never draw)         |
| 2        | Plane data > = comparison |
| 3        | Plane data < comparison   |
| 4        | Plane data <> comparison  |
| 5        | Plane data_= comparison   |
| 6        | Plane data <= comparison  |
| 7        | Plane data > comparison   |

| 76 | Data Extension<br>Bit pattern from<br>the following<br>source | Use<br>Depending on the<br>color source and<br>mix                                                                                                                                                                                                                 |
|----|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00 | Bit pattern always<br>= 1; BGRD_MIX<br>not used.              | BAE8h bits $6,5 =$<br>$01 \rightarrow$ regular solid<br>BAE8h bits $6,5 =$<br>$10 \rightarrow$ regular<br>image write<br>BAE8h bits $6,5 =$<br>$11 \rightarrow$ regular BIT<br>BLT                                                                                 |
| 01 | Pixel position mix<br>control (BEE8-8,9)                      | BAE8h bits $6,5 =$<br>01 $\rightarrow$ horizontal<br>text line<br>B6E8h bits $6,5 =$<br>00 $\rightarrow$ horizontal<br>text line                                                                                                                                   |
| 10 | CPU pixel data                                                | $\begin{array}{l} FMX \to CPU \ 10-\\ bit \ pattern \ image \\ BMX \to transfer \ to \\ display \ memory \\ BAE8h \ bits \ 6,5 = \\ 01; \ B6E8h = 00: \\ image \ write \ across \\ the \ plane \ or \ from \ 1 \\ bit \ plane \ to \ FGC \\ and \ BGC \end{array}$ |

| Bits<br>76 | Data Extension<br>Bit pattern from<br>the following<br>source    | Use<br>Depending on the<br>color source and<br>mix                                                                                                                                                              |
|------------|------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10         | Display memory<br>used to display<br>packed data* bit<br>pattern | BAE8h bits 6,5 =<br>01; B6E8h bits 6,5<br>= 00: BITBLT<br>across the plane<br>or from 1 bit plane<br>to FGC and BGC<br>BAE8h bits 6,5 =<br>10; B6E8h bits 6,5<br>= 00: Special multi-<br>color marker<br>mode** |

\* Packed data - When in an operation involving read, packed data is computed from the source. Packed Data is defined as "the screen data ORed with the complement of the bit plane read mask". If the result is all 1's, then 1 is extracted, otherwise 0 is extracted per pixel. When a write operation is selected, WD9500 goes into a special search and fill mode. The screen data is read and if the packed data extracted is 0, write operation is suspended. When a paced data "1" is encountered, write operation is enable until the next "1". This mode is used to detect the boundary of a polygon for fill operation.

\*\* Marker - special BITBLT mode used for multi-color marker. A 10 pattern is stored in display memory. During BITBLT, if display memory data = 1, CPU data is used.

### 6.6.21 PIXEL DATA TRANSFER REGISTER (READ/WRITE - ADDRESS E2E8H)

The Pixel Data Transfer (PIX\_TRANS) Register specifies the read/write port for image transfer. For across the plane image transfer, read/write data is determined by nibble boundary on the screen. The starting point will fall on the first nibble group for word mode, two nibbles of data can be transferred for each read/write. For through the plane image transfer, two pixels can be transferred for each read/write operation in work mode.

| BIT                                                                                                                                                              | FUNCTION                                    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|
|                                                                                                                                                                  | Across The Plane                            |
| 0, 6-8,<br>13-15                                                                                                                                                 | Unused                                      |
| 4-1                                                                                                                                                              | Pixel read/write value: Pixels 4-7          |
| 12-9                                                                                                                                                             | Pixel read/write value: Pixels 0-3          |
|                                                                                                                                                                  | Through the Plane                           |
| 0-7                                                                                                                                                              | Pixel 2: bp0-bp7                            |
| 8-15                                                                                                                                                             | Pixel 1 if 16-bit mode selected:<br>bp0-bp7 |
| Note: For Image Read operation, all data (in-<br>cluding the last pixel) must be read from the<br>CPU before issuing a new command to the<br>Graphics Processor. |                                             |

# 6.7 STATUS REGISTERS

There are three status registers that can be read to acquire information: the Subsystem Status (SUBSYS\_STAT) register at address 42E8h, the Graphics Processor Status (GP\_STAT) register at address 9AE8h, and the Display Status (DISP\_STAT) register at address 02E8h.

### 6.7.1 SUBSYSTEM STATUS REGISTER (READ ONLY - ADDRESS 42E8H)

Subsystem Status Register (SUBSYS\_STAT) Register provides interrupt status, monitor ID, and plane size.

| BIT  | FUNCTION                                                                                  |
|------|-------------------------------------------------------------------------------------------|
| 0    | Vsync: when set to 1, it indicates a vertical sync interrupt.                             |
| 1    | GE Busy: When set to 1, indicates GE busy.                                                |
| 2    | FIFO Overflow: When set to 1, in-<br>dicates FIFO overflow.                               |
| 3    | FIFO Empty: When set to 1, indi-<br>cates FIFO empty.                                     |
| 4-6  | Monitor ID: Indicates the monitor type being driven by the WD9500 or 8514/A.              |
| 7    | Plane size: Indicates a 4-bit<br>planae when set to 0 or an 8-bit<br>plane when set to 1. |
| 8-15 | Reserved for hardware test                                                                |

| Address Decoding Table for Read |          |                    |              |              |
|---------------------------------|----------|--------------------|--------------|--------------|
| Bits 15-12 / 11-0               | 2e8      | 6e8                | ae8          | ee8h         |
| 0                               | 2e8      | 2e8                | 2e8          | 2e8          |
| 1                               | 2e8      | 2e8                | 2e8          | 2e8          |
| 2                               | 2e8      | 2e8                | 2e8          | 2e8          |
| 3                               | 2e8      | 2e8                | 2e8          | 2e8          |
| 4                               | 42e8     | 42e8               | 42e8         | 42e8         |
| 5                               | 42e8     | 42e8               | 42e8         | 42e8         |
| 6                               | 42e8     | 42e8               | 42e8         | 42e8         |
| 7                               | 42e8     | 42e8               | 42e8         | 42e8         |
| 8                               | 82e8     | 86e8               | 0*           | 0*           |
| 9                               | 92e8     | 0*                 | 9ae8         | 0*           |
| a                               | e2e8     | e2e8               | 0*           | 0*           |
| b                               | 0*       | 0*                 | 0*           | 0*           |
| С                               | 82e8     | 86e8               | 0*           | 0*           |
| d                               | 92e8     | 0*                 | 9ae8         | 0*           |
| е                               | e2e8     | e2e8               | 0*           | 0*           |
| f                               | 0*       | 0*                 | 0*           | 0*           |
| * A value of zero will          | be read. |                    |              | 1            |
|                                 | Addres   | s Decoding Table f | or Write     |              |
| Bits 15-12 / 11-0               | 2e8      | 6e8                | ae8          | ee8h         |
| 0                               | 2e8      | 6e8                | ae8          | ee8          |
| 1                               | 12e8     | 16e8               | 1ae8         | 1ee8         |
| 2                               | 22e8     | Х                  | Х            | X            |
| 3                               | Х        | Х                  | X            | X            |
| 4                               | 42e8     | 46e8               | 4ae8         | X            |
| 5                               | 42e8     | 46e8               | 4ae8         | X            |
| 6                               | 42e8     | 46e8               | 4ae8         | X            |
| 7                               | 42e8     | 46e8               | 4ae8         | X            |
| 8                               | 82e8     | 86e8               | 8ae8         | 8ee8         |
| 9                               | 92e8     | 96e8               | 9ae8         | 9ee8         |
| а                               | a2e8     | a6e8               | aae8         | aee8         |
| b                               | b2e8     | b6e8               | bae8         | bee8         |
| U I                             | 0200     |                    |              |              |
| c                               | 82e8     | 86e8               | 8ae8         | 8ee8         |
|                                 |          | 86e8<br>96e8       | 8ae8<br>9ae8 | 8ee8<br>9ee8 |
| С                               | 82e8     |                    |              |              |

# TABLE 24. ADDRESS DECODING TABLES FOR 8514/A REGISTERS

| 654 | Monitor ID          |
|-----|---------------------|
| 010 | 8514/A color 16"    |
| 101 | VGA 8503 mono 12"   |
| 110 | VGA 8513 color 12"  |
| 110 | VGA 8512 color 14"  |
| 111 | No monitor or other |
|     | monitor             |

### 6.7.2 GRAPHICS PROCESSOR STATUS REGISTER (READ ONLY - ADDRESS 9AE8H)

Provides FIFO status information. PC read data status, and hardware busy status.

| BIT   | FUNCTION                                                                                                                       |
|-------|--------------------------------------------------------------------------------------------------------------------------------|
| 7-0   | FIFO Entries 7-0: Indicates data<br>status of the FIFO (i.e., a 1 indi-<br>cates that an input entry is oc-<br>cupied by data. |
| 8     | Data Available: Indicates that PC<br>read data is available when set<br>to1; not available when set to 0.                      |
| 9     | Hardware Busy: Indicates that the hardware is busy when set to 1; not busy when set to 0.                                      |
| 15-10 | Not used.                                                                                                                      |

### 6.7.3 DISPLAY STATUS REGISTER (READ ONLY - ADDRESS 02E8H)

Provides video status information.

| BIT  | FUNCTION                                                                                                       |
|------|----------------------------------------------------------------------------------------------------------------|
| 0    | Analog RGB signal test: 0 = R, G,<br>or B greater than 0.30 volts; 1 =<br>R, G, and B all less than 0.30 volts |
| 1    | Vertical Sync                                                                                                  |
| 2    | Line Count                                                                                                     |
| 3    | 0                                                                                                              |
| 4-15 | Unused                                                                                                         |

Table 24 illustrates how the addresses are decoded for 8514/A compatible registers. The left most column gives the hexadecimal value of address bits 15-12, and the top row shows the value of the rest of the twelve address bits, for example, the read address A2E8 (hex) is decoded as

"E2E8" column at the a-th row. This also means an I/O read from A2E8 is the same as if reading from address E2E8, the IRW register. Address decoding for read is different from that for write.

#### 6.8 SOFTWARE INTERFACE EXTEN-SIONS

Suitable CPU Adapter Interface software (AI), such as the Western Digital Adapter Interface (WDAI) can make use of the WD9500's advanced capabilities by invoking "Western Digital Enhanced Mode" on a short-term basis, as explained later There two consequences to this software interface design. First, a WD9500-based board can be inserted into a system with no change in software, and it will function as a faster 8514/A. Second, it provides for performance enhancement for custom software. In order to minimize future register conflict, all functions for Western Digital Enhanced Mode are implemented using one register address, 96E8h. A dummy IO read at address 28E9h must precede any access to 96E8h for Western Digital Enhanced Mode. Under 8514/A emulation mode, 96E8h is a write only register for Rectangle Width.

Extended Register Operation To identify the WD9500 chip set, see Figure 5. To escape to Western Digital Enhanced Mode, the Al should execute a byte read of I/O address 28E9h. (The purpose of the byte read is to perform the escape; the WD9500 does not return any data). This operation is a no-op for the IBM 8514/A since it involves a write-only register, which furthermore does not respond to any access to an odd-numbered byte address. This operation will tag the next register access through a special bit in the FIFO, FIFO is fully functional in Western Digital Enhanced Mode. After escaping to Western Digital Enhanced Mode, the WD9500 will automatically reset itself back to 8514/A emulation mode in one of these four circumstances:

- 1. If, as its next board access immediately after the escape, the AI reads the Western Digital Status Register (I/O address 96E8h).
- If, as its next board access immediately after escape, the AI writes to one of the six Western Digital Control Registers, or to the Rectangle Width Register (I/O address 96E8h).

The purpose of the second two, however, deserves explanation. Western Digital enhancements simplify and speed line drawing commands in two ways: first, line drawing parameters are simpler, in that the AI needs to specify only the pixel coordinates of the line's end point, rather than the tediously calculated parameters used by the 8514/A. Therefore, the WD9500 needs to be in Western Digital Enhanced Mode to "know" that the write into register 8AE8 contains the Y ending

point parameter, in preparation for line-drawing command (case 4). Second, in 640x480 resolution, the WD9500 can, through Western Digital Enhanced Mode, make use of a much simpler Y-coordinate format than is required by the 8514/A, and therefore must be "told" by being in Western Digital Enhanced Mode, that this simpler format is being written to one of the Y-coordinate registers (82E8 or 8AE8, case 3 above). The parameters are defined in this chapter in "Enhanced Solid Line Drawing".

The same system I/O address (96E8) is used to access the Western Digital Status Register, and all six of the Western Digital Control Register. In 8514/A Emulation Mode, this address is that of the Rectangle Width Register.

1



 If, as its next board access immediately after an escape, the AI writes to either I/O address 82E8(register name in 8514/A Emulation Mode: Copy Y Destination/Incr 1 Register). Figure 5. Method of Identifying WD9500 Chip Set.



FIGURE 6. WD ENHANCED MODE USAGE IN 1024 X 768 RESOLUTION

#### 6.8.1 WESTERN DIGITAL ESCAPE REGISTER (READ ONLY - ADDRESS 28E9)

A read of the Western Digital Escape Register allows access to WD enhancements. The data returned is not significant.

### 6.8.2 WESTERN DIGITAL STATUS REGISTER (READ ONLY - 96E8H)

| BIT | FUNCTION                                                                                                                                                                |  |  |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0   | VRAM type: 1 = 256k; 0 = 64k                                                                                                                                            |  |  |
| 1,2 | Indicates the number of VRAM chips                                                                                                                                      |  |  |
| 3   | Resolution: indicates the maxi-<br>mum resolution permitted by the<br>VRAM design. When set to 0, it in-<br>dicates 1024x768; when set to 1,<br>it indicates 1280x1204. |  |  |

| 4      | Pal Write: indicates whether a palette write is pending. When set to 0, a palette write is not pending; when set to 1, a palette write is pending.                                                                                                                                           |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5      | DAC Type: Indicates whether the<br>DAC used is 6-bit only or a switch-<br>able 6-bit/8-bit. The 6-bit/8-bit<br>DAC allows compatibility at 6-bit<br>color to 8514/A and a large 8-bit<br>color palette that requires special<br>programming. $1 = 6/8$ bit color; $0 =$<br>6-bit color only. |
| 7,6    | Monitor Selection                                                                                                                                                                                                                                                                            |
| 13-8   | Current texture pattern position                                                                                                                                                                                                                                                             |
| 15, 14 | Chip set revision number                                                                                                                                                                                                                                                                     |

A byte read at 28E9 followed by a 16-bit read of this address, 96E8, yields the contents of the



FIGURE 7. WD ENHANCED MODE USAGE IN 640 X 480 RESOLUTION

25

Western Digital Status Register. Note that in 8514/A Emulation Mode, 96E8 is a write-only register.

### 6.8.3 WESTERN DIGITAL CONTROL REGISTER (WRITE ONLY - AD-DRESS 96E8)

In Western Digital Enhanced Mode, when a 16-bit write is made to address 96E8, theWD9500 interprets the high 3-bits as a selection of one of six Western Digital Control Register destinations for the lower 13 bits of data. In this sense, address 96E8 can be thought of as a "gateway" for writes to the six Western Digital Control Registers, and the notations 96E8-1,96E8-2,...., 96E8-7 are used to refer to those registers. Note also that this design provides "double insurance" against accidental 8514/A-mode access to these registers: first, they can be accessed only after escaping to Western Digital Enhanced Mode; second, the rectangle width parameter should never be so large as to involve 1-bits in the high three bit positions of the 16-bit data (and in fact, "96E8-1)" leads to the "real" rectangle width register). When Bits 15-13 are set to 3, bits 12-6 specify the texture pattern ending position and Bits 5-0 specify the texture pattern starting position within the 48 bits available in the four texture pattern registers (see "Textured Line Drawing" in this chapter), bit 12 is unused. The following table defines the Western Digital Enhanced Mode Register (ie., bits 12-0 of 96E8 when bits 15-13 = 001). All the control fields in this register are one-bit mode control; they select between two alternate modes, and the selected mode remains in effect through all future operations until the AI changes it by inverting the associated control bit.

| BIT | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | Pixel Depth: Specifies the number<br>of bit planes t o be used in all<br>operations. Four-bit planes are<br>specified when set to 0; 8-bit<br>planes are specified when set to 1.                                                                                                                                                                                                                                                                                                              |
| 1   | Page Select Draw: In modes other<br>than 640x480x4, bit 1 specifies<br>screen page selection for drawing<br>(if the VRAM supports two screen<br>pages at the current resolution).<br>Page 1 is selected when set to 0<br>and page 2 is selected when set<br>to 1. Note that the page select<br>controls provide a simple<br>mechanism for drawing in the<br>background so that the user can<br>instantly replace one screen<br>image with another.                                             |
| 2   | Page Select View: In modes other<br>than 640x480x4, bit 2 specifies<br>screen page selection for viewing<br>(source of screen refresh). Page 1<br>is selected when set to 0 and<br>page 2 is selected when set to 1.<br>Note that the 1 is selected when<br>set to 0 and page 2 is selected<br>when set to 1. Note that the page<br>select controls provide a simple<br>mechanism for drawing in the<br>background so that the user can<br>instantly replace one screen<br>image with another. |
| 3   | Mode Extension: In conjunction<br>with bit 2 of register 4AE8 this bit<br>is used to select different resolu-<br>tions. Bit $3 = 0$ is the default for<br>8514/A resolution modes (i.e.,<br>1024x768 and $640x480$ ).                                                                                                                                                                                                                                                                          |
| 4   | Flicker-free mode: specifies flicker-<br>free palette loading mode control.<br>Setting this bit to 1 enables this<br>mode and a 0 clears the mode.                                                                                                                                                                                                                                                                                                                                             |
| 5   | Texture Mode: specifies Western<br>Digital textured line mode. Setting<br>this bit to 1 enables this mode and<br>a 0 clears the mode.                                                                                                                                                                                                                                                                                                                                                          |

| MODE EXT. | 8513/A MODE | MONITOR<br>TYPE (BIT 8) | VERTICAL<br>REFRESH<br>FREQUENCY<br>(BIT 7) | CLKSEL 2-0                   |
|-----------|-------------|-------------------------|---------------------------------------------|------------------------------|
| 0         | 0           | Х                       | 0                                           | <b>000</b> , 640x480, 60 Hz  |
| 0         | 0           | Х                       | 1                                           | 100, 640x480, 70 Hz          |
| 0         | 1           | 0                       | 0                                           | <b>001</b> , 1024x768, 43 Hz |
| 0         | 1           | 1                       | 0                                           | <b>011</b> , 1024x768, 60 Hz |
| 0         | 1           | Х                       | 1                                           | <b>111</b> , 1024x768, 70 Hz |

| BIT | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | DAC Palette: Used only if the<br>board has a 8/6 bit/color switch-<br>able DAC. (See Selection,<br>Western Digital Status Register.)<br>Bit 6 = 1 selcts 6-bit/color mode<br>(default); Bit 6 = 1 = 8-bit DAC.                                                                                                                                                                                                                                                                                                                                             |
| 8-7 | Monitor Type and Vertical Refresh<br>Frequency: Combined with the<br>mode extension bit and 8514/A bit<br>(Bit 2 of 4AE8) sets the CLKSEL<br>values that select the pixel clock<br>frequency. Bit 2 of 4AE8 automat-<br>ically selects a proper frequency<br>after the control bits are<br>programmed by the BIOS. When<br>bit 7 is set to 0, it selects a vertical<br>refresh frequency of 60 Hz or 43<br>Hz; when set to 1, it selects 70<br>Hz. When bit 8 is set to 0, it<br>selects a 43 Hz monitor type;<br>when set to 1 it selects 60 Hz/70<br>Hz. |
| 9   | Standard Video Registers Enable:<br>Controls the programming of the<br>standard video registers. The<br>default 0 setting disables loading.                                                                                                                                                                                                                                                                                                                                                                                                                |
| 10  | Standard Video Registers Ena<br>ble: Controls the programming of<br>the alternate video registers<br>(WD9500 extended feature). The<br>default 0 setting disables loading.                                                                                                                                                                                                                                                                                                                                                                                 |
| 11  | When set, causes a wait on $I/O$<br>read or write cycles (when ad-<br>dress bit 14 is set). Bit 11 = 0 =<br>disable wait.                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| BIT   | FUNCTION                                                                                                                             |
|-------|--------------------------------------------------------------------------------------------------------------------------------------|
| 12    | Specifies the length of wait for I/O<br>access when address bit 14 is set.<br>A 0 specifies 4.8 µseconds; 1<br>specifies ? µseconds. |
| 15-13 | Western Digital Control Register<br>Select                                                                                           |

| BITS<br>15 14 13 | Western Digital Control Registers                                     |
|------------------|-----------------------------------------------------------------------|
| 0 0 0            | Rectangle Width Register (96E8-0)<br>(Same as regular 8514A register) |
| 001              | Western Digital Enhanced Mode<br>Register (96E8-1)*                   |
| 010              | Reserved (96E8-2)                                                     |
| 011              | Texture Pattern Start/End (96E8-<br>3)*                               |
| 100              | Texture Pattern 11-0 (96E8-4)*                                        |
| 101              | Texture Pattern 23-12 (96E8-5)*                                       |
| 1 1 0            | Texture Pattern 35-24 (96E8-6)*                                       |
| 1 1 1            | Texture Pattern 47-36 (96E8-7)*                                       |

#### 6.8.4 TEXTURE PATTERN START/END REGISTER (WRITE ONLY - AD-DRESS 96E8-3)

| BIT   | FUNCTION              |  |  |
|-------|-----------------------|--|--|
| 5-0   | Starting Bit Position |  |  |
| 11-6  | Ending Bit Position   |  |  |
| 12    | Reserved              |  |  |
| 15-13 | 011                   |  |  |

| BITS<br>10 9 | DESCRIPTION                                                                                                                                                                                                 |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 1          | Load standard video timing<br>registers (default)                                                                                                                                                           |
| 1 0          | Load alternate video timing<br>registers                                                                                                                                                                    |
| 1 1          | Load both register sets                                                                                                                                                                                     |
| 0 0          | Activate automatic switching be-<br>tween register sets and locks<br>registers<br>4AE8h Bit $2 = 0$ (640x480) selects<br>Standard Register Set; bit $2 = 1$<br>(1024x768) selects Alternate<br>Register Set |

| BIT 3 | 4AE8<br>BIT 2 | RESOLUTION |
|-------|---------------|------------|
| 0     | 0             | 640x480    |
| 0     | 1             | 1024x768   |
| 1     | 0             | 800x600    |
| 1     | 1             | 1280x1024  |

## 6.9 ENHANCED SOLID LINE DRAWING

The following procedure should be used to draw a solid line in Wester Digital Enhanced Mode:

- 1. Escape to Western Digital Enhanced Mode by doing a byte read of I/O address 28E9.
- Write the X pixel coordinate of the beginning 2. point of the new line to I/O address 86E8 (Current X Drawing Point Register). If this value has not changed since the last drawing operation (i.e. the new line will start with the X-coordinate of the current drawing point). then instead, the X pixel coordinate of the ending point of the new line should now be written to I/O address 8EE8 (Ending X Register in Western Digital Enhanced Mode), even if that X coordinate has not changed. The reason is that at least one of the two X-coordinate registers must be loaded prior to loading a Y-coordinate register to avoid leaving Western Digital Enhanced Mode prematurely.
- 3. Write the Y pixel coordinate of the beginning point of the new line to I/O address 82E8 (Current Y Drawing Point Register). If the

value has not changed since the last drawing operation (i.e., the new line will start with the same Y-coordinate as where the last one ended), this step may be skipped.

- 4. Unless already done in step 2, write the X pixel coordinate of the ending point of the new line to I/O address 8EE8 (Ending X Register in Western Digital Enhanced Mode). If this value has not changed since the last drawing operation, this step may be skipped.
- Write the Y pixel coordinate of the ending point of the new line to I/O address 8AE8 (Ending Y Register in Western Digital Enhanced Mode). This step has to be done to start the line parameter calculation.
- 6. Conclude by writing the standard line drawing command to the Command Register at I/O address 9AE8.

Western Digital Enhanced Mode simplifies the calculation of Y coordinates when using two pages, including the case of 640x480 resolution. In contrast to the 8514/A Emulation Mode, Western Digital Enhanced Mode requires no transformations; the desired page-oriented Y coordinate can be written directly into the Y-coordinate register. The coordinates will apply to the page selected by their 640x480x4 drawing page selection bit in the MEM\_CNTL register In both 8514/A Emulation Mode and Western Digital Enhanced Mode, however, the user must be aware of pixel coordinate usage with regard to boundaries.

First, under all circumstances, X and Y coordinates wrap around at the 2K boundary; in other words, pixel coordinates are processed as 11-bit values and hence manipulated modulo 2048.

Second, under all circumstances, Y coordinates between 1K and 2K are "lost" (i.e., drawn objects or parts of drawn objects whose Y coordinates are between 1K and 2K are not recorded in VRAM.)

Third, where only one page is available (except for the 1280x1024 case), X coordinates between 1K and 2K are similarly "lost" (See below for 1280x1024.) Fourth, where two pages are available, first-page X coordinates between 1K and 2K will "intrude" into the second page (modulo 1024), and second-page X coordinates between 1K and 2K will intrude into the first page (modulo 1024). The reason is that when two pages are provided, the 1Kx1K pages are arranged "side by side" in physical memory, with the logical (page-oriented) X coordinate internally processed as a physical X coordinate between 0 and 2K. The intrusion can be avoided by establishing clipping boundaries at the 1K page limit (or less).

Finally, images drawn within a (1K by 1K) page but beyond the screen viewing boundary (1Kx768 or 640x480) are not "lost", and can be copied from their "off-screen" location into the viewing area by a BITBLT operation. In the (single page) case of 1280x1024 resolution, off-screen" storage is provided for coordinates between 1280 and 2K.

# 6.10 TEXTURED-LINE DRAWING

In Western Digital Enhanced Mode, textured lines can be drawn directly. After the "texture pattern" and its pointers have been set up as described below, the AI need only turn on the Western Digital textured-line mode control bits, 7 & 6 of BEE8-A to 01, set bits 6 & 5 of BAE8 to 01, and then use the same procedure as for solid-line drawing (see "Enhanced Solid-Line Drawing" in this chapter). The texture pattern is a string of bits whose 0/1 values are consulted in sequence as the PWGA1 draws the line, applying the current mix to the combination of current texture-pattern bit and current pixel. (For example, a "1" bit in the texture pattern might be interpreted as an overpaint instruction). The pattern may be up to 48 bits long. Four Western Digital Control Registers 96E8-4, 96E8-5, 96E8-6, and 96E8-7 are provided for its storage. (Bit 12 of each of these registers is reserved.) The pattern must be defined beginning at Bit 47, but need not continue to Bit 0; the 6-bit "ending position" field in Western Digital Control Register 96E8-3 is provided to specify the number of its last bit. The related 6-bit "starting position" field, however, is used differently. It specifies where (between Bit 47 and the ending-position bit) the texture-pattern pointer should be placed at the beginning of a textured line-drawing process from that start position toward the defined ending position (i.e., from high-order to low-order bits within the texture pattern); after the WD9500 used the texture-pattern bit at the ending position, it will circulate the pointer back, not to the specified starting position but to Bit 47, and then repeat the process. After the line is complete, the wd9500 will place the current position of the texture-pattern pointer into the appropriate field within the Western Digital Status Register, where it may be read by the AI. If the user does not store a new value into the starting position field, then in its next textured-line-drawing operation, the WD9500 will use the current pointer from the status register. The chief purpose of this feature is convenience in allowing the user to automatically continue a texture pattern from one line to the next without needing to do an explicit read and write of the pointer position; for example, a dashed line will properly turn a corner without user concern for the texture pattern pointer. Note that after board reset, all texture controls, including current position, are undefined, and must be initialized by the AI.

# 6.11 FLICKER-FREE PALETTE LOADING

When using the IBM 8514/A, the CPU must wait for vertical screen refresh before reloading its color palette, In a high resolution design, however, especially with a non-interlaced monitor, the vertical retrace time (typically less than 600 microseconds) may not be long enough to program all 256 color entries. When the Western Digital flicker-free option is incorporated into the design of a WD9500-based board ("Video DAC and Interface Subsystem" in section 3), the WD9500 can accept palette writes from the CPU at any time, but will buffer them in the DSP until horizontal retrace time: during horizontal flyback, it will write them to the DAC's palette, avoiding flicker. Note that in VGA pass-through mode, any VGA palette-loading operation also loads the DAC on the 8514/A (and hence will do the same on a WD9500-based board). Flicker-free programming does not apply in VGA pass-through mode. Flicker-free mode is enabled by setting Bit 4 of the Western Digital Enhanced Mode Control Register. When sending color data to the board, however, the AI must monitor Bit 4 of the Western Digital Status Register; if set, this bit indicates that a palette write is pending, and no further palette color data should be sent until the WD9500 clears the bit. When clear, the Al can then send three

25

| I/O ADDRESS | READ/WRITE | FUNCTION                                      |
|-------------|------------|-----------------------------------------------|
| O2EA/03C6   | R/W        | DAC Mask                                      |
| O2EB/03C7   | W          | DAC Read Index                                |
| O2EB/03C7   | R          | DAC State                                     |
| O2EC/03C8   | R/W        | DAC Write Index                               |
| O2ED/03C9   | R/W        | DAC Data                                      |
| 02E8        | R          | Display Status                                |
| 02E8        | W          | Horizontal Total                              |
| 06E8        | W          | Horizontal Displayed                          |
| 0AE8        | W          | Horizontal Sync Start                         |
| 0EE8        | W          | Horizontal Sync Width                         |
| 12E8        | W          | Vertical Total                                |
| 16E8        | W          | Vertical Displayed                            |
| 1AE8        | W          | Vertical Sync Start                           |
| 1EE8        | W          | Vertical Sync Width                           |
| 22E8        | W          | Display Control                               |
| 42E8        | W          | Subsystem Status                              |
| 42E8        | W          | Subsystem Control                             |
| 46E8        | W          | ROM Page Select (MC)                          |
| 4AE8        | W          | Advanced Function Control                     |
| 82E8        | R/W        | Current Y Position                            |
| 86E8        | R/W        | Current X Position                            |
| 8AE8        | W          | Destination Y Position/Axial Step Constant    |
| 8EE8        | W          | Destination X Position/Diagonal Step Constant |
| 92E8        | R/W        | Error Term                                    |
| 96E8        | W          | Major Axis Pixel Count                        |
| 9AE8        | R          | Graphics Processor Status                     |
| 9AE8        | W          | Command                                       |
| 9EE8        | W          | Short Stroke Transfer                         |
| A2E8        | W          | Background Color                              |
| A6E8        | W          | Foreground Color                              |
| AAE8        | W          | Write Mask                                    |
| AEE8        | W          | Read Mask                                     |

## TABLE 25. IBM 8514/A COMPATIBLE REGISTERS

bytes, representing the contents of one of the 256 entries in the palette. Other AI accesses of the DAC, including reading color values, are independent of the flicker-free design, and should emulate 8514/A operations.

| I/O ADDRESS | <b>READ/WRITE</b> | FUNCTION               |
|-------------|-------------------|------------------------|
| B2E8        | W                 | Color Compare          |
| B6E8        | W                 | Background Mix         |
| BAE8        | W                 | Foreground Mix         |
| BEE8        |                   | Multifunction Control  |
| BEE8(0)     | W                 | Minor Axis Pixel Count |
| BEE8(1)     | W                 | Top Scissors           |
| BEE8(2)     | W                 | Left Scissors          |
| BEE8(3)     | W                 | Bottom Scissors        |
| BEE8(4)     | W                 | Right Scissors         |
| BEE8(5)     | W                 | Memory Control         |
| BEE8(8)     | W                 | Fixed Pattern - Low    |
| BEE8(9)     | W                 | Fixed Pattern - High   |
| BEE8(A)     | W                 | Pixel Control          |

# TABLE 25. IBM 8514/A COMPATIBLE REGISTERS (CONT'D)

| I/O ADDRESS | READ/WRITE | FUNCTION                      |
|-------------|------------|-------------------------------|
| 28E9        | R          | Dummy Read/Enable for 96E8    |
| 36E8        | W          | EPROM SelectAT Bus Only       |
| 8AE8        | W          | Ending X Point for Line       |
| 8EE8        | W          | Ending Y Point for Line       |
| 96E8        | R          | Western Digital Status        |
| 96E8(1)     | W          | Western Digital Enhanced Mode |
| 96E8(3)     | W          | Texture Pattern Start End     |
| 96E8(4)     | W          | Texture Pattern 11-0          |
| 96E8(5)     | W          | Texture Pattern 23-12         |
| 96E8(6)     | W          | Texture Pattern 35-24         |
| 96E8(7)     | W          | Texture Pattern 47-36         |

**TABLE 26. WD9500 ENHANCED REGISTERS** 

25

**APPENDIX A. VRAM DESIGN - TBD** 

APPENDIX B. IMPLEMENTATION OF VIDEO DAC - TBD

**APPENDIX C. EPROM - TBD**