# Am81C176 # **CMOS Color Palette** # Advanced Micro Devices #### DISTINCTIVE CHARACTERISTICS - Plug-in Replacement for Inmos G171 and G176 - VGA hardware and software compatible - Clock rates up to 80 MHz - Available in 28-pin DIP and 32-pin PLCC package - 256 x 18 Color Look-Up Table (LUT) - Triple 6-bit Digital-to-Analog Converters (DACs) - RS-170A compatible RGB outputs - External current reference - Asynchronous MPU interface - Single monolithic, high-performance CMOS - Single +5 V power supply #### **GENERAL DESCRIPTION** The Am81C176 is a monolithic CMOS Color Palette and is hardware and software compatible with the VGA standard. Applications include high-resolution color graphics, CAD/CAM/CAE, and desktop publishing. The Am81C176 operates at speeds up to 80 MHz and can support monitors with resolutions up to 1024 x 768. The Am81C176 has a 256 x 18 Look-Up Table and triple 6-bit DACs. It can simultaneously display 256 colors out of an available set of 256K colors. Because of a proprietary technique, read and write operations to the Color look-up table may occur during active video. The Am81C176 generates RS-170A compatible outputs into doubly-terminated 75 $\Omega$ loads, without external buffers. The Am81C176 is fabricated using AMD's state-of-theart 1.2 $\mu$ CMOS process. The device is available in a 28-lead DIP and 32-lead PLCC package. It is pin- and functionally-compatible with the Inmos IMS G171 and IMS G176. Publication # 11912 Rev. A Amendment /0 Isaue Date: April 1989 Am81C176 3-95 # CONNECTION DIAGRAMS Top View # LOGIC SYMBOL 11912-004A 3-96 Am81C176 # ORDERING INFORMATION **Standard Products** AMD standard products are available in several packages and operating ranges. The ordering number (Valid Combination) is formed by a combination of: a. Device Number - b. Speed Option (if applicable) - c. Package Type - d. Temperature Range - e. Optional Processing | Valid Combinations | | | | | | |----------------------------------------------------------|-------------|--|--|--|--| | Am81C176-80<br>Am81C176-66<br>Am81C176-50<br>Am81C176-35 | JC, PCB, PC | | | | | #### **Valid Combinations** Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations, to check on newly released combinations, and to obtain additional data on AMD's standard military grade products. Am81C176 # PIN DESCRIPTION # **Timing Section** #### CLK # Clock source pin (TTL compatible input) This input is the pixel clock of the video system and is to be driven by a dedicated TTL buffer. The rising edge of CLK latches the BLANK and PIXo – PIXr inputs and also controls the flow of these signals through the pipeline stages of the Color Palette and DACs to the R, G, and B outputs. # **BLANK** # Blank (TTL compatible input) The $\overline{\text{BLANK}}$ input, when active, overrides the pixel data to force the R, G, and B outputs to their blank levels. This blank level is required during the monitor vertical and horizontal retrace times. It is latched on the rising edge of CLK. Typically, blank time is used to update the Color-Look-up Table through $D_0-D_7$ . # Bit Map Interface Section # PIX<sub>0</sub> - PIX<sub>7</sub> # Color Pixel Data addresses (TTL compatible inputs) These 8 inputs select which of the 256 entries in the Color Look-Up Table is to be used to provide pixel color information. These inputs run at the pixel rate of the system and are latched on the rising edge of CLK. PIXo is the least significant bit. #### **MPU Interface Section** #### $D_0 - D_7$ # Data and address bus (TTL compatible bi-directional) These 8 pins are used by the host microprocessor to write to ( with $\overline{WR}$ low) and read from ( with $\overline{RD}$ low) the internal registers (Pixel Mask Register, Pixel Address Register, and Color Data Register). Do is the least significant bit. During write cycles, the rising edge of $\overline{WR}$ latches data from the $D_0 - D_7$ inputs into the register selected by the $RS_0 - RS_1$ inputs. During read cycles, $\overline{RD}$ drives the $D_0 - D_7$ lines from the register selected by $RS_0 - RS_1$ . The end of a read cycle is determined by the rising edge of $\overline{DR}$ When both $\overline{WR}$ and $\overline{RD}$ are a logical one, the Do – D7 pins go into three-state. #### WD # Write Control Input (TTL compatible input) $\overline{WR}$ is the control signal used for writing data into internal registers. $\overline{WR}$ must be a logical zero to write data to the internal registers. During Write operations, RS<sub>0</sub> – RS<sub>1</sub> are latched on the falling edge of $\overline{WR}$ and D<sub>0</sub> – D<sub>7</sub> are latched on the rising edge of $\overline{WR}$ . When active, informa- tion on the external data bus is available to the $D_0$ – $D_7$ inputs. # RD ### Read Control Input (TTL compatible input) $\overline{RD}$ must be a logical zero to read data from the internal registers. During Read operations, RS<sub>0</sub> - RS<sub>1</sub> are latched on the falling edge of $\overline{RD}$ . When active, information on the internal data bus is available to the D<sub>0</sub> - D<sub>7</sub> pins. # RS<sub>0</sub> - RS<sub>1</sub> #### Register Select Inputs (TTL compatible inputs) $RS_0-RS_1$ allow the MPU to select any of the internal registers. These inputs determine the type of read or write operation being performed. See Table 1. # Analog Output Section #### R # Red video output (Analog output) Analog output of the red DAC. This output is capable of driving an RS-170A compatible doubly-terminated $75\Omega$ cable. #### G ## Green video output (Analog output) Analog output of the green DAC. This output is capable of driving an RS-170A compatible doubly-terminated $75\Omega$ cable. #### В ## Blue video output (Analog output) Analog output of the blue DAC. This output is capable of driving an RS-170A compatible doubly-terminated $75\Omega$ cable. #### las #### Current reference (Analog input). IREF is the reference current input. Through this pin the user provides the reference current for the DAC which, in turn, control the full-scale output currents. IREF = $$\frac{1}{2.1} * \frac{V_{\text{white}}}{R_{\text{load}} (= 37.5\Omega)}$$ #### **Power Supply Section** ### Vcc +5 volt supply. #### DVcc +5 volt digital power supply. #### **AVcc** +5 volt analog power supply. #### GND Ground 3-98 Am81C176 #### **FUNCTIONAL DESCRIPTION** The Am81C176 CMOS color palette integrates all major functions required in the video section of a graphics system and supports pixel rates sufficient to drive monitors with resolutions up to 1024 x 768. A programmable 256 x 18 Color Look-Up Table (LUT) maps pixel data from a bit-map memory into physical color, and three 6-bit Digital-to-Analog-Converters (DACs) convert the outputs of the Color Look-Up-Table (LUT) into RS170 compatible RGB analog format. Up to 8 bits per pixel are supported for a maximum of 256 simultaneous colors out of 256K available color combinations. #### **MPU** Interface The Am81C176 is designed to support a standard MPU bus interface with direct access to 256 Color Look-Up Table (LUT) locations and two control registers. The MPU interface is completely asynchronous with respect to pixel clock. However, data transfers between the LUT and Red Register, Green Register, and Blue Register (see block diagram) are internally synchronized to pixel clock. Double sampling techniques have been utilized in order to minimize metastability problems occurring when synchronizing an asynchronous event (such as RD or WR) with a free running clock (such as CLK). The Read and Write accesses to the LUT take one and two pixel clock cycles, respectively. The nature of the MPU access is determined by the Register Select (RS<sub>1</sub>, RS<sub>0</sub>) inputs. RS<sub>1</sub>and RS<sub>0</sub> select among Address Register (LUT write), Address Register (LUT read), Color Data Register and Pixel Mask Register, as shown in Table 1. Table 1. RSo, RS, Decoding | RS, | RS, | Function | |-----|-----|------------------------------| | 0 | 0 | Address Register (LUT write) | | 0 | 1 | Color Data Register | | 1 | 0 | Pixel Mask Register | | 1 | 1 | Address Register (LUT read) | A typical *color data write cycle* is initiated by setting the 8-bit Address Register (LUT write) with the address of the LUT into which data is to be written. Next the MPU performs three write cycles to the Color Data Register: one for red, one for green, one for blue intensity. At the end of the blue cycle the data is concatenated into an 18-bit word and written to the LUT location pointed to by the Address Register. The Address Register is then auto-incremented to point to the next location in LUT. This process may be repeated again as required. If the user needs to access consecutive LUT locations, the Address Register needs to be written to only at the beginning of the sequence. See Table 2. A typical *color data read cycle* is initiated by setting the 8-bit Address Register (LUT read) with the address of the LUT to be read. At this point, 18 bits of color data are transferred from the LUT to the Red, Green and Blue portion of the Color Data Register (see block diagram) and the Address Register is auto-incremented to point to the next location in LUT. Next the MPU performs three read cycles to the Color Data Register: one for red, one for green, one for blue intensity. At the end of the blue cycle a new set of 18 bits is tranferred to the Red, Green and Blue portions of the Color Data Register, and the Address Register is again auto-incremented. This process may be repeated as required. If the user needs to access consecutive LUT locations the Address Register needs to be written to only at the beginning of the sequence. See table 2. The 6-bit color data occupy the six least significant positions in the data bus. Bits $D_0$ and $D_7$ are ignored during write cycles and are set to 0 during read cycles. Bit $D_0$ is the least significant bit. The Am81C176 uses one 8-bit Address Register to address the LUT as shown in Table 3. The Address Register resets to 0 after a blue read/write cycle to the LUT address 255. A user transparent modulo-3 counter (ARb, ARa) keeps track of the red, green and blue cycles and auto-increments at the end of each read/write access to the LUT. This counter is reset to zero after a write access to the Address Register, and is unchanged following a read access to the Address Register. Thus a write to the Address Register will abort any unfinished read or write sequence. The Am81C176 uses one 8-bit *Pixel Mask Register* to modify the address of the LUT as provided by $PlX_0-PlX_7$ . The eight bits of this register are ANDed with $PlX_0-PlX_7$ , and the result used as the address to the LUT . This mechanism provides a quick way to alter the appearance of one or more colors on the display unit with just one MPU access, without the need for changing the bit-map memory or the LUT contents. The CPU addresses are not affected by this register. #### **Display Memory Interface** Pixel data $PIX_0 - PIX_7$ are latched on the rising edge of CLK and are used as address to the 256 locations of the LUT. The total pipeline delay from $PIX_0 - PIX_7$ and $\overline{BLANK}$ inputs, to R, G, B outputs is four clock cycles. # Video Generation During each clock cycle, a 18-bit word from the LUT is presented to three DACs: 6 bits for red, 6 for green and 6 for blue. The three DACs convert the digital color memory output into RGB RS-170A analog format. The BLANK input is latched on the rising edge of CLK. It is routed to the three DACs after a delay of four clock periods, identical to the delay incurred by the video stream. BLANK, when active, forces a zero to the input to the DACs, overriding the current LUT output. Am81C176 3-99 The three analog outputs of the Am81C176 are each capable of driving a doubly terminated 75 $\Omega$ coaxial cable. Table 2. Read/Write Access to the Am81C176 | RD | WR | RS, | RS. | AR, | AR. | | Function | |----|----|-----|-----|-----|-----|------------------------------------------------------------------|------------------------------------------------------------------------------------------| | 1 | 0 | 0 | 0 | х | х | Write Address Register (LUT Write) | AR(7:0)←D(7:0); ARb:ARa←00. | | 1 | 0 | 0 | 1 | 0 | 0 | Write Color Data Register(Red) | RREG(5:0)←D(5:0); ARb:ARa←01. | | 1 | o | 0 | 1 | 0 | 1 | Write Color Data Register(Green) | GREG(5:0)←D(5:0); ARb:ARa←10; | | 1 | 0 | 0 | 1 | 1 | 0 | WriteColor Data Register(Blue) Write Color Look-Up-Table | BREG(5:0)←D(5:0); ARb:ARa←00;<br>R(5:0)←RREG; G(5:0)←GREG;<br>B(5:0)←BREG; INC. AR(7:0). | | 1 | 0 | 1 | 1 | x | X | Write Address Register<br>(LUT Read)<br>Read Color Look-Up Table | AR(7:0)←D(7:0); ARb:ARa←00;<br>RREG←R(5:0); GREG←G(5:0); | | 0 | 1 | 0 | 1 | 0 | 0 | Read Color Data Register (Red) | BREG←B(5:0); INC. AR(7:0).<br>D(5:0)←RREG(5:0); D(7:6)←0;<br>ARb:ARa←01. | | 0 | 1 | 0 | 1 | 0 | 1 | Read Color Data Register (Green) | D(5:0)←GREG(5:0); D(7:6)←0;<br>ARb:ARa←10. | | 0 | 1 | 0 | 1 | 1 | 0 | Read Color Data Register (Blue) | D(5:0)←BREG(5:0); D(7:6)←0;<br>ARb:ARa←00. | | 0 | 1 | 0 | 0 | X | X | Read Address Register | D(7:0) ← AR(7:0). | | 1 | 0 | 1 | 0 | Х | X | Write Pixel Mask Register | PMREG(7:0)←D(7:0). | | 0 | 1 | 1 | 0 | х | x | Read Pixel Mask Register | D(7:0)←PMREG(7:0). | Note: Refer to timing diagrams for edge information on RD and WR. #### **ABSOLUTE MAXIMUM RATINGS OPERATING RANGES** Storage Temperature -65 to +150°C Commercial (C) Devices Ambient Temperature 0 to +70°C Ambient Temperature (TA) **Under Bias** -55 to +125°C Supply Voltage (Vcc) Junction Temperature +175℃ for 80 MHz devices +4.75 to +5.25 V Supply Voltage to Ground for 35, 50, 66 MHz device +4.50 to +5.50 V -0.5 to 7.0 V **Potential Continuous** IREF Current -7 to -9 mA DC Voltage Applied to Outputs **Output Load** 37.5Ω for HIGH Output State -0.5 to V∞ +0.5 V Operating ranges define those limits between which the func-DC Input Voltage -0.5 to Vcc +0.5 V tionality of the device is guaranteed. Stresses above those listed under "Absolute Maximum Ratings" may cause device failure. Functionality at or above these limits is not implied. Exposure of the device to absolute maximum rating conditions for extended periods may affect device reliability. # DC CHARACTERISTICS (over operating range) | Parameter<br>Symbol | Parameter<br>Description | Test Conditions | Min. | Тур. | Max. | Unit | |---------------------|-----------------------------|----------------------------------|-----------------|-----------|----------------------|--------| | Digital Inp | outs | | | | | | | VIH | Input High Voltage | | 2.0 | | V <sub>CC</sub> +0.5 | ٧ | | Val | Input Low Voltage | | <b>▲GND-0.5</b> | | 8.0 | V | | l <sub>iH</sub> | Input High Current | Vin= Vcc | 4 | | 1 | μΑ | | İŁ | Input Low Current | V <sub>in</sub> = GND | | | -1 | μА | | CIN | Input Capacitance | f=1 MHz, V <sub>in</sub> = 2.4 V | C | | 7 | pF | | Digital Ou | itputs | 7.0 | 5 | | | | | Vон | Output High Voltage | lon = -5 mA | 2.4 | | | V | | Val | Output Low Voltage | lox = +5 =0 | | | .4 | V | | loz | Three-State Current | GND <= 5 Cc | | | 50 | μА | | Cout | Output Capacitance | 10. | | | 7 | pF | | Analog O | utputs | | | | | | | | Resolution (each DAC) | | 6 | 6 | 6 | Bits | | INL | Integral Linearity Error | | | | ±1/2 | LSB | | DNL | Differential Linearity Engl | <b>N</b> ' | | | ±1/2 | LSB | | | Full Scale Error | | | | ±5 | %Gray | | | Monotonicity | | G | Suarantee | d | | | | Coding | Binary | | | | Binary | | | Output Voltage | | | | 1.5 | V | | | Output Current | | | | 21 | mA | | | DAC-to-DAC Matching | | | | 2 | % | | | Glitch Energy | | | 120 | | pV-sec | Am81C176 3-101 # **SWITCHING CHARACTERISTICS** | Parameter<br>Number | Parameter<br>Description | Min/Typ<br>Max | | | | | Unit | |---------------------|-----------------------------------------------|----------------|----------|--------------|-------------|---------|--------| | | Clock Rate | | 80 | 66 | 50 | 35 | MHz | | 1 | RS <sub>0</sub> - RS <sub>1</sub> Setup Time | Min | 10 | 10 | 10 | 15 | ns | | 2 | RS <sub>0</sub> - RS <sub>1</sub> Hold Time | Min | 10 | 10 | 10 | 15 | ns | | 3 | RD Asserted to Data Bus Driven | Min | 5 | 5 | 5 | 5 | ns | | 4 | RD Asserted to Data Valid | Max | 40 | 40 | 40 | 40 | ns | | 5 | RD Negated to Data Bus 3-stated | Max | 20 | 20 | 20 | 20 | ns | | 6 | Output Hold Time | Min | 5 | 5 | 5 | 5 | ns | | 7 | RD Pulse Width Low | Min | 50 | 50 | 50 | 50 | ns | | 8 | WR Pulse Width Low | Min | 50 | 50 | <b>∡</b> 50 | 50 | ns | | 9 | Write Data Setup Time | Min | 10 | 10 🚜 | 10 | 15 | ns | | 10 | Write Data Hold Time | Min | 10 | 10 | | 15 | ns | | 11 | Clock Cycle Time | Min | 12.5 | 15. | 20 | 28 | ns | | 12 | Clock Pulse Width High Time | Min | 4 | W. A | 6 | 7 | ns | | 13 | Clock Pulse Width Low Time | Min | 4 | | <b>•</b> 6 | 9 | ns | | 14 | Pixel Setup Time | Min | 3 | 7.7 | 3 | 4 | ns | | 15 | Pixel Hold Time | Min | .4.7 | <b>7.3</b> . | 3 | 4 | ns | | 16 | Analog Output Delay | Max | est. | 30 | 30 | 30 | ns | | 17 | Analog Output RiseTime<br>(Note 1) | Max | M. | <b>*</b> 6 | 8 | 8 | ns | | 18 | Analog Output Settling Time (Note 1) | Mex | 73 | 15.3 | 20 | 28 | ns | | 19 | Read after write address register (read mode) | An . | 5* tcyc | 5* toyo | 5* toyo | 5* toyo | ns | | 20 | Successive read interval | lin | 4 * tcyc | 4* toyo | 4* tcyc | 4* tcyc | ns | | 21 | Read after color read | Min | 5* tcyc | 5* toyo | 5* toyo | 5* tcyc | ns | | 22 | Write after color read | Min | 5* tcyc | 5* toyc | 5* toyo | 5* tcyc | ns | | 23 | Successive write interval | Min | 4* tcyc | 4* tcyc | 4* toyo | 4* toyo | ns | | 24 | Read after color write | Min | 4* toyo | 4* tcyc | 4* toyo | 4* tcyc | ns | | 25 | Write after color write | Min | 4* tcvc | 4* toyo | 4 * tcyc | 4* tcyc | ns | | 26 | Read followed by write interval | Min | 4* tcyc | 4* tcyc | 4* toyc | 4* tcyc | ns | | 27 | Write followed by read interval | Min | 4* toyo | 4* tcyc | 4* tcyc | 4* toyo | ns | | | Analog Output Skew | Max | 2 | 2 | 2 | 2 | ns | | | Pipeline Delay | Тур | 4 | 4 | 4 | 4 | clocks | | | V <sub>CC</sub> Supply Current (Note 3) | Тур | 150 | 150 | 150 | 150 | mA | | | V <sub>CC</sub> Supply Current (Note 3) | Max | 180 | 180 | 180 | 180 | mA | # Notes: - 1. Clock and data feedthrough are not included - 2 Load = $37.5\Omega + 30 \text{ pF}$ with $I_{REF} = -8.88 \text{ mA}$ - Measured at maximum f<sub>CLK</sub>; l<sub>CC</sub>(Max.): V<sub>CC</sub> = 5.25 V, T<sub>A</sub> = 0°C l<sub>CC</sub>(Typ.): V<sub>CC</sub> = 5.0 V, T<sub>A</sub> = + 25°C #### **Test Conditions:** TTL Input Level: 0 to 3 V with $t_R$ , $t_F$ (10-90%) $\leq$ 3 ns Analog Output Load $\leq$ 10 pF; $D_0$ – $D_7$ Output Load $\leq$ 50 pF 3-102 Am81C176 # Y # SWITCHING WAVEFORMS Key To Switching Waveforms KS000010 Am81C176 3-103 11912-005A # **MPU Read Cycle** 11912-006A MPU Write Cycle Am81C176 3-104 # \_\_\_\_ # **SWITCHING WAVEFORMS (continued)** Note 1: Output delay measured from the 50% point of the rising edge of CLK to the 50 % point of the full scale transition. Note 2: Settling time measured from the 50% point of the full scale transition to the output remaining within ± 1 LSB. Note 3: Output rise/fall time measured between the 10% and 90% points of full scale transition. 11912-007A ### Video Input /Output 11912-008A Color Value Read Followed by Any Read 11912-009A # Color Value Read Followed by Any Write 11912-010A Color Value Write Followed by Any Read 3-106 Am81C176 11912-011A # Color Value Write Followed by Any Write 11912-012A Read Color Value then Read the Address Register 11912-013A # Write and then Read Back the Address Register 11912-014A Write to Mask Register Followed by Read or Write 3-108 Am81C176 Read from Mask or Address Register Followed by Read or Write # SWITCHING TEST WAVEFORM Notes: 1. Diagram shown for HIGH data only. Output transition may be opposite sense. 2. Cross-hatched area is don't care condition. 11912-016A # APPENDIX A: APPLICATION NOTE FOR THE Am81C176 The design of a system using the Am81C176 should be based on the guidelines used for designing high precision mixed analog and digital circuits. Some of these rules are outlined here. Users may, of course, choose to design circuits considerably different from that shown here. Separate power planes should be used for the analog and digital power.pins to reduce the noise on the analog output due to the switching at the digital inputs. A high frequency capacitor of around 0.1 µf should be placed close to the package between Vcc and GND. A large tantalum capacitor of about 22 µF should also be placed in parallel to the 0.1 µF capacitor. This same arrangement should be used on the DIP package as well. An inductor used in series with the power supply acts as a low-pass filter and improves the Am81C176 supply even further. Care should be taken to see that the analog plane does not cross the digital plane. The pixel data lines should be kept as far from the digital lines accessible by the MPU interface. Use of a current mirror such as the one shown in Figure A1 is recommended to ensure a constant current source for the DACs. The current sources may need to be temperature compensated externally using a diode bias. It may be necessary to add coupling capacitors (47 $\mu$ F in parallel with 0.1 $\mu$ F) between lase and Vcc to absorb power supply variations not absorbed by the current source. The two capacitors help track the variations in power supply at the low and the high frequency end. The connection between the DACs and the monitor acts as a transmission lie The two ends of the line need to be terminated to provide proper impedance matching and thereby avoid any reflections that might result otherwise. Also, analog output protection is provided by the diode as shown in Figure A2. The diode basically acts to prevent excessive negative or positive voltage swings which could result from electrostatic discharges and things of that nature. 11912-017A Figure A1. 11912-018A 3-110 Am81C176 Figure A3. Application Example: VGA system using a VGA Controller and an Am81C176