## IBM VGA-COMPATIBLE VIDEO GRAPHICS CONTROLLER #### **FEATURES** - Single-chip VGA video graphics device that is completely compatible in the following systems: - -IBM PC/AT®-compatible - -IBM PC/XT®-compatible - -IBM PS/2®-compatible - Fully compatible with IBM VGA® in all modes - Fully compatible with IBM BIOS® (Basic Input/Output System) - Provides 800 x 600 element highresolution graphics with 16 colors - Flicker-free operation in all video modes - · Supports 132-column text modes - Supports both digital and analog monitor ## DESCRIPTION The OTI-037 VGA-compatible Video Graphics Controller is a single-chip, high-integration, high resolution graphics device intended for use in IBM PS/2 Model 30-compatible systems as well PC/AT- and PC/XT-compatible systems. It provides high resolution graphics of 800 x 600 elements with 16 colors. The OTI-037 is fully compatible with IBM VGA in all modes, as well as being fully compatible with Hercules graphics. OTI-037 compatibility also extends EGA, CGA, MDA and IBM BIOS. It is also flicker-free in all modes. It supports an external digital-to-analog look-up table. The OTI-037 is available from Oak Technology, Inc. in an industry-standard plastic 100-pin flatoack. ### **PIN DIAGRAM** #### OTI-037 ### **ORDER INFORMATION** | Part<br>Number | Package | | |----------------|------------------|--| | OTI-037 | Plastic Flatpack | | **Notes:** Operating temperature range is 0°C to +70°C. IBM PC/AT, PC/XT, PS/2, IBM VGA, and IBM BIOS are registered trademarks of International Business Machines Corporation. ## SIGNAL DESCRIPTIONS | Signal<br>Name | Pin<br>Number | Signal<br>Type | Signal<br>Description | |----------------|-----------------------------|----------------|-------------------------------------------------------------------------------------------------| | -CRTINT | 1 | 0 | Display vertical retrace interrupt. An active low open collector. | | RESET | 2 | 1 | System reset signal, active high. | | SWITCH | 3 | I | Signal that detects the type of monitor. | | A8-A16 | 4-12 | I | CPU address bus bits 8 through16. | | ASEL | 13 | 1 | Active high, to select VGA address to decode. | | -NMI | 14 | 0 | Non maskable interrupt. An active low open collector. | | CPURDY | 16 | 0 | An open collector active high output to signal processor that it is ready for memory access. | | -VMWR | 17 | I | Active low, video memory write signal. | | -VMRD | 19 | 1 | Active low, video memory read signal. | | -IOWR | 20 | 1 | Active low, I/O write signal. | | -IORD | 21 | 1 | Active low, I/O read signal. | | VCLK3 | 22 | 1 | 35.5 MHz input clock signal. | | VCLK2 | 23 | 1 | Reserved | | VCLK1 | 24 | I | 28.322 MHz input clock signal. | | VCLK0 | 25 | 1 | 25.175 MHz input clock signal. | | EXCLK | 26 | I | External clock signal. | | -SWTR | 27 | 0 | Read DIP switch control signal. | | -WE | 28 | 0 | Video memory write enable. An active low signal. | | -CAS | 29 | 0 | Column address strobe to all planes. An active low signal. | | –OE | 30 | 0 | Output enable signal to memory. It is active low. | | -RAS0-RAS3 | 32-35 | 0 | Row address strobe to planes 0-3. An active low signal. | | MD31-24 | 36- 39, 41-44 | 1/0 | Display memory address/data time multiplexed bus line 7 - 0, interface to video memory plane 3. | | MD23-16 | 45-52 | I/O | Display memory address/data time multiplexed bus line 7 - 0, interface to video memory plane 2. | | MD15-8 | 53-57, 59,<br>60, 62 | I/O | Display memory address/data time multiplexed bus line 7 - 0, interface to video memory plane 1. | | MD7-0 | 63, 64, 66<br>67, 69-71, 73 | I/O | Display memory address/data time multiplexed bus line 7 - 0, interface to video memory plane 0. | | P7-P0 | 74-81 | 0 | Video color look up table address bits 7 - 0. | | HSYNC | 82 | 0 | Horizontal SYNC signal for monitor. | | VSYNC | 83 | 0 | Vertical SYNC signal for monitor. | | -BLANK | 84 | 0 | An active low blanking signal to external palette chip. | | -DACW | 85 | 0 | An active low I/O write signal for external palette chip (256 color look up table). | | -DACR | 86 | 0 | An active low I/O read signal for external palette chip (256 color look up table). | | PCLK | 87 | 0 | Pixel clock signal for external palette chip (256 color look up table). | | DA7-DA0 | 88, 89 | 1/0 | Multiplexed address/data bus bits 7 through 0. | | SIGNAL D | ESCRIPTION | S (Cont.) | | |----------------|--------------------------------|----------------|--------------------------------------------------------| | Signal<br>Name | Pin<br>Number | Signal<br>Type | Signal<br>Description | | | 91-94<br>96, 97 | | | | -EABUF | 98 | 0 | Active low, enable external address buffer. | | -EDBUF | 99 | 0 | Active low, enable external data buffer. | | DIR | 100 | 0 | Control signal for bidirectional data bus transceiver. | | vcc | 18, 58<br>68, 95 | | Power: +5 V | | GND | 15, 31, 40<br>61, 65, 72<br>90 | | Ground | # FUNCTIONAL DESCRIPTION INTRODUCTION The single chip VGA is a standard video graphic controller for PS/2 model 30 and PC/XT/AT systems. Compared to earlier version video graphic controllers, several new features are added including higher resolution (640 X 480), new video mode, 256 colors support for 320 X 200 graphics mode, up to 64 shades of grey display for monochrome monitor, and eight fonts loaded into video RAM simultaneously. For the OTI-037 chip, even more functionalities are added to gain performance. The host can access to both VGA registers and video memory by setting up bus address and read/write command to read or write 8-bit data. Video RAM and screen refresh activities occur concurrently and independently by assigning appropriate memory access cycles to each of them. Most registers are readable so that BIOS and driver software are able to determine current state of video. In the basic configuration, 256K byte of memory is needed as the display buffer. Four planes of video memory are controlled by four different- RAS (Row Address Strobe) signals and one -CAS (Column Address Strobe), one -WE (Write Enable), one -OE (Output Enable) signal. Video data bus is time multiplexed with video address bus in the way that outputs RAS and CAS address early in memory cycle and inputs 8-bit data for read or output 8-bit data for write late in memory cycle. NMI (Non-Maskable Interrupt) is generated by trapping some particular I/O ports so that backward compatibility can be done through the BIOS. The VGA chip will provide 'DIRectional' signal to control the data flow to system data bus for CPU Read or Write. #### MAJOR COMPONENTS There are four major components of OTI-037 contained within a single 100- pin Plastic Flatpack. They are described below: #### **CRT CONTROLLER** The OTI-037 CRT Controller provides synchronization control, timing generation and supplies video memory address to display memory. Flexible timing configuration options are allowed by accessing I/O registers through software control. During the blanking period, an 8-bit refresh counter is placed on the memory address lines. A split screen feature is also provided to allow two windows. #### SEQUENCER The OTI-037 Sequencer takes care of basic memory timing for the display memory and the character clock for the control of memory fetches. The intelligent state machine in the Sequencer automatically assigns appropriate memory access cycles to both the CPU and CRT Controller during active display period. The sequencer can also protect the entire memory plane by selectively masking out planes through the Mask register. #### **GRAPHICS CONTROLLER** The Graphics Controller provides a data path for both CPU Read/Write and CRT Read access to the display memory. For CRT access it directs data to the Attribute Controller while the CPU access directs data to the system bus instead. It handles two basic modes which are alphanumeric and graphics. In alphanumeric mode, the data is sent in parallel directly to the Attribute Controller. In graphics mode the memory data is shifted out serially to the Attribute Controller. The data formatting and manipulation are implemented for various modes. Color comparator is provided for fast color comparison in the application of color painting modes. Since the Graphics Controller can process 32-bit data (8bits from each plane) at a time, a fast color presetting and area fill operation can be achieved. #### ATTRIBUTE CONTROLLER The OTI-037 Attribute Controller provides video shifting, attribute processing and internal palette of 16 colors selectable from a possible 64 colors. Pixel panning is also provided for both graphics and text modes. Underline, cursor and blinking logic are interpreted and manipulated here. The final output of Attribute Controller is 8-bit wide color data to be sent to the external color look-up table for final color mapping. ## MEMORY AND CLOCK CONSIDERATION In basic configuration, eight of 64K X 4-bit dynamic RAM's should be used to configure 256K byte of video memory. The supported speed of DRAM and CLOCK are related to the graphics resolution as shown in Table 1. #### **VGA REGISTERS** All the registers in the VGA can be ategorized into six groups for the different function blocks in the hardware. In the OTI-037 VGA chip, the system microprocessor data latches are readable for faster save and restore VGA state in the VGA BIOS. The VGA also provides the system microprocessor interface for the video DAC (external color pallete chip). The DAC has one address register which can be accessed through address hex 03C7 for read, and hex 03C8 for write. Table 2 lists the registers and the I/O address where they are located. It also lists whether or not they are Read/Write, Read-Only, or Write-Only. Note that PEL Mask Register must not be written to by application code or destruction of the color look-up table may occur. ### **General Registers** This section describes all the general registers. The (?) is controlled by bit 0 of the Miscellaneous Output Register. ## Miscellaneous Output Register Read-03CC Write-03C2 Bit Description 7 Vertical Sync Polarity ## **TABLE 1. RESOLUTION REQUIREMENTS** | DRAM | 120 ns | 120 ns | 100 ns | |------------|-----------|-----------|-----------| | CLOCK | 28 MHz | 25 MHz | 36 MHz | | RESOLUTION | 720 X 400 | 640 X 480 | 800 X 600 | | COLORS | 16 | 16 | 16 | | | | Ì | | ### **TABLE 2. VGA REGISTERS** PEL Address (Read) \_\_\_\_\_\_ PEL Data Register PEL Mask | Register Group | R/W | Mono<br>Emulation | Color<br>Emulation | |---------------------|-----------------|-------------------|--------------------| | General Registers | | | | | Miscellaneous | w | 03C2 | 03C2 | | | l R | 03CC | 03CC | | Input Status 0 | RO | 03C2 | 03C2 | | Input Status 1 | RO | 03BA | 03DA | | Feature Control | W | 03BA | 03DA | | | R | 03CA | 03CA | | VGA Enable | RW | 03C3 | 03C3 | | DAC State | R | 03C7 | 03C7 | | Sequencer Registers | | | | | Address Register | RW | 03C4 | 03C4 | | Data Registers | RW | 03C5 | 03C5 | | CRTC Registers | | | | | Address Register | RW | 03B4 | 03D4 | | Data Registers | RW | 03B5 | 03D5 | | Graphics Registers | <u> </u> | | | | Address Register | l RW | 03CE | 03CE | | Data Register | RW | 03CF | 03CF | | Attribute Registers | <del>- </del> | | | | Address Register | l <sub>RW</sub> | 03C0 | 03C0 | | Data Registers | l w | 03C0 | 03C0 | | Data Hogistore | R | 03C1 | 03C1 | | Extended Registers | | | | | Address Register | l RW | 03DE | 03DE | | Data Registers | RW | 03DF | 03DF | | DAC Registers | | | | | PEL Address (Write) | RW | 03C8 | 03C8 | WO RW RW 03C7 03C9 03C6 ## **TABLE 3. GENERAL REGISTERS** | Read<br>Port | Write<br>Port | Index | |--------------|----------------------------------------------|------------------------------------------------------------| | 03CC | 03C2 | I — | | 03C2 | l — | _ | | 03?A | l — | l — | | 03CA | 03?A | | | 03C3 | 03C3 | <b> </b> | | 03C7 | 1 — | l — | | | 9000<br>03CC<br>03C2<br>03?A<br>03CA<br>03C3 | Port Port 03CC 03C2 03C2 — 03?A — 03CA 03?A 03C3 03C3 | ## TABLE 4. REGISTERS (Cont.) | Bit 7 | Bit 6 | Vertical Size | |-------|-------|---------------| | 0 | 0 | Reserved | | 0 | 1 | 400 lines | | 1 | 0 | 350 lines | | 1 | 1 | 480 lines | | | L | | ## TABLE 5. REGISTERS (Cont.) | CSEL2 | CSEL1 | CSEL0 | CLOCK | |-------|-------|-------|----------------------| | 0 | 0 | 0 | 25,175 MHz | | ō | ō | 1 | 28.322 MHz | | 0 | 1 | 0 | External Input Clock | | 0 | 1 | 1 | Reserved | | 1 | 0 | 0 | 14.318 MHz | | 1 | 0 | 1 | 16.257 MHz | | 1 | 1 | 0 | Reserved | | 1 | 1 | 1 | 35.5 MHz | | | | | | | 6<br>5 | Horizontal Sync Polarity<br>Page Bit for Odd/Even | | bit is provided for diagnostic use. | Bit 0 | dresses to | sets CRTC ad-<br>Hex 03BX and | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------------------------------------------|----------------------------------| | 4 | 3 Clock Select bit 1 2 Clock Select Bit 0 Bit 1 Enable RAM | Bit 4 | Reserved | | • | s Register 0's<br>03BA for Mono- | | _ | | Bit 3,2 | if 3,2 These two bits select the clock source. In OTI-037 VGA the third bit is defined in extended | | ulation. A logical 1<br>addresses to Hex<br>Input Status | | | Bit 7,6 | The Polarity of Vertical/<br>Horizontal Sync is used to<br>select the vertical size as<br>shown in Table 4. | | register and used with these<br>two bits to select a more wide<br>range of clock source for<br>different video modes. See<br>Table 5. | Read- | 03DA for co<br>Status Regis<br>Only | Address = 03C2 | | Bit 5 | Selects between two pages of<br>memory when in the Odd/Even<br>modes (mode 0-5, 7). A<br>logical 0 selects the low page<br>of memory; a logical 1 selects<br>the high page of memory. This | Bit 1 | A logical 0 disables Video RAM address decode from the system microprocessor; a logical 1 enables Video RAM to the system microprocessor. | Bit<br>7<br>6,5<br>4<br>3-0 | Description<br>CRT Intern<br>Reserved<br>Switch Sen<br>Reserved | upt | 03C7 03C9 03C6 Index 0 Bit 7 A logical 1 indicates a vertical retrace interrupt is pending. A logical 0 indicates the vertical retrace interrupt is cleared. Bit 6.5 Reserved This bit allows the power-on Bit 4 initialization to determine if a monochrome or color monitor is connected to the system. Bit 3-0 Reserved #### Input Status Register 1 Read-Only Address = 03?A Bit Description 7,6 Reserved Diagnostic 0 5 4 Diagnostic 1 Vertical Retrace 3 Reserved 2,1 Display Enable Bits 7,6 Reserved Bits 5,4 These two bits are used for diagnostics. They are connected to two of the eight color outputs of the Attribute Controller. The two bits defined in the Color Plane Enable Register controls the multiplexer for the color output wiring are described in Table 6. Bit 3 A logical 1 occurs during a vertical retrace interval. A logical 0 shows that video information is being displayed. #### Bits 2.1 Reserved Bit 0 A logical 1 indicates a horizontal or vertical retrace interval. A logical 0 indicates that the internal Display Enable Signal is active. To avoid glitches on the display, some programs use this status bit to restrict screen updates to de-activate display intervals. The VGA has been designed to eliminate this software requirement, so display screen updates may be made at any time. **Feature Control Register** Write = 03?A Read = 03CA Description Bit 7-4 Reserved Vertical Sync Select 3 Reserved 2-0 Bits 7-4 Reserved This bit should always be set Bits 3 to 0 to enable normal vertical sync output to the monitor; when bit 3 = 1, the "vertical sync" output is the logical OR of "vertical sync" and "vertical display enable". Bits 2-0 Reserved #### Video Subsystem Enable Register Write-03C3 Read-03C3 Description Bit 7-1 Reserved Video Subsystem Enable Bits 7-1 Reserved A logical 1 enables video I/O Bit 0 and memory address decoding. A 0 disables the video I/O and memory address decoding. #### SEQUENCER REGISTERS This section describes registers in the Sequencer Control block. See Table 7. #### Sequencer Address Register Write-03C4 Read-03C4 Description Bit 7-3 Reserved Sequencer Address 2-0 Bits 7-3 Reserved Bits 2-0 A binary value pointing to the register where data is to be written or read. Reset Register Port = 03C5 Bit Description 7-2 Reserved Synchronous Reset 1 Asynchronous Reset 0 Bits 7-2 Reserved Bit 1 A logical 0 directs the sequencer to synchronously clear and halt. Bits 1 and 0 must be 1 to allow the sequencer to operate. This bit must be set to 0 before changing either bit 3 or bit 0 of the Clocking Mode register, or bit 3 or bit 2 of the Miscellaneous Output Register, or bit 5, bit 4 or bit 3 of the Bandwidth Control Register. A logical 0 directs the se-Bit 0 quencer to asychronously clear and halt. Bit 1 and 0 must both be 1 to allow the sequencer to operate. Resetting the sequencer with this bit can cause data loss in dynamic RAMs. ## **Clocking Mode Register** Port = 03C5 Index 1 Bit Description Reserved 7,6 Screen Off 5 4 Shift 4 3 Dot Clock 2 Shift Load 1 Reserved 0 8/9 Dot Clocks Bits 7,6 Reserved Bit 5 When set to 1, it turns off the video screen and assigns maximum memory bandwidth to the system CPU. A logical 0 puts the screen into normal operation. When this bit is set the screen is blanked. The synchronization pulses are ## **TABLE 6. REGISTERS BITS** | Color Plane<br>Register<br>Bit 5 Bit 4 | | Reg | Status 1<br>ister<br>Bit 4 | |----------------------------------------|---|-----|----------------------------| | 0 | 0 | P2 | P0 | | 0 | 1 | P5 | P4 | | 1 | 0 | P3 | P1 | | 1 | 1 | P7 | P6 | ### **TABLE 7. SEQUENCER REGISTERS** | Register Name | I/O Port | Index | |----------------------|----------|-------| | Sequencer Address | 03C4 | | | Reset | 03C5 | 00 | | Clocking Mode | 03C5 | 01 | | Map Mask | 03C5 | 02 | | Character Map Select | 03C5 | 03 | | Memory Mode | 03C5 | 04 | maintained. This bit is used for fast full-screen updates. Bit 4 When set to 1, the internal shift load registers are loaded every fourth character clock. When set to 0, they are loaded every character clock. When 32 bits are fetched each cycle and used together in the shift registers, this mode is useful. Bit 3 A logical 0 selects normal dot clock directly from the sequencer master clock input. A logical 1 will select master clock divided by two as dot clock. Normally, dot clock divided by two is used for 320 and 360 horizontal resolution modes. Bit 2 When set to 1, the internal shift load registers are loaded every other character clock. When set to 0, and bit 4 is set to 0, the internal shift load register are loaded every character clock. This mode is useful when 16 bits are fetched per cycle and chained together in the shift load registers. Bit 1 Reserved Bit 0 A logical 0 directs the sequencer to generate nine dct wide character clocks. A logical 1 generates eight dot wide character clocks from the sequencer. Selecting nine dots for alphanumeric modes only. For nine dot modes, the ninth dot equals the eighth dot for ASCII codes C0 through DF hex. Also, see the Line Graphics bit in Mode Control Register in Attribute section. # Map Mask Register Port = 03C5 Index = 02 Bit Description | Dit | Description | |-----|--------------| | 7-4 | Reserved | | 3 | Map 3 Enable | | 2 | Map 2 Enable | | 1 | Map 1 Enable | | 0 | Map 0 Enable | | | | Bits 7-4 Reserved Bits 3-0 A logical 1 enables CPU to write to the corresponding memory map. These bits are used to write protect any memory map. When all four TABLE 8. MAP SELECT (1) | Bit 5 | Bit 3 | Bit 2 | Map | Table Location | |-------|-------|-------|-----|-----------------| | 0 | 0 | 0 | 0 | 1st 8K of Map 2 | | 0 | 0 | 1 | 1 | 3rd 8K of Map 2 | | 0 | 1 | 0 | 2 | 5th 8K of Map 2 | | 0 | 1 | 1 | 3 | 7th 8K of Map 2 | | 1 | 0 | 0 | 4 | 2nd 8K of Map 2 | | 1 | 0 | 1 | 5 | 4th 8K of Map 2 | | 1 | 1 | 0 | 6 | 6th 8K of Map 2 | | 1 | 1 | 1 | 7 | 8th 8K of Map 2 | TABLE 9. MAP SELECT (2) | Bit 4 | Bit 1 | Bit 0 | Мар | Table Location | |-------|-------|-------|-----|-----------------| | 0 | 0 | 0 | 0 | 1st 8K of Map 2 | | 0 | 0 | 1 | 1 | 3rd 8K of Map 2 | | 0 | 1 | 0 | 2 | 5th 8K of Map 2 | | 0 | 1 | 1 | 3 | 7th 8K of Map 2 | | 1 | 0 | 0 | 4 | 2nd 8K of Map 2 | | 1 | 0 | 1 | 5 | 4th 8K of Map 2 | | 1 | 1 | 0 | 6 | 6th 8K of Map 2 | | 1 | 1 | 1 | 7 | 8th 8K of Map 2 | bits are logical 1, a 32-bit write operation can be performed by CPU with only one memory cycle. This is useful for intensive screen updates in graphics modes. For odd/even modes, maps 0 and 1, and maps 2 and 3 should have the same map mask value. When chain 4 mode is selected, all maps should be enabled. This is a read-modify-write operation for CPU write. Character Map Select Register Port = 03C5 Index = 03 Bit Description 7,6 Reserved 5 Character Map Select High Bit A 4 Character Map Select High Bit B 8 3,2 Character Map Select A 1,0 Character Map Select B Bits 7,6 Reserved Bits 5,3,2 Selects font table from map 2 according to Table 8 when attribute bit 3 is a 1. Bits 4,1,0 Selects font table from map 2 according to Table 9 when attribute bit 3 is a 0. Note: Bit 3 of the attribute byte normally controls the ON/OFF of the foreground intensity in text modes. This bit, however, may be redefined as a switch between character sets. For this feature to be enabled, the following statement must be true: The setting value of Character Map Select A does not equal the value of Character Map Select B. #### Memory Mode Register Port = 03C5 Index = 04 Bit Description 7-4 Reserved 3 Chain 4 2 Odd/Even 1 Extended Memory 0 Reserved Bits 7-4 Reserved Bit 3 A logical 0 enables CPU to access data sequentially within a bit map by use of the Map Mask Register. A logical 1 causes two low-order address bits (A0, A1) to select the map that will be accessed in Table For read operation from CPU, these two bits are also used to select the read maps in the graphics section. ## TABLE 10. MAP SELECT (3) | A1 | A0 | Map Selected | |----|-----|--------------| | 0 | 0 | Мар 0 | | 0 | 1 | Map 1 | | 1 | 0 | Map 2 | | 1 | 1 | Мар 3 | | | l . | | ### **TABLE 11. CRT CONTROLLER REGISTERS** | Register Name | Port | Index | |---------------------------------|------|-------| | CRT Controller Address Register | 03?4 | _ | | Horizontal Total | 03?5 | 00 | | Horizontal Display Enable End | 03?5 | 01 | | Start Horizontal Blanking | 03?5 | 02 | | End Horizontal Blanking | 03?5 | 03 | | Start Horizontal Retrace | 03?5 | 04 | | End Horizontal Retrace | 03?5 | 05 | | Vertical Total | 03?5 | 06 | | Overflow | 03?5 | 07 | | Preset Row Scan | 03?5 | 08 | | Maximum Scan Line | 03?5 | 09 | | Cursor Start | 03?5 | 0A | | Cursor End | 03?5 | ов | | Start Address High | 03?5 | oC | | Start Address Low | 03?5 | OD | | Cursor Location High | 03?5 | 0E | | Cursor Location Low | 03?5 | 0F | | Start Vertical Retrace | 03?5 | 10 | | End Vertical Retrace | 03?5 | 11 | | Vertical Display Enable End | 03?5 | 12 | | Offset | 03?5 | 13 | | Underline Location | 03?5 | 14 | | Start Vertical Blank | 03?5 | 15 | | End Vertical Blank | 03?5 | 16 | | CRTC Mode Control | 03?5 | 17 | | Line Compare | 03?5 | 18 | | | | | <sup>? =</sup> B or D in accordance with Bit 0 of Miscellaneous Output register. Bit 2 A logical 0 directs even CPU addresses to access maps 0 and 2, while odd CPU addresses access maps 1 and 3. A logical 1 causes access to data within a bit map sequentially. Bit 1 A logical 1 shows that greater than 64K bytes of video memory is being used. This is set to permit the VGA to use the 256K bytes of video memory. This also enables the character map selection. (See Character Map Select Register.) Bit 0 Reserved ### **CRT CONTROLLER REGISTERS** This section describes all the registers in the CRT Controller. See Table 11. ## CRT Controller Address Register Port = -3?4 Bit Description 7-6 Reserved 5 Test Bit, must = 0 4-0 CRTC Address Bits 7,6 Reserved Bit 5 Test bit, must remain 0. Bit 4-0 Binary value programmed in these bits selects one of the CRT Controller registers where data is to be accessed. Note: All CRT Controller Registers are read/write registers. #### Horizontal Total Register Port = 03?5 Index = 0 Bit Description 7-0 Horizontal T Horizontal Total (-5) In the CRT Controller, there is a horizontal character counter which counts character clock inputs generating from Sequencer and compares against the value of the horizontal registers to provide horizontal timings. The horizontal total defines the total number of characters in the horizontal scan interval including the retrace time. Bits 7-0 The total number of characters minus 5. #### Horizontal Display Enable End Register Port = 03?5 Index = 01 Bit Description 7-0 Horizontal Display Enable End (-1) This register defines the length of the horizontal display enable signal. It determines the number of displayed character positions per horizontal line. Bits 7-0 Total number of displayed characters minus 1. ## Start Horizontal Blanking Register Port = 03?5 Index = 02 Bit Description 7-0 Start Horizontal Blanking Bit 7-0 These 8-bit values determine when to start the internal horizontal blanking output signal. When the internal character counter reaches this value, the horizontal blanking signal becomes active. ## End Horizontal Blanking Register Port = 03?5 Index = 03 Bit Description 7 Test Bit 6-5 Display Enable Skew Control 4-0 End Blanking Bit 7 Test Bit Bits 6,5 Bits 6 and 5 indicate the magnitude of display enable skew. Display enable skew control is necessary to give adequate time for the CRT Controller to interrogate the display buffer in order to obtain a character and attribute code. It must also access the character generator font, and subsequently access the Horizontal PEL Panning register in the Attribute Controller. The display enable signal must be skewed one character clock unit for every access. This allows the video output to be in synchronization with the horizontal and vertical retrace signals. See Table 12. Bits 4-0 A binary value programmed in these bits is compared to the six least-significant bits of the horizontal character counter to determine the status of the horizontal blanking signal. The comparison is equal at the time the horizontal blanking signal becomes inactive. Use the following algorithm to calculate the width W of blanking signal: Value of Start Blanking register + width of blanking signal in character clock units = 6-bit result to be programmed into these bits. Bit number 5 is located in the End Horizontal Retrace register. ## Start Horizontal Retrace Register Port = 03?5 Index = 04 Bit Description 7-0 Start Horizontal Retrace Bits 7-0 This register is used to center the screen horizontally and to specify the character position at which the Horizontal Retrace Pulse becomes active. The value programmed is a binary count of the character position number at which the signal becomes active. ## End Horizontal Retrace Register Port = 03?5 Index = 05 Bit Description 7 End Horizontal Blanking, bit 5 6,5 Horizontal Retrace Delay 4-0 End Horizontal Retrace This register specifies the character position at which the Horizontal Retrace Pulse becomes inactive. Bit 7 This is bit number 5 of End Horizontal Blanking. The first four bits are located in the End Horizontal Blanking register (index hex 03). Bits 6,5 These bits control the skew of the Horizontal Retrace signal. See Table 12. Bits 4-0 A value programmed here is compared to the five least-significant bits of the horizontal character counter. When they are equal, the horizontal retrace signal becomes inactive. Use the following algorithm to calculate the width W of the retrace signal: Value of Start Horizontal Retrace Register + Width of Horizontal Retrace signal in character clock units = 5-bit result to be programmed into the End Horizontal Retrace Register. #### Vertical Total Register Port = 03?5 Index = 06 Bit Description 7-0 Vertical Total (-2) The 8-bit binary value gives the number of horizontal scan lines on the CRT screen, minus 2, including vertical retrace. This is the low-order 8-bits of a 10-bit register. Bit 8 or this register is located in the CRT Controller Overflow register (hex 07, bit 0). Bit 9 of this register is located in the CRT Controller Overflow register (hex 07, bit 5). Bits 7-0 Total number of horizontal scan lines, minus 2. ## Overflow Register Port = 03?5 Index = 07 Bit Description 7 Start Vertical Retrace Bit 9 6 Vertical display Enable End Bit 9 5 Vertical Total Bit 9 4 Line Compare Bit 8 3 Start Vertical Blank Bit 8 2 Start Vertical Balik Bit 8 1 Vertical display Enable End Bit 8 Vertical Total Bit 8 O Bit 7 Bit 9 of the Start Vertical Retrace register. Bit 6 Bit 9 of the Vertical display Enable End Register. Bit 5 Bit 9 of the Vertical Total Register. Bit 4 Bit 8 of the Line Compare Register. Bit 3 Bit 8 of the Start Vertical Blank Register. Bit 2 Bit 8 of the Start Vertical Retrace Register. #### TABLE 12. SKEW | Bit 6 | Bit 5 | Amount of Skew | |-------|-------|----------------| | 0 | 0 | Zero skew | | 0 | 1 | One skew | | 1 | 0 | Two skew | | 1 | 1 | Three skew | | | | | #### TABLE 13. CLOCK SKEW | Bit 6 | Bit 5 | 5 Function | | |-------|-------|----------------------------|--| | 0 | 0 | Zero-character clock skew | | | 0 | 1 1 | One-character clock skew | | | 1 | 0 | Two-character clock skew | | | 1 | [ 1 ] | Three-character clock skew | | Bit 1 Bit 8 of the Vertical Display Enable End Register. Bit 0 Bit 8 of the Vertical Total Register. ## Preset Row Scan Register Port = 0375 index = 08 Bit Description Reserved Byte Panning Control 4-0 Starting Row Scan Count after a Vertical Retrace #### Bit 7 Reserved Bits 6,5 Bits 6 and 5 control byte panning when programmed as multiple shift modes. (This is currently not used.) The PEL Panning register in the attribute section allows panning of up to eight single PELs. When in single byte shift modes the CRT Controller start address is increased by one, while attribute panning is reset to 0. This is done to pan the next higher PEL. When used for multiple shift modes, the byte pan bits are extensions to the attribute PEL Panning register. In this manner, panning across the width of the video output shift is achieved. In the 32-bit shift mode, the byte pan and PEL panning bits provide up to 31 bits of panning capability. To pan from position 31 to 32, the **CRT** Controller start address is incremented and PEL and byte panning is reset to 0. These bits should normally be set to 0. Bits 4-0 A binary value to specify the starting row scan count after a vertical retrace. The row scan counter increments each horizontal retrace time until a maximum row scan occurs. At maximum row scan compare time, the row scan is cleared (not preset). 200-> 400 Line Conversion ## Maximum Scan Line Register Port = 03?5 Index = 09 Line Compare Bit 9 Description Bit 7 6 5 Start Vertical Blank Bit 9 4-0 Maximum Scan Line Bit 7 A logical 1 causes the clock to the row scan counter divided by 2 and enables 200 to 400 line conversion. This allows the older 200-line modes to be displayed as 400 lines on the display (i.e. each line is displayed twice). When this bit is a 0, the clock to the row scan counter is equal to the Bit 6 Bit 9 of the Line Compare Register. Bit 9 of the Start Vertical Blank Register. horizontal scan rate. Bits 4-0 These bits specify the number of lines per character row. The number to be programmed is the maximum row scan number minus 1. #### Cursor Start Register Port = 03?5 Port = 03?5 Index = 0A Bit Description 7,6 Reserved 5 Cursor Off 4-0 Cursor Starts Bits 7,6 Reserved Bit 5 A logical 1 turns off the cursor, Bits 4-0 The value of these five bits tells the row scan line of a character where cursor is to begin. a logical 0 turns on the cursor. Note that when Cursor Start is programmed with a value greater than the Cursor End, no cursor is generated. #### Cursor End Register Port = 03?5 Index = 0B Bit Description Reserved Cursor Skew Control Cursor Ends Bit 7 Reserved Bits 6,5 These bits control the skew of the cursor signal. Cursor skew delays the cursor by the selected number of clocks. Each additional skew moves the cursor right one position on the screen. See Table 13. Bits 4-0 These bits specify the row scan line of a character where the cursor is to end. ## Start Address High Register Port = 03?5 Index = 0C Bit Description 7-0 High Order 8-bit Start Address Bits 7-0 These are the high order 8 bits of the start address. The 16-bit value, from the high-order and low-order Start Address Registers, is the first address after the vertical retrace on each screen refresh. ## Start Address Low Register Port = 03?5 Index = 0D Bit Description 7-0 Low Order Start Address Bits 7-0 These are the low-order 8 bits of the start address. ## Cursor Location High Register Port = 03?5 Index = 0E Bit Description 7-0 High Order Cursor Location Bits 7-0 These are the high-order 8 bits of the cursor location. ## Cursor Location Low Register Port = 03?5 Index = 0F Bit Description 7-0 Low Order Cursor Location Bits 7-0 These are the low-order 8 bits of the cursor location. ## Start Vertical Retrace Register Port = 03?5 Index = 10 Bit Description 7-0 Low Order 8-bit Vertical Retrace Pulse Bits 7-0 These are the low-order 8 bits of the vertical retrace pulse start position in horizontal scan lines. Bit 8 and 9 are in the CRTC Overflow register. ## End Vertical Retrace Register Port = 03?5 Index 11 7 Protect R0-R7 6 Select 5 Refresh Cycles 5 0=Enable Vertical Interrupt 4 0=Clear Vertical Interrupt Description Bit 3-0 End Vertical Retrace Bit 7 A logical 0 enables writing to CRTC registers 0-7. A logical 1 CHTC registers 0-7. A logical 1 disables writing these registers. Note that the line compare bit 4 in register 07 is not protected. Bit 6 A logical 0 selects three refresh DRAM cycles. A logical 1 selects five refresh cycles per horizontal line. Five refresh cycles are used for slow (15.75 KHz) sweep rate displays. Bit 5 A logical 0 enables a vertical retrace interrupt. This occurs on IRQ2. Since this may be a "shared" interrupt level, the Input Status register 0, bit 7, must be checked to determine if the VGA caused the interrupt to occur Bit 4 A logical 0 clears a vertical retrace interrupt. An interrupt handler has to reset an internal flip-flop by writing a 0 to this bit, then setting the bit to 1 so that the flip-flop does not hold interrupts inactive. Note that you do not change the other bits in this register when changing this bit. Read this register first before resetting this flip-flop so that the value of the other bits can be determined and saved for later use. Bits 3-0 These bits determine the horizontal scan count value when the vertical retrace output signal becomes inactive. Use the following algorithm to calculate the width of vertical retrace signal: Value of Start Vertical Retrace register + width of vertical retrace signal in horizontal scan line units = 4-bit result to be programmed into the End Vertical Retrace register. ## Vertical Display Enable End Register Port = 03?5 Index = 12 Bit Description 7-0 Low Order Vertical Display Enable End (-1) Bits 7-0 These are the low-order 8 bits of a 10-bit register that determines the vertical display enable end position. Bit 8 and 9 of this register are contained in the CRT Controller Overflow register bit 1 and 6 respectively. #### Offset Register Port = 03?5 Index = 13 Bit Description 7-0 Logical Line Width of the Screen Bits 7-0 This register defines the logical line width of the screen. Starting memory address for the next character row is larger than the current character row by a factor of 2X or 4X this value. A word address programs the Offset Register. This word address may be a word or double word address, determined by the means of clocking the CRT Controller. #### Underline Location Register Port = 03?5 Index = 14 Bit Description 7 Reserved 6 Doubleword Mode 5 Count by 4 4-0 Horizontal row scan where underline will occur Bit 7 Reserved Bit 6 A logical 1 enables doubleword mode for memory addresses. Also, see the description of the CRT Controller Mode Control register bit 6. Bit 5 When this bit is set to 1, the memory address counter is clocked with the character clock divided by 4. This bit is used when doubleword addresses are used. Bits 4-0 This register determines the horizontal row scan of a character row where an under- line occurs. The scan line number desired is a value one greater than the number programmed. ## Start Vertical Blanking Register Port = 03?5 Index = 15 Bit Description 7-0 Start Vertical Blanking (-1) Bits 7-0 These are the low-order 8 bits of a 10-bit register. The value of this register determines when the vertical blanking signal becomes active. Bit 8 is located in the CRT Controller Overflow register bit 3. Bit 9 is contained in the CRT Controller Maximum Scan Line register bit 5. The horizontal scan line count (at which the vertical blanking signal becomes active) is one greater than the value of these 10 bits. ## End Vertical Blanking Register Port = 03?5 Index = 16 Bit Description 7-0 End Vertical Blanking Bits 7-0 This register defines the horizontal scan count value at the time the vertical blank output signal goes inactive. The register must be programmed in whole units of horizontal scan lines. Use the following algorithm to obtain the width of the vertical blank signal. (Value of Start Vertical Blank register - 1) + width of vertical blank signal in horizontal scan unit = 8-bit result to be programmed into the End Vertical Blank register. ## CRTC Mode Control Register Port = 03?5 Index =17 Bit Description 7 Hardware Reset 6 Word/Byte Mode 5 Address Wrap 4 Reserved 3 Count by Two2 Horizontal Retrace Select Select Row Scan Counter CMSO Bit 7 A logical 0 clears horizontal and vertical retrace. A logical 1 enables horizontal and | TARI | F 14 | REGISTER | MODES | |------|---------|----------|-------| | LADL | .E 144. | neuisien | NUCLU | | Memory<br>Address | Byte<br>Mode | Word<br>Mode | Doubleword<br>Mode | |-------------------|--------------|--------------|--------------------| | MA0/RFA0 | MA0 | MA15/MA13 | MA12 | | MA1/RFA1 | MA1 | MA0 | MA13 | | MA2/RFA2 | MA2 | MA1 | MA0 | | MA3/RFA3 | МАЗ | MA2 | MA1 | | MA4/RFA4 | MA4 | МАЗ | MA2 | | MA5/RFA5 | MA5 | MA4 | МАЗ | | MA6/RFA6 | MA6 | MA5 | MA4 | | MA7/RFA7 | MA7 | MA6 | MA5 | | MA8/RFA8 | MA8 | MA7 | MA6 | | MA9 | MA9 | MA8 | MA7 | | MA10 | MA10 | MA9 | MA8 | | MA11 | MA11 | MA10 | MA9 | | MA12 | MA12 | MA11 | MA10 | | MA13 | MA13 | MA12 | MA11 | | MA14 | MA14 | MA13 | MA12 | | MA15 | MA15 | MA14 | MA13 | vertical retrace. This bit does not reset any other registers or outputs. A logical 0 selects word Bit 6 address mode which shifts all memory address counter bits down one bit, and the most significant bit of the counter appears on the least significant bit of the memory address output. A logical 1 selects the byte address mode. Note that bit 6 of the Underline Location register also controls the addressing. When it is a 0, bit 6 of this register has control. When it is a 1, the addressing is forced to be shifted by two Bit 5 This bit selects the memory address counter bit MA13 or bit MA15, and it appears on the MA0 of CRT address output in the word address mode. A logical 1 selects MA15. MA13 is selected for the case where only 64K memory is installed. Since 256K memory is always installed for VL82C037, MA15 should be selected in odd/even mode. #### Bit 4 Reserved Bit 3 A logical 0 causes the memory address counter clocked with the normal character clock input. A logical 1 clocks the memory address counter with the character clock input divided by 2. This bit is used to create either a byte or word refresh address for the display buffer. A logical 0 selects normal horizontal retrace. A logical 1 selects horizontal retrace divided by 2 as the clock that controls the vertical timing counter. This bit can be used to effectively double the vertical resolution capability of the CRT Controller. The 10-bit vertical counter has a maximum of 1024 scan lines. If the vertical counter is clocked with the horizontal retrace divided by 2, then the vertical resolution is doubled to 2048 horizontal scan lines. Bit 1 A logical 0 selects row scan counter bit 1 for CRT memory address bit MA14. A logical 1 selects MA14 counter bit for CRT memory address bit MA14. Bit 0 When this bit is a logical 0, row scan address bit 0 is substituted for memory address bit 13 during active display time. A logical 1 enables memory address bit 13 to appear on the memory address output bit 13 of the CRT Controller. #### Line Compare Register Port = 03?5 index = 18 Bit Description 7-0 Line Compare Target Bits 7-0 This register is the lower byte of the line compare target. When the vertical counter achieves this value, the internal start of the line counter is reset. This causes an area of the screen is not affected by scrolling. Bit 9 is in the Maximum Scan Line register. Bit 8 of this register is in the Overflow Register. ## GRAPHICS CONTROLLER REGISTERS This section describes all the registers located in the Graphics Controller. See Table 15. ## Graphics Address Register Port = 03CE Bit Description 7-4 Reserved 3-0 Graphics Address Bits 7-4 Reserved Bits 3-0 A binary value in these bits points to the other registers in the Graphics Controller section. #### Set/Reset Register Port = 03CF Bit Description 7-4 Reserved Index = 00 Bit 2 ### TABLE 15. GRAPHICS CONTROLLER REGISTERS | Register Name | Port | Index | |------------------|------|-------| | Graphics Address | 03CE | _ | | Set/Reset | 03CF | 00 | | Enable Set/Reset | 03CF | 01 | | Color Compare | 03CF | 02 | | Data Rotate | 03CF | 03 | | Read Map Select | 03CF | 04 | | Graphics Mode | 03CF | 05 | | Miscellaneous | 03CF | 06 | | Color Don't Care | 03CF | 07 | | Bit Mask | 03CF | 80 | ### **TABLE 16. DATA FUNCTIONS** | Bit 4 | Bit 3 | Function | |------------------|------------------|-------------------------------------------------------------------------------------------------------| | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | Data unmodified Data ANDed with latched data Data ORed with latched data Data XORed with latched data | ### **TABLE 17. ROTATE FUNCTIONS** | Bit 2 | Blt 1 | Bit 0 | Function | |-------|-------|-------|--------------------| | | 0 | 0 | No Rotate | | 0 | 0 | 1 | Rotate 1 Position | | 0 | 1 | 0 | Rotate 2 Positions | | 0 | 1 | 1 | Rotate 3 Positions | | 1 | 0 | 0 | Rotate 4 Positions | | 1 | 0 | 1 | Rotate 5 Positions | | 1 | 1 1 | 0 | Rotate 6 Positions | | 1 | 1 | 1 | Rotate 7 Positions | | | | | | | 3 | Set/Reset Map 3 | |---|-----------------| | 2 | Set/Reset Map 2 | | 1 | Set/Reset Map 1 | | 0 | Set/Reset Map 0 | Bits 7-4 Reserved Bits 3-0 During CPU memory write with write mode 0, the value of these bits will be written to all eight bits of the respective memory map if Set/Reset mode is enabled for the corresponding map. #### Enable Set/Reset Register Port = 03CF Index = 01 Description Bit Reserved 7-4 3 Enable Set/Reset Map 3 Enable Set/Reset Map 2 2 Enable Set/Reset Map 1 1 Enable Set/Reset Map 0 n Bits 7-4 Reserved Bits 3-0 A logical 1 enables the Set/ Reset function. When enabled, the respective memory map is written with the value of the Set/Reset register, if write mode 0 is selected. However, when write mode is 0 and Set/Reset is not enabled on a map, that map is written with the value of the system microprocessor data. #### Color Compare Register Port = 03CF Bit Description 7-4 Reserved Color Compare Map 3 3 Color Compare Map 2 Color Compare Map 1 Index = 02 Color Compare Map 0 Bits 7-4 Reserved 2 1 0 Bits 3-0 These bits represent a 4-bit color value to be compared if the system microprocessor sets read mode 1 and does a memory read, the data returned from the memory cycle will be a 1 in each bit position where the four maps equal the color compare register. > The color compare bit is the value that all bits of the corresponding map's byte are compared with. Each of the eight bit positions of the selected byte are then compared across the four maps and a 1 is returned in each bit position where the bits of all four maps equal their respective color compare values. **Data Rotate Register** Port = 03CF Rit Description Index = 03 7-5 Reserved Function Select 4 3 Function Select Rotate Count 2 2 **Rotate Count 1** 1 Rotate Count 0 n Bits 7-5 Reserved Bits 4,3 Data in the system microprocessor latches can operate logically with data written to memory. If rotate function is selected, it is applied before the logical function. See Table 16. Bits 2-0 These bits specify the number of positions to right-rotate the system microprocessor data bus during system microprocessor memory writes. This operation is done when the write mode is 0. To write nonrotated data, the bits should be set to 0. See Table 17. #### Read Map Select Register Port = 03CF Index = 04 Description Bit 7-2 Reserved 1 Map Select 1 Map Select 0 Bits 7-2 Reserved Bits 1.0 These bits select the memory map number from which the ### **TABLE 18. MAP DATA** | MS 1 | MS 0 | Function | |------|------|----------------------| | 0 | 0 | Read data from Map 0 | | 0 | 1 | Read data from Map 1 | | 1 | 0 | Read data from Map 2 | | 1 | 1 | Read data from Map 3 | | | | ' | #### TABLE 19. FUNCTION DECODE | Bit-1 | Bit-0 | Function | |-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | 0 | The system microprocessor data is rotated by the number or counts in the Rotate Register that each memory map is written with, unless Set/Reset is enabled for the map. When the map Set/Reset is enabled, they are written with 8-bits of the value in the Set/Reset Register for that map. | | 0 | 1 | The contents of the system microprocessor latches are written to each memory map. A system read operation loads these latches. | | 1 | 0 | 8-bits of the value of data bit n fills memory map n (0-3). | | 1 | 1 | The maps are written by the 8-bits contained in the Set/Reset Register for that specific map (Enable Set/Reset Register is a "don't care"). Rotated system microprocessor data is logically ANDed with Bit Mask Register data and forms an 8-bit value. This is the function that the Bit Mask Register performs in write modes 0 and 2. (See Bit Mask Register.) | Note that the logic function specified by the Function Select register is applied to data being written to memory following modes 0, 2, and 3 described above. system microprocessor reads data. This register has no effect on the color compare read mode. In odd/even modes the value may be 00 or 01 (10 or 11) for chained maps 0, 1 (2, 3). See Table 18. | Graphic | Graphics Mode Register | | | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Port = 0 | 3CF Index = 05 | | | | Bit | Description | | | | 7 | Reserved | | | | 6 | 256 Color Mode | | | | 5 | Shift Register Mode | | | | 4 | Odd/Even | | | | 3 | Read Type | | | | 2 | Reserved | | | | 1,0 | Write Mode | | | | Bit 7 | Reserved | | | | Bit 6 | A logical 0 permits bit 5 to<br>handle the loading of the Shift<br>Registers. A logical 1 supports<br>the 256 color mode (only for<br>320X200 320X400 resolution). | | | | Bit 5 | A logical 1 instructs the Shift | | | A logical 1 instructs the Shift Registers in the graphic section to format the serial data with odd-numbered bits from both maps on the oddnumbered maps and evennumbered bits from both maps on the even-numbered maps. This bit is also used in modes Bit 4 A logical 1 enables the odd/ even addressing mode, that can emulate the IBM CGA compatible mode. The value programmed is the value of the Memory Mode register bit 2 of the Sequencer. Bit 3 A logical 0 causes the system microprocessor to read data from the memory map selected by the Read Map Select register, unless chain 4, link 4, or link 8 is set to 1. In this case the Read Map Select register has no effect. When this bit is a logical 1, the system microprocessor reads the results of the comparison of the four memory maps and the Color Compare register. Reserved Bit 2 Bits 1,0 Write Mode (See Table 19.) #### Miscellaneous Register Port = 03CF Index = 06 Bit Description 7-4 Reserved 3 Memory Map 1 2 Memory Map 0 Odd/Even **Graphics Mode** Bits 7-4 Reserved Bits 3,2 These bits control the mapping between regenerative buffer and the CPU address space. The bit functions are defined in Table 20. Bit 1 When set to a logical 1, this bit instructs the system microprocessor address bit 0 to be replaced by a higher-order bit. The odd/even maps will be selected with odd/even values of the system microprocessor A0 bit, respectively. Bit 0 This is the text mode addressing control. A logical 1 enables the graphics mode. The character generator address latches are disabled, when set to graphics mode. #### Color Don't Care Register Port = 03CF Index = 07Bit Description 7-4 Reserved 3 Map 3 = Don't Care Map 2 = Don't Care Map 1 = Don't Care Map 0 = Don't Care Bits 7-4 Reserved #### **TABLE 20. BYTE SELECT** | Bit 3 | Bit 2 | Function | |-------|-------|--------------------------| | 0 | 0 | Hex A0000 for 128K bytes | | 0 | 1 | Hex A0000 for 64K bytes | | 1 | 0 | Hex B0000 for 32K bytes | | 1 | 1 | Hex B8000 for 32K bytes | | | I | | # TABLE 21. ATTRIBUTE CONTROLLER REGISTERS | Register Name | Port | Index | |---------------------------------|------|-------| | Address Register | 03C0 | _ | | Palette Registers | 03C0 | 00-0F | | Attribute Mode Control Register | 03C0 | 10 | | Overscan Color Register | 03C0 | 11 | | Color Plan Enable Register | 03C0 | 12 | | Horizontal PEL Panning Register | 03C0 | 13 | | Color Select Register | 03C0 | 14 | | | | | | Bit 3 | <ol> <li>Do the color compare for<br/>map 3.</li> </ol> | |-------|---------------------------------------------------------| | | 0 - Don't Care for map 3. | | Bit 2 | 1 - Do the color compare for | | | map 2. | | | 0 - Don't Care for map 2. | | Bit 1 | 1 - Do the color compare for | | | map 1. | | | 0 - Don't Care for map 1. | | Bit 0 | 1 - Do the color compare for | | | map 0. | | | 0 - Don't care for map 0. | #### Bit Mask Register Port = 03CF Bit Description 7-0 Bit Mask for 8-bits of data Index = 08 Bits 7-0 Bits programmed to a 1 allow writes to the corresponding bits in the maps. A logical 0 permits the corresponding bit n in each map to be locked at its current state, providing the location being written was the final location read by the system's microprocessor. Note that the bit mask applies to write modes 0 and 2. To preserve bits using the bit mask, data must be latched internally by reading the location. When data is written to preserve the bits, the most current data in the latches is written in those positions. The bit mask applies to all maps simultaneously. ## ATTRIBUTE CONTROLLER REGISTERS This section describes all the registers located in Attribute Controller section. See Table 21. | | ute Address Register<br>= 03C0 | 5<br>4 | P5<br>P4 | |-----|--------------------------------|--------|----------| | Bit | Description | 3 | P3 | | 7,6 | Reserved | 2 | P2 | | 5 | Palette Address Source | 1 | P1 | | 4-0 | Attribute Address | 0 | P0 | #### Bits 7,6 Reserved Bit 5 Bit 5 must be cleared to 0 before loading the Color Palette registers. Normal operation of the Attribute Controller, requires that bit 5 be set to 1. This allows the video memory data to access the palette registers. Bits 4-0 A binary value in these bits points to the Attribute Data register where data is to be written. The Address and Data registers can not be selected by the Attribute Controller register. An internal address flip-flop controls this selection. To initialize the flip-flop, an I/O Read instruction must be sent to the Attribute Controller at address 03BA or 03DA. This clears the flip-flop, and then selects the Address register. The Address register is then loaded with an I/O Write to 03C0. The following I/O Write instruction to 03C0 loads the Data register. The flip-flop changes state each time an I/O Write instruction is sent to the Attribute Controller. It does not change when an I/O Read to 03C1 occurs. #### Palette Registers Write-03C0 Read-03C1 Index-00-0F Bit Description 7.6 Reserved #### Bits 7.6 Reserved Bits 5-0 The attribute byte of text or graphic color value is indexed to these 16 Color Palette registers. The content of the pointed Palette register is then used as a value sent off the chip to the video DAC, where they in turn serve as addresses into the DAC internal registers. A logical 1 selects the appropriate color. The Palette registers should be modified only during the vertical retrace interval to avoid problems with the displayed image. ## Attribute Mode Control Port = 03C0(R), 03C1(W) Index = 10 Bit Description P5. P4 Select 7 6 PEL Width PEL Panning Compatibility 5 4 Reserved Select Background Intensity or 3 **Enable Blink** 2 Enable Line Graphics Character Code Mono Emulation O Graphics/Alphanumeric Mode Bit 7 A logical 0 selects the output of the Palette register as P5, P4. A logical 1 selects bits 1, 0 of the Color Select register as P5, P4 which are digital video bits that go off the chip. Bit 6 A logical 1 causes the video pipeline to be sampled so that eight bits are available to select a color in the 256 color mode (hex 13). This bit must be a logical 0 in all other modes. Bit 5 A logical 0 makes line compare and has no effect on the output of the PEL Panning register. A logical 1 causes a line compare in the CRTC to force the output of the PEL Panning register to 0. When VSYNC occurs, the output reverts to its programmed value. This bit allows part of the screen to be panned. #### Bit 4 Reserved Bit 3 This bit is set to 1 for blinking graphics modes. A logical 1 enables the blink function in alphanumeric modes. A logical 0 selects the background intensity of the input. Previously, this mode was on the MDA and CGA modes. Bit 2 A logical 1 enables the special line graphics character codes for the Monochrome emulation mode. A logical 0 causes the ninth dot the same as the background. When this bit is enabled it forces the ninth dot of a line graphic character to be the same as the eighth dot of a line graphic character. Graphics character codes are hex C0 through hex DF. For character fonts that do not use the line graphics character codes in this range (hex C0 through hex DF) bit 2 should be a 0. If not, unwanted video information will be shown on the CRT screen. Bit 1 A logical 1 sets monochrome emulation mode. A logical 0 sets color emulation mode. Bit 0 A logical 0 selects text mode. A logical 1 selects graphics mode. Overscan Color Register Port = 03C0(R), 03C1(W) Index = 11 Bit Description ### **TABLE 22. COLOR PLANE AND STATUS** | Color Plane Register | | Input Status Register 1 | | | |----------------------|-----|-------------------------|-------|--| | Bit 5 Bit 4 | | Blt 5 | Bit 4 | | | 0 | 0 | P2 | P0 | | | 0 | 1 1 | P5 | P4 | | | 1 | 0 | P3 | P1 | | | 1 | 1 | P7 | P6 | | | | l | | | | | 7 | P7 | | |---|----|--| | 6 | P6 | | | 5 | P5 | | | 4 | P4 | | | 3 | P3 | | | 2 | P2 | | | 1 | P1 | | | 0 | PO | | Bits 7-0 A binary value in this register determines the border color displayed on the CRT screen. The border color is displayed right after the Display Enable signal goes low and before the start of blanking period. The border is not supported in the 40-column text modes or the 320-PEL graphics modes, except for mode hex 13. ## Color Plane Enable Port = 03C0(R), 03C1(W) Index = 12 **Enable Color Plane** Bit Description 7,6 Reserved 5,4 Video Status MUX Bits 7.6 Reserved 3-0 Bits 5,4 Two of the eight color outputs will be selected, according to these two bits, to reflect the real time status on bits 4 and 5 of Input Status Register 1. See Table 22. Bits 3-0 A logical 1 for each bit enables the respective display memory color plane. A logical 0 disables color plane. #### Horizontal PEL Panning Port = 3C0(W), 3C1(R) Index = 13 Bit Description 7-4 Reserved 3-0 Horizontal PEL Panning Bits 7-4 Reserved Bits 3-0 These four bits select the number of pixels that will shift the video data to the left. PEL panning is available in both graphics and text modes. In modes 0+, 1+, 2+, 3+, 7 and 7+, the maximum shift is eight pixels. Mode 13 allows a maximum of three pixels. In the rest of the modes, the image can be shifted a maximum of seven pixels. The order for shifting the image is shown in Table 23. ## Color Select Register ## Port = 03C0(W), 03C1(R) Index = 14 | Bit | Description | |----------|----------------| | 7-4 | Reserved | | 3 | Select Color 7 | | 2 | Select Color 6 | | 1 | Select Color 5 | | <b>3</b> | Select Color 4 | Bits 7-4 Reserved Bits 3,2 These bits are the two highorder bits of the 8-bit digital color value sent off-chip in all modes except the 256 color graphics. In the 256 color modes, the 8-bit attributes are stored in video memory. This becomes the 8-bit digital color value to be sent off-chip to the video DAC. These bits are also used to switch quickly among sets of colors in the video DAC. Bits 1,0 These two bits can be used to replace the P4 and P5 bits from the Attribute Palette registers to form the 8-bit digital color value sent off-chip. This is controlled by bit 7 of Attribute Mode Control register. By using this feature, sets of colors can be rapidly switched in the video DAC. #### **TABLE 23. PEL REGISTER** | | Number of PELs Shifted to the Left | | | | |-------------------------------|------------------------------------|--------------------|------------|--| | PEL Panning<br>Register Value | 0+, 1+, 2+<br>3+, 7, 7+ | All Other<br>Modes | Mode<br>13 | | | 0 | 1 | 0 | 0 | | | 1 | 2 | 1 | _ | | | 2 | 3 | 2 | 1 | | | 3 | 4 | 3 | _ | | | 4 | 5 | 4 | 2 | | | 5 | 6 | 5 | - | | | 6 | 7 | 6 | 3 | | | 7 | 8 | 7 | _ | | | 8 | 0 | | - | | ### **TABLE 24. EXTENDED REGISTERS** | Port | Index | R/W | Bits | Register | |------|-------|-----|------|----------------------------| | 3DE | - | R/W | 5 | Extension Address Register | | 3DF | D | R/W | 6 | Bandwidth Control | | 3DF | E | R/W | 4 | I/O Trap Control | | 3DF | F | R | 8 | NMI Data Cache (FIFO) | | 3DF | 10 | R | 8 | Read DIP Switch | #### **EXTENDED REGISTERS** A set of new registers are added into the basic version of VGA to perform new features and enhancements. They are grouped under the assignment of I/O port 3DE and 3DF for address and data access respectively. All, except the NMI Data Cache register have both read and write access. A summary of new registers is given in Table 24. ## 3DE - EXTENSION ADDRESS REGISTER Bit Description 0-4 5-bit index pointer to the extension data registers. 5-7 Reserved The contents of this register need to be programmed before the data register is accessed. The I/O port assigned is 3DE for both read and write access. #### 3DF - BANDWIDTH CONTROL INDEX D Bit Description 0-2 Reserved 3-4 Bandwidth Control (See Table 25.) 5 Clock select bit 2 (CSEL2). Used with bit 2 and 3 of Miscellaneous Register. Up to eight different clock inputs can be selected from. (See Table 26.) ### 3DF - I/O TRAP CONTROL INDEX E Bit Description When set to 1, turn on the trap and generate NMI for downward compatibility emulation. When set to 0, it turns off the NMI logic. 1-2 Backward Compatibility Mode (See Table 27.) 3-6 Reserved = 0 Graphics Latch read compatibility. ### 3DF - NMI DATA CACHE INDEX F Bit Description 0-7 First read of this register gets the address of the trapped I/O. Second read gets the data of the trapped I/O. The size of the cache is two bytes wide and five rows deep. Each read would cause read pointer autoincremented and gets reset at the end of information. ### **TABLE 25. BANDWIDTH** | Bit 4 | Bit 3 | Bandwidth | | | |-------|-------|-----------|--|--| | 0 | 0 | 1-4 | | | | 1 | 0 | 1-7 | | | | 0 | 1 | 1-9 | | | | 1 | 1 | Reserved | | | ### **TABLE 26. CLOCK** | CSEL2 | CSEL1 | CSEL0 | CLOCK | |-------|-------|-------|----------------------| | 0 | 0 | 0 | 25.175 MHz | | Ō | 0 | 1 | 28.322 MHz | | 0 | 1 1 | 0 . | External Input Clock | | 0 | 1 | 1 | Reserved | | 1 | Ιo | 0 | 14.318 MHz | | 1 | lo | 1 | 16.257 MHz | | 1 | 1 | 0 | Reserved | | 1 | 1 1 | 1 | 35.5 MHz | | | | | | ### **TABLE 27. GRAPHICS MODE** | Bit 2 | Bit 1 | Mode | |-------|-------|-------------------| | 0 | 0 | VGA | | 0 | 1 | EGA | | 1 | 0 | CGA | | 1 | 1 | MCGA (MDA & HERC) | Note that only the first 8-bits of I/O address are saved into cache. That means the first digit "3" is ignored. The trapped software should be taking care of this after getting out the address from cache. Since bit 7 of the first read of this register is always 1 if there is an address saved at this position, the trapped software should check this bit to determine whether this is a last read or not. Note that this is a read only register. #### 3DF - READ DIP SWITCH INDEX 10 | - HEAD DIE CHILL | |------------------| | Description | | Reserved | | DIP Switch 6 | | DIP Switch 5 | | DIP Switch 4 | | DIP Switch 3 | | DIP Switch 2 | | DIP Switch 1 | | DIP Switch 0 | | | These bits will be read in during BIOS initialization to determine the type of monitor currently attached. # AC CHARACTERISTICS: TA = 0°C to +70°C, VCC = 5 V $\pm$ 5%, GND = 0 V I/O READ/WRITE, DAC READ/WRITE, SWITCH READ (See Figures 1, 2, 8, 9 & 10.) | Symbol | Parameter | Min | Max | Units | Conditions | |--------|----------------------------|-----|-----|-------|------------| | tACS | Address Setup Time | 60 | _ | ns | | | tCCS | ASEL Setup Time | 30 | _ | ns | | | tCAH | Address Hold Time | 0 | _ | ns | | | tCCH | ASEL Hold Time | 0 | | ns | | | tCPW | Command Pulse Width (Note) | 200 | _ | ns | | | tDWD | Write Data Delay | | 80 | ns | | | tDWH | Write Data Hold Time | 0 | _ | ns | | | tCED | -EDBUF and -EABUF Delay | | 50 | ns | | | tRDD | Read Data Valid Delay | _ | 120 | ns | | | tRDH | Read Data Hold Time | 10 | _ | ns | | | tRDIRD | Read to DIR Delay | _ | 45 | ns | | | tDRDD | -DACR Delay | _ | 50 | ns | | | tDWDD | -DACW Delay | | 50 | ns | | | tRDACD | Read to DAC Read Delay | _ | 40 | ns | | | tWDACD | Write to DAC Write Delay | _ | 40 | ns | | | tRSWTR | Read to Switch Read Delay | _ | 40 | ns | | Note: 200ns when VCLK0 = 25 MHz; otherwise, three clocks +80 ns. MEMORY READ/WRITE (See Figures 3 & 4.) | Symbol | Parameter | Min | Max | Units | Conditions | |---------|------------------------------|-----|-----|-------|------------| | tACS | Address Setup Time | 60 | _ | ns | | | tCCS | ASEL Setup Time | 30 | | ns | | | tCAH | Address Hold Time | 0 | _ | ns | | | tCCH | ASEL Hold Time | 0 | _ | ns | | | tDWD | Write Data Delay | | 80 | ns | | | tDWH | Write Data Hold Time | 0 | _ | ns | | | tCED | –EDBUF and –EABUF Delay | | 50 | ns | | | tRDIRD | Read to DIR Delay | - | 45 | ns | | | tMRIOLD | Command to CPURDY Low Delay | | 40 | ns | | | tMRIOHD | RD Data to CPURDY High Delay | _ | 15 | ns | | | tVDH | Valid RD Data Hold Time | | 45 | ns | | ## AC CHARACTERISTICS (Cont.) ## DRAM READ/WRITE (See Figures 6 & 7.) | Symbol | Parameter | Min | Max | Units | Conditions | |--------|---------------------------|--------------|-----|-------|------------| | tRS | Row Address Setup | 10 | _ | ns | | | tRH | Row Address Hold Time | .5 tCLK | _ | ns | | | tRPW | -RAS Low Time | 4 tCLK -10 | _ | ns | | | tRPC | -RAS High Time | 3 tCLK | _ | ns | | | tCS | Column Address Setup Time | 10 | _ | ns | | | tCH | Column Address Hold Time | tCLK | _ | ns | | | tCPW | -CAS Low Time | 4.5 tCLK | _ | ns | | | tCPC | -CAS High Time | 2.5 tCLK -10 | _ | ns | | | tROEA | -RAS to -OE Delay | 2.5 tCLK -10 | _ | ns | | | tRWE | -RAS to -WE Delay | 2.5 tCLK -10 | _ | ns | | | tWER | -WE to -RAS High | tCLK | _ | ns | | | tRC | -RAS to -CAS Reference | 1.5 tCLK -10 | _ | ns | | | tDWS | Data to –WE Setup Time | 10 | _ | ns | | | tDWH | Data to -WE Hold Time | tCLK | _ | ns | | ### CLOCK AND VIDEO (See Figure 5.) | Symbol | Parameter | Min | Max | Units | Conditions | |--------|---------------------|-----|-----|-------|------------| | tCLK | CLKIN/DOTCLK Cycle | 28 | | ns | | | tPEL | P0-P7 Delay | | 80 | ns | | | tBNK | -BLANK Delay | | 80 | ns | | | tSYNC | HSYNC/VSYNC Delay | _ | 80 | ns | | | tPCLK | CLKIN to PCLK Delay | _ | 60 | ns | | ### TIMING DIAGRAMS ### FIGURE 1. I/O READ TIMING ### FIGURE 2. I/O WRITE TIMING ### FIGURE 5. CLOCK AND VIDEO TIMING ### FIGURE 6. DRAM READ TIMING #### FIGURE 7. DRAM WRITE TIMING ### FIGURE 8. DAC READ TIMING #### FIGURE 9. DAC WRITE TIMING ### FIGURE 10. SWITCH READ TIMING ## **ABSOLUTE MAXIMUM RATINGS** **Ambient Operating** Temperature 0°C to +70°C Storage Temperature -65°C to +150°C Supply Voltage to Ground Potential -0.5 V to VCC +7.0 V Applied Input Voltage --0.5 V to VCC +7.0 V Stresses above those listed may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or any other conditions above those indicated in this data sheet is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. DC CHARACTERISTICS: $TA = 0^{\circ}C \ VCC = 5 \ V + 5\% \ GND = 0 \ V$ | Symbol | Parameter | Min | Max | Unit | Condition | |--------|--------------------------|------|-----------|------|-----------------------------------------------------| | VOH | Output High Voltage | 2.4 | | ٧ | IOH = 400 μA | | VOL | Output Low Voltage | | 0.45 | V | IOL = 20 mA, Note 1 | | VOL | Output Low Voltage | | 0.45 | V | IOL = 12 mA, Note 1 | | VOL | Output Low Voltage | | 0.45 | ٧ | IOL = 8 mA, Note 1 | | VOL | Output Low Voltage | | 0.45 | ٧ | IOL = 4 mA, Note 1 | | VOL | Output Low Voltage | | 0.45 | ٧ | IOL = 2 mA, Note 1 | | VIH | Input High Voltage | 2.0 | VCC + 0.5 | ٧ | TTL | | VIL | Input Low Voltage | -0.5 | 0.8 | V | TTL | | СО | Output Capacitance | | 8 | pF | | | CI | Input Capacitance | | 8 | pF | | | CIO | Input/Output Capacitance | | 16 | pF | | | ILI | Input Leakage Current | -10 | 10 | μА | | | OLI | Output Leakage Current | -10 | 10 | μА | | | ICC | Operating Supply Current | | 80 | mA | VIN =VCC or GND<br>VCC = 5.25 V<br>Outputs Unloaded | Note 1: 2 mA output pads: -EABUF, -EDBUF, DIR, -CRTINT, -NMI, CPURDY, -SWTR, HSYNC, VSYNC, -BLANK, -DACR, -DACW 4 mA output pads: P7-P0, DA7-DA0, MD31-MD0. 8 mA output pads: -RAS0--RAS3, -WE 12 mA output pads: -OE 20 mA output pads: -CAS