# **Triple 10-Bit Video RAM-DAC** ### **ADV7151** #### **FEATURES** 220 MHz, 10-Bit (30-Bit Gamma Corrected) Pseudo Color (Indexed-Color) Triple 10-Bit "Gamma Correcting" D/A Converters Triple 256 $\times$ 10 (256 $\times$ 30) Color Palette RAM (256 Colors out of 1 Billion) On-Chip Clock Control Circuit **Palette Priority Select Registers** RS-343A/RS-170 Compatible Analog Outputs FTL Compatible Digital Inputs Standard MP/U I/O Interface 10-Bit Paralle/Structure 8+2 Byte/Structure Multiplexed Pixel Input Ports; 1(1, 2:) +5 VCMOS Monolithic Construction 100-Lead Plastic Quad Flatpack (QFP) Thermally Enhanced to Adhieve $\theta_{JC}$ #### MODES OF OPERATION 8-Bit Pseudo Color - @ 220 MHz - @ 170 MHz - @ 135 MHz - @ 110 MHz - @ 85 MHz #### **APPLICATIONS High Resolution Graphics** #### GENERAL DESCRIPTION The ADV7151 (ADV★) is a complete analog output, Video RAM-DAC on a single CMOS monolithic chip. The part is specifically designed for use in high performance, color graphics workstations. The ADV7151 integrates a number of graphic functions onto one device allowing 8-bit Pseudo-Color (Indexed-Color) operation at the maximum screen update rate of 220 MHz. The device consists of three, high speed, 10-bit, video D/A converters (RGB), three 256 $\times$ 10 (one 256 $\times$ 30) color look-up tables, palette priority selects, a pixel input data multiplexer/ serializer and a clock generator/divider circuit. The ADV7151 is capable of 1:1, 2:1 and 4:1 multiplexing. The on-board palette priority select inputs enable multiple palette devices to be connefted together for use in multipalette and window applications. The part is controlled and programmed through the microprocessor (MPU) port. The part also contains a number of on-board lest registers, associated with self diagnostic testing of the device. ADV is a regi ered trademark of Analog Dev ces. Inc phtimied on page 12) #### FUNCTIONAL BLOCK DIAGRAM OfC/ Information furnished by Analog Devices is believed to be accurate and reliable. However, no responsibility is assumed by Analog Devices for its use, nor for any infringements of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of Analog Devices. One Technology Way, P.O. Box 9106, Norwood, MA 02062-9106, U.S.A. Tel: 617/329-4700 Fax: 617/326-8703 | Parameter | All Versions | Unit | Test Conditions/Comments | |--------------------------------------------|---------------------------------------------------|----------------------------------------------|-------------------------------------------------------| | STATIC PERFORMANCE | | | | | Resolution (Each DAC) | 10 | Bits | | | Accuracy (Each DAC) | | | | | Integral Nonlinearity | ±1 | LSB max | | | Differential Nonlinearity | $\pm 1$ | LSB max | Guaranteed Monotonic | | Gray Scale Error | ±5 | % Gray Scale max | | | Coding | | Binary | | | DIGITAL INPUTS (Excluding CLOCK, CLOCK) | | | | | Input High Voltage, V <sub>INH</sub> | 2 | V min | | | Input Low Voltage, V <sub>INL</sub> | 0.8 | V max | | | Input Current, I <sub>IN</sub> | ±10 | μA max | $V_{IN} = 0.4 \text{ V or } 2.4 \text{ V}$ | | Input Capacitance, C <sub>IN</sub> | 10 | pF typ | VIN 0.4 V 01 2.4 V | | | 10 | pr typ | | | CLOCK INPUTS (CLOCK, CLOCK) | | V : | | | Input High Voltage, V <sub>INH</sub> | $V_{AA} - 1.0$ | V min | | | Ipput Low Voltage, V <sub>INL</sub> | $V_{AA} - 1.6$ | V max | *** | | Input Current, N | ±10 | μA max | $V_{IN} = 0.4 \text{ V or } 2.4 \text{ V}$ | | Input Capacitance, C <sub>IN</sub> | 10 | pF typ | | | DIGITAL OUTPUTS / / | | | | | Output High Vollage, VOH | 2.4 | V min | $I_{SOURCE} = 400 \mu A$ | | Output Low Voltage, Van | 0.4 | V max | $I_{SINK} = 3.2 \text{ mA}$ | | Floating-State Leakage Current | $\smile_{20}$ | μA max | | | Floating-State Output Capacitance | 20/ | pF t/p | | | NALOG OUTPUTS | + | <b>\ </b> | | | Gray Scale Current Range | 1 / 5 / | mak mih | | | Gray beare current runge | $ \begin{array}{c c} & 15 \\ 2 & 7 \end{array} $ | mA max | | | Output Current | | / "T" "T" / | | | White Level Relative to Blank | 17.69 | phA phin | Typically 19.05 mA | | with Level Relative to Blank | 20.40 | mA max | Typically 19.09 flin | | White Level Relative to Black | 16.74 | mA min | Typically 17.62/mA/ | | White Level Relative to Black | 18.50 | mA max | Typicany 17.02 min | | Black Level Relative to Blank | 0.95 | mA min | Typically 1.44 mA | | Black Level Relative to Blank | 1.90 | mA max | Typiquity 1.44 min | | Blank Level on IOR, IOB | 0 | μA min | Typically 5 µA | | Blank Bever on Tork, 10B | 50 | μA max | 1 / / / / / / / / / / / / / / / / / / / | | Blank Level on IOG | 6.29 | mA min | Typically 7.62 mA | | Blank Ecter on Too | 8.96 | mA max | Typicany 7.02 mm | | Sync Level on IOG | 0 | μA min | Typically 5 μA | | Sylic Devel on 10 d | 50 | μA max | Typically 5 pill | | LSB Size | 17.22 | μA typ | | | DAC-to-DAC Matching | 2 | % max | Typically 1% | | Output Compliance, V <sub>OC</sub> | 0 | V min | Typically 170 | | Output Comphance, Voc | +1.4 | V max | | | Output Impedance, R <sub>OUT</sub> | 100 | kΩ typ | | | Output Impedance, K <sub>OUT</sub> | 30 | pF max | $I_{OUT} = 0 \text{ mA}$ | | | 30 | pr max | I <sub>OUT</sub> — 0 IIII | | OLTAGE REFERENCE | 1.14/2.24 | X7 : /X7 | 1 225 X C C (C 1 D C | | Voltage Reference Range, V <sub>REF</sub> | 1.14/1.26 | V min/V max | $V_{REF} = 1.235 \text{ V for Specified Performance}$ | | Input Current, I <sub>VREF</sub> | +5 | μA typ | | | OWER REQUIREMENTS | | | | | $V_{AA}$ | 5 | V nom | | | $I_{AA}^{3}$ | 400 | mA max | 220 MHz Parts | | $I_{AA}^{\alpha \dot{\alpha}}$ | 370 | mA max | 170 MHz Parts | | $ ilde{ ext{I}}_{ ext{AA}}$ | 350 | mA max | 135 MHz Parts | | $I_{AA}$ | 330 | mA max | 110 MHz Parts | | $I_{AA}$ | 315 | mA max | 85 MHz Parts | | Power Supply Rejection Ratio | 0.5 | %/% max | Typically $0.12\%$ /%: COMP = $0.1 \mu$ F | | DYNAMIC PERFORMANCE | | | · · · · · · · · · · · · · · · · · · · | | Clock and Data Feedthrough <sup>4, 5</sup> | -30 | dB typ | | | Glitch Impulse | 50 | pV secs typ | | | DAC-to-DAC Crosstalk <sup>6</sup> | -23 | dB typ | | | | | | | $<sup>^{2}</sup>$ Temperature range ( $T_{MIN}$ to $T_{MAX}$ ): 0°C to +70°C; $T_{J}$ (Silicon Junction Temperature) $\leq 100$ °C. $^{3}$ Pixel Port is continuously clocked with data corresponding to a linear ramp. $T_{J} = 100$ °C. <sup>\*</sup>Clock and data feedthrough is a function of the amount of overshoot and undershoot on the digital inputs. Glitch impulse includes clock and data feedthrough. <sup>&</sup>lt;sup>5</sup>TTL input values are 0 to 3 volts, with input rise/fall times ≤3 ns, measured the 10% and 90% points. Timing reference points at 50% for inputs and outputs. DAC-to-DAC crosstalk is measured by holding one DAC high while the other two are making low-to-high and high-to-low transitions. Specifications subject to change without notice. TIMING CHARACTERISTICS $(V_{AA}{}^2=+5~V;~V_{REF}=+1.235~V;~R_{SET}=280~\Omega.~IOR,~IOG,~IOB~(R_L=37.5~\Omega,~C_L=10~pF);~\overline{IOR},~\overline{IOB}=GND.~All~specifications~T_{MIN}~to~T_{MAX}{}^3~unless~otherwise~noted.)$ #### CLOCK CONTROL AND PIXEL PORT<sup>4</sup> | Parameter | 220 MHz<br>Version | 170 MHz<br>Version | 135 MHz<br>Version | 110 MHz<br>Version | 85 MHz<br>Version | Units | Conditions/Comments | |--------------------------------|----------------------|--------------------|-----------------------------------|---------------------------------------------------|--------------------------|------------|---------------------------------------------------| | $f_{CLOCK}$ | 220 | 170 | 135 | 110 | 85 | MHz max | Pixel CLOCK Rate | | $t_1$ | 4.55 | 5.88 | 7.4 | 9.1 | 11.77 | ns min | Pixel CLOCK Cycle Time | | $t_2$ | 2 | 2.5 | 3.2 | 4 | 4 | ns min | Pixel CLOCK High Time | | t <sub>3</sub> | 2 | 2.5 | 3 | 4 | 4 | ns min | Pixel CLOCK Low Time | | $f_{LOADIN}$ | 10 | 10 | 10 | 10 | 10 | ns max | Pixel CLOCK to LOADOUT Delay LOADIN Clocking Rate | | 1:1 Multiplexing | 110 | 110 | 110 | 110 | 85 | MHz max | | | 2:1 Multiplexing | 110 | 85 | 67.5 | 55 | 42.5 | MHz max | | | 4:1 Multiplexing | 55 | 42.5 | 42.5 | 33.75 | 27.5 | 21.25 | MHz max | | t. | | | | | | | LOADIN Cycle Time | | 1:1 Multiplexing | 9:1~ | 9.1 | 9.1 | 9.1 | 11.76 | ns min | , | | | 19.I | 11.76 | 14.8 | 18.18 | 23.53 | ns min | | | | 18.18) | 23.53 | 29.63 | 36.36 | 47.1 | ns min | | | $(t_6)$ | | | | | | | LOADIN High Time | | 1:1 Multipleking | * < | 4 \ 1 | 4) | 4 | 4 | ns min | | | 2:1 Multiplexing | 4 ) ) | 5 | $\begin{bmatrix} 6 \end{bmatrix}$ | 8 \ | 9/ | ns min | | | 4:1 Multiplexing | ا ( سھ | <del>-9</del> 1 \ | 12/ | 15 | <b> 1</b> /8 | ns min | | | $t_7$ | $\smile$ $\setminus$ | ( ) | 1) / / | ) ) | / / | | LOADIN Low Time | | 1:1 Multiplexing | 4 | $\bigvee_{4}$ | <i> </i> | 4 / / | /4 / | ns m/lin — | | | 2:1 Multiplexing | 4 | 5 | 6 \ | 8// | 9 / | ns phin/ | | | 4:1 Multiplexing | 8 | 9 | 12 | 15 / 1 | 1\$ | ns min — | 7 ~ 7 ~ | | t <sub>8</sub> | 0 | 0 | 0 | <del> 0 </del> | 04 | ns/min | Pixel Data Setup Time | | t <sub>9</sub> | 5 | 5 | 5 | 5 4 | 5 | n¢ mi/n | Pixel Data/Hold Time | | t <sub>10</sub> | 0 | 0 | 0 | 0 | $\mid 0 \longrightarrow$ | n/s min | LOADOUT to LOAD IN Delay | | τ-t <sub>11</sub> <sup>5</sup> | τ-5 | τ-5 | τ-5 | τ-5 | τ-4 | ns max | LOADOUT to LOADIN Delay | | t <sub>PD</sub> <sup>6</sup> | | | | | | | Pipeline Delay / / | | 1:1 Multiplexing | 5 | 5 | 5 | 5 | 5 | CLOCKs | $(1 \times CLOCK = t_1)$ | | 2:1 Multiplexing | 6 | 6 | 6 | 6 | 6 | CLOCKs | | | 4:1 Multiplexing | 8 | 8 | 8 | 8 | 8 | CLOCKs | | | $t_{12}$ | 10 | 10 | 10 | 10 | 10 | ns max | Pixel CLOCK to PRGCKOUT Delay | | t <sub>13</sub> | 5 | 5 | 5 | 5 | 5 | ns max | SCKIN to SCKOUT Delay | | t <sub>14</sub> | 5 | 5 | 5 | 5 | 5 | ns min | BLANK to SCKIN Setup Time | | t <sub>15</sub> | 1 | 1 | 1 | 1 | 1 | ns min | BLANK to SCKIN Hold Time | #### ANALOG OUTPUTS7 | Parameter | 220 MHz<br>Version | 170 MHz<br>Version | 135 MHz<br>Version | 110 MHz<br>Version | 85 MHz<br>Version | Units | Conditions/Comments | |-----------------|--------------------|--------------------|--------------------|--------------------|-------------------|--------|------------------------------------| | t <sub>16</sub> | 15 | 15 | 15 | 15 | 15 | ns typ | Analog Output Delay | | t <sub>17</sub> | 1 | 1 | 1 | 1 | 1 | ns typ | Analog Output Rise/Fall Time | | t <sub>18</sub> | 15 | 15 | 15 | 15 | 15 | ns typ | Analog Output Transition Time | | t <sub>SK</sub> | 2 | 2 | 2 | 2 | 2 | ns max | Analog Output Skew (IOR, IOG, IOB) | | <b></b> | 0 | 0 | 0 | 0 | 0 | ns typ | | #### MPU PORT<sup>8, 9</sup> | Parameter | 220 MHz<br>Version | 170 MHz<br>Version | 135 MHz<br>Version | 110 MHz<br>Version | 85 MHz<br>Version | Units | Conditions/Comments | |------------------------------|--------------------|--------------------|--------------------|--------------------|-------------------|--------|---------------------------------------------------------| | t <sub>19</sub> | 3 | 3 | 3 | 3 | 3 | ns min | $R/\overline{W}$ , C0, C1 to $\overline{CE}$ Setup Time | | t <sub>20</sub> | 10 | 10 | 10 | 10 | 10 | ns min | $R/\overline{W}$ , C0, C1 to $\overline{CE}$ Hold Time | | t <sub>21</sub> | 45 | 45 | 45 | 45 | 45 | ns min | CE Low Time | | t <sub>22</sub> | 25 | 25 | 25 | 25 | 25 | ns min | CE High Time | | t <sub>23</sub> <sup>8</sup> | 5 | 5 | 5 | 5 | 5 | ns min | CE Asserted to Databus Driven | | t <sub>24</sub> 9 | 45 | 45 | 45 | 45 | 45 | ns max | CE Asserted to Data Valid | | t <sub>25</sub> 9 | 20 | 20 | 20 | 20 | 20 | ns max | CE Disabled to Databus Three-Stated | | 23 | 5 | 5 | 5 | 5 | 5 | ns min | | | t <sub>26</sub> | 20 | 20 | 20 | 20 | 20 | ns min | Write Data (D0-D9) Setup Time | | t <sub>27</sub> | 5 | 5 | 5 | 5 | 5 | ns min | Write Data (D0-D9) Hold Time | #### NOTES $^{1}$ TTL input values are 0 to 3 volts, with input rise/fall times ≤ 3 ns, measured between the 10% and 90% points. ECL inputs (CLOCK, $\overline{\text{CLOCK}}$ ) are $V_{AA}$ –0.8 V to $V_{AA}$ –1.8 V, with input rise/fall times ≤ 2 ns, measured between the 10% and 90% points. Timing reference points at 50% for inputs and outputs. Analog output load ≤ 10 pF. Databus (D0–D9) loaded as shown in Figure 1. Digital output load for LOADOUT, PRGCKOUT and SCKOUT ≤ 30 pF. $^2\pm5\%$ for all versions. $^3 Temperature \ range \ (T_{MIN} \ to \ T_{MAX}); \ 0^{\circ} C \ to \ +70^{\circ} C; \ T_J \ (Silicon \ Junction \ Temperature) \leq 100^{\circ} C.$ Pixel Port consists of the following inputs: Pixel Inputs: P0–P7 [A, B, C, D]; Palette Selects: PS0 [A, B, C, D] PS1 [A, B, C, D]; Pixel Controls: SYNC, BLANK; Clock Inputs: CLOCK, CLOCK, LOADIN, SCKIN; Clock Outputs: LOADOUT, PRGCKOUT, SCKOUT. $^{5}\tau$ is the LOADOUT Cycle Time and is a function of the Pixel CLOCK Rate and the Multiplexing Mode: 1:1 multiplexing; $\tau = \text{CLOCK} = t_1$ ns: 2:1 multiplexing; $\tau = \text{CLOCK} \times 2 = 2 \times t_1$ ns: 4:1 multiplexing; $\tau = \text{CLOCK} \times 4 = 4 \times t_1$ ns. <sup>6</sup>These fixed values for Pipeline Delay are valid under conditions where $t_{10}$ and $\tau$ - $t_{11}$ are met. If either $t_{10}$ or $\tau$ - $t_{11}$ are not met, the part will operate but the Pipeline Delay is increased by an additional 2 Clock Cycles for 2:1 Mode and is increased by an additional 4 Clock Cycles for 4:1 Mode, after calibration is performed. Output delay measured from the 50% point of the rising edge of CLOCK to the 50% point of full-scale transition. Output rise/fall time measured between the 10% and 90% points of full-scale transition. Transition time measured from the 50% point of full-scale transition to the output remaining within ±1 LSB. (Transition time does not include clock and data feedthrough.) \*123 and 124 are measured with the load circuit of Figure 1 and defined as the time required for an output to cross 0.4 V or 2.4 V. the is derived from the measured time taken by the data outputs to change by 0.5 V when loaded with the circuit of Figure 1. The measured number is then extrapolated back to remove the effects of charging the 100 pF capacitor. This means that the time, t<sub>25</sub>, quoted in the Timing Characteristics is the true value for the device and as such is independent of external databus loading capacitances. Figure 2. LOADOUT vs. Pixel Clock Input (CLOCK, CLOCK) -4- \*INCLUDES PIXEL DATA (P0-P7); PALETTE SELECT INPUTS (PS0-PS1); SYNC; BLANK Figure 3. LOADIN vs. Pixel Input Data Figure 4. Pixel Input to Analog Output Pipeline with Minimum LOADOUT to LOADIN Delay (4:1 Multiplex Mode) Figure 5. Pixel Input to Analog Output Pipeline with Maximum LOADOUT to LOADIN Delay (4:1 Multiplex Mode) Figure 7. Pixel Input to Analog Output Pipeline with Maximum LOADOUT to LOADIN Delay (2:1 Multiplex Mode) Figure 9. Video Data Shift Clock Input (SCKIN) and BLANK vs. Video Data Shift Clock Output (SCKOUT) Figure 10. Analog Output Response vs. CLOCK ECOMMENDED OPERATING CONDITIONS | 117551117575 | | שע איניי | 115/11/01/0 | 2 | | | | |-----------------------|-------------|-------------------|---------------|---------|---------|---------|-------| | Parameter | $\sim$ | S | mbol | Min | Тур | Max | Units | | Power Supply | $\smile$ ), | $\sqrt{v}$ | $\frac{1}{2}$ | 4.75 | 5.00 | 5.25 | Volts | | Ambient Operating Ten | perature | $Y \mid I \mid I$ | `^ | 101 / / | | +70 | °C | | Reference Voltage | | | REF | 1./14// | 1 /35 ~ | 7 ~1 26 | Vales | | Output Load | | | | | 27.5 | J + | Volts | | <u> </u> | | | | <i></i> | 3/.5 | | Ω | CAUTION . ESD (electrostatic discharge) sensitive device. The digital control inputs are diode protected; however, permanent damage may occur on unconnected devices subject to high energy electrostatic fields. Unused devices must be stored in conductive foam or shunts. The protective foam should be discharged to the destination socket before devices are inserted. #### ABSOLUTE MAXIMUM RATINGS\* #### NOTES \*Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those listed in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. Analog Output Short Circuit to any Power Supply or Common can be of an indefinite duration. #### ORDERING GUIDE<sup>1, 2, 3</sup> | Speed | | | | | | | | |--------------|--------------|--------------|--------------|-------------|--|--|--| | 220 MHz | 170 MHz | 135 MHz | 110 MHz | 85 MHz | | | | | ADV7151LS220 | ADV7151LS170 | ADV7151LS135 | ADV7151LS110 | ADV7151LS85 | | | | #### NOTES ADV7151 is packaged in a 100-pin plastic quad flatpack, QFP. <sup>&</sup>lt;sup>2</sup>All devices are specified for 0°C to +70°C operation. <sup>&</sup>lt;sup>3</sup>Contact sales office for latest information on package design. #### **ADV7151 PIN ASSIGNMENTS** 100-Lead QFP Configuration Pin Pin Pin No. Mnemonic No. Mnemonic No. Mnemonic **SYNCOUT** 1 $V_{AA}$ 41 81 $V_{AA} \\$ **SYNC** 2 42 **GND** 82 D6 PIN NO. 1 IDENTIFIER **BLANK** 83 3 43 NC D7NC 84 D84 44 **GND** 5 85 D9 NC 45 **GND** NC NC 86 **GND** 6 46 ADV7151 PQFP 7 47 NC 87 **GND** $P0_A$ **TOP VIEW** 8 48 $PS0_A$ 88 ĪOB (Not to Scale) $P0_{B}$ $P0_{C}$ 49 89 $\overline{IOR}$ $PS0_B$ P0 $PS0_{\rm C}$ **IOG** 50 90 $P_{A}$ 91 IOB 11 31 $\mathrm{PS0}_{\mathrm{D}}$ P 12 PS1 92 IOG PS/B $V_{\underline{A}\underline{A}}$ 13 ROW B PJ PS 15 NC **K**OR COMP ₽5<sub>A</sub> $P2_A$ 16 57 P5. 17 $P2_{\rm B}$ $V_{REF}$ 98 18 58 $P5_C$ $P2_{C}$ 19 59 $P5_{D}$ 99 $P2_{D}$ 20 NC 60 $P6_A$ 100 **GND** $P6_{\rm B}$ 21 NC 61 22 $P3_A$ 62 $P6_{C}$ 63 23 $P3_B$ $P6_{\rm D}$ 24 $P3_{C}$ 64 NC $P7_A$ 25 65 $P3_D$ 26 NC 66 $P7_{B}$ NC 67 $P7_{C}$ 27 $P4_A$ 28 68 $P7_{D}$ NC 29 $P4_B$ 69 30 $P4_{\rm C}$ 70 $\overline{CE}$ 31 71 $R/\overline{W}$ $P4_{D}$ **CLOCK** 32 72 C0 **CLOCK** 73 33 C1 74 34 LOADIN D0LOADOUT 75 D135 76 D2 36 $V_{AA}$ 37 $V_{AA}$ 77 **GND PRGCKOUT** 78 D338 39 **SCKIN** 79 D4 NC = NO CONNECT. **SCKOUT** 80 D5 40 #### PIN FUNCTION DESCRIPTION | Mnemonic | Function | |-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | $P0_A \dots P0_D - P7_A \dots P7_D$ | Pixel Port (TTL Compatible Inputs). There are 32 pixel select inputs on the ADV7151. Each bit is multiplexed [A-D] 4:1, 2:1 or 1:1. Pixel Data is latched into the device on a rising LOADIN signal rising edge. | | $PS0_A \dots PS0_D$ , $PS1_A \dots PS1_D$ | Palette Priority Selects (TTL Compatible Inputs). These pixel port select inputs determine whether or not the device's pixel data port is selected on a pixel by pixel basis. The palette selects allow switching between multiple palette devices. The device can be preprogrammed to completely shut off the DAC analog outputs. If the values of PS0 and PS1 match the values programmed into bits MR16 and MR17 of the Mode Register, then the device is selected. Each bit is multiplexed [A–D] 4:1, 2:1 or 1:1. PS0 and PS1 are latched into the device on a rising LOADIN signal rising edge. | | LOADIN | Pixel Data Load Input (TTL Compatible Input). This input latches the serialized pixel data, including PS0-PS1, BLANK and SYNC into the device. | | COADOUT | Pixel Data Load Output (TTL Compatible Output). This output control signal runs at a divided down frequency of the pixel CLOCK input. Its frequency is a function of the multiplex rate. It can be used to directly or indirectly drive LOADIN $f_{LOADOUT} = f_{CLOCK}/M$ where $M = 1$ for 1:1 Multiplex Mode) | | PRGCKOUT | (M = 2 for 2:) Multiplex Mode) (M = 4 for 4:) Multiplex Mode). Programmable Clock Output (TYL dompatible Output). This output control signal runs at a divided down frequency of the pixel/CLOCK input. Its frequency is user programmable and is determined by bits CR30 and CR31 of Command Register 3 | | | $f_{PRGCKOUT} = f_{CLOCK}$ | | SCKIN | where $N = 4$ , 8, 16 and 32.<br>Video Shift Clock Input (TTL Compatible Input). The signal on this input is internally gated synchronously with the $\overline{\text{BLANK}}$ signal. The resultant output, SCKOUT, is a video clocking signal that is stopped during video blanking periods. | | SCKOUT | Video Shift Clock Output (TTL Compatible Output). This output is a synchronously gated version of SCKIN and BLANK. SCKOUT, is a video clocking signal that is stopped during video blanking periods. | | CLOCK, CLOCK | Clock Inputs (ECL Compatible Inputs). These differential clock inputs are designed to be driven by ECL logic levels configured for single supply (+5 V) operation. The clock rate is normally the pixel clock rate of the system. | | BLANK | Composite Blank (TTL Compatible Input). This video control signal drives the analog outputs to the blanking level. | | SYNC | Composite-Sync Input (TTL Compatible Input). This video control signal drives the IOG analog output to the \$\overline{SYNC}\$ level. It is only asserted during the blanking period. CR22 in Command Register 2 must be set if \$\overline{SYNC}\$ is to be decoded onto the analog output, otherwise the \$\overline{SYNC}\$ input is ignored. | | SYNCOUT | Composite SYNC O/P (TTL Compatible Output). This video output is a delayed version of SYNC. The delay corresponds to the number of pipeline stages of the device. | | D0-D9 | Databus (TTL Compatible Input/Output Bus). Data, including color palette values and device control information is written to and read from the device over this 10-bit, bidirectional databus. 10-bit data or 8-bit data can be used. The databus can be configured for either 10-bit parallel data or byte data $(8+2)$ as well as standard 8-bit data. Any unused bits of the databus should be terminated through a resistor to either the digital power plane $(V_{CC})$ or GND. | | CE | Chip Enable (TTL Compatible Input). This input must be at Logic "0" when writing to or reading from the device over the databus (D0–D9). Internally, data is latched on the rising edge of $\overline{CE}$ . | | R/W | Read/Write Control (TTL Compatible Input). This input determines whether data is written to or read from the device's registers and color palette RAM. $R/\overline{W}$ and $\overline{CE}$ must be at Logic "0" to write data to the part. $R/\overline{W}$ must be at Logic "1" and $\overline{CE}$ at Logic "0" to read from the device. | -10- REV. A | Mnemonic | Function | |------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | C0, C1 | Command Controls (TTL Compatible Inputs). These inputs determine the type of read or writ operation being performed on the device over the databus (see Interface Truth Table). Data on these inputs is latched on the falling edge of $\overline{CE}$ . | | $\overline{IOR}$ ; $\overline{IOR}$ , $\overline{IOG}$ , $\overline{IOG}$ , $\overline{IOB}$ ; | Red, Green and Blue Current Outputs (High Impedance Current Sources). These RGB video outputs are specified to directly drive RS-343A and RS-170 video levels into doubly terminated 75 $\Omega$ loads. | | | $\overline{\text{IOR}}$ , $\overline{\text{IOG}}$ and $\overline{\text{IOB}}$ are the complementary outputs of IOR, IOG and IOB. These outputs can be tied to GND if it is not required to use differential outputs. | | $V_{REF}$ | Voltage Reference Input (Analog Input). An external 1.235 V voltage reference is required to drive this input. An AD589 (2-terminal voltage reference) or equivalent is recommended. (Note It is not recommended to use a resistor network to generate the voltage reference.) | | P <sub>SET</sub> | Output Full-Scale Adjust Control (Analog Input). A resistor connected between this pin and analog ground controls the absolute amplitude of the output video signal. The value of $R_{\rm SET}$ is derived from the full-scale output current on IOG according to the following equations: | | | $R_{SET}(\Omega) = C1 \times R_{REF}/IOG(mA); \ \overline{SYNC} \ on \ GREEN$ | | | $R_{SET}(\Omega) = C2 \times R_{REF}/IOG (mA); No \ \overline{SYNC} \ on \ GREEN.$ | | | Full-Scale output currents on IOR and IOB for a particular value of $R_{\rm SET}$ are given by: | | | $IOR(mA) = \oint 2 \times R_{REF}(V)/R_{SET}(\Omega)$ | | | \\ \text{und} \\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | | $IOB(mA) = C2 \times R_{REF} (V)/R_{IET}(\Omega)$ | | | where $CI = 6.050$ : PEDESTAL = 7.5 IRE | | | = 5,723: PEDESTAL = 0 IRE | | | and $C2 = 4,323$ : PEDESTAL = 7.5 IRE | | | = 3,996: PEDESTAL = 0 IRE. | | COMP | Compensation Pin. A 0.1 $\mu$ F capacitor should be connected between this pin and $V_{AA}$ . | | I <sub>PLL</sub> | Phase Lock Loop Output Current (High Impedance Current Source). This output is used to enable multiple ADV7151s along with ADV7150/ADV7152s to be synchronized together with subpixel resolution when using an external PLL. This output is triggered either from the fallin edge of SYNC or BLANK as determined by bit CR21 of Command Register 2. When activated it supplies a current corresponding to | | | $I_{PLL}$ (mA) = 1,728 × $R_{REF}$ (V)/ $R_{SET}$ ( $\Omega$ ). | | | When not using the I <sub>PLL</sub> function, this output pin should be tied to GND. | | $ m V_{AA}$ | Power Supply (+5 V $\pm$ 5%). The part contains multiple power supply pins, all should be connected together to one common +5 V filtered analog power supply. | | GND | Analog Ground. The part contains multiple ground pins, all should be connected together to the system's ground plane. | (Continued from page 1) Indexed-Color image rendition, at speeds of up to 220 MHz, is achieved through the use of the on-board data multiplexer/serializer. The pixel input port's flexibility allows for direct interface to most standard frame buffer memory configurations. The 30 bits of resolution, associated with the color look-up table and triple 10-bit DAC, realizes 8-bit Indexed-Color resolution, while also allowing for the on-board implementation of linearization algorithms, such as Gamma-Correction. This allows effective 10-bit Indexed-Color operation. The on-chip video clock controller circuit generates all the internal clocking and some additional external clocking signals. An external ECL oscillator source with differential outputs is all that is required to drive the CLOCK and $\overline{\text{CLOCK}}$ inputs of the ADV7151. The part can also be driven by an external clock generator chip circuit, such as the AD730. The ADV7151 is capable of generating RGB video output signals which are compatible with RS-343A and RS-170 video standards, without requiring external buffering. Test diagnostic circuitry has been included to complement the users system level debugging. The ADV7151 is fabricated in a +5 V CMOS process. Its monolithic CMOS construction ensures greater functionality with low power dissipation. The ADV7151 is packaged in a plastic 100-pin quad flatpack (QFP). Superior thermal dissipation is achieved by inclusion of a copper heatslug, within the standard package outline to which the die is attached. CIRCUIT DETAILS AND OVERVIEW Digital video or pixel data is latched into the ADV7151 over the devices Pixel Port. This data acts as a pointer to the on-board Color Palette RAM. The data at the RAM address pointed to is latched into the digital-to-analog converters (DACs) and output as an RGB analog video signal. For the purposes of clarity of description, the ADV7151 is broken down into three separate functional blocks. These are: - 1. Pixel port and clock control circuit - 2. MPU port, registers and color palette - 3. Digital-to-analog converters and video outputs Table I. Architectural and Packaging Differences of the ADV715x Series | Description | ADV7150* | ADV7151 | ADV7152* | |-------------------------------|----------|---------|----------| | 24-Bit "Gamma" True Color | • | | • | | 24-Bit "Standard" True Color | • | | • | | 8-Bit "Gamma" Pseudo Color | • | • | • | | 8-Bit "Standard" Pseudo Color | • | • | • | | 15-Bit True Color | • | | • | | 220 MHz-True Color | • | | • | | 220 MHz-Pseudo Color | • | • | • | | Triple 10-Bit DACs | • | • | • | | 4:1 Multiplexing | • | • | | | 2:1 Multiplexing | • | • | • | | 1:1 Multiplexing | • | • | • | | 160-Lead QFP | • | | | | 100-Lead QFP | | • | • | <sup>\*</sup>See the relevant data sheet for more information on these parts. Table I shows the architectural and packaging differences between the ADV7151 and the associated ADV7150/ADV7152. (For more details on the ADV7150 or the ADV7152, please consult the relevant data sheet). #### Pixel Port and Clock Control Circuit The Pixel Port of the ADV7151 is directly interfaced to the video/graphics pipeline of a computer graphics subsystem. It is connected directly or through a gate array to the video RAM of the systems Frame-Buffer (video memory). The pixel port on the device consists of: Color Data $P0A-P7A \dots P0D-P7D$ Pixel Controls $\overline{SYNC}$ , $\overline{BLANK}$ Palette Selects PS0-PS1 The associated clocking signals for the pixel port include: Clock Inputs CLOCK, CLOCK, LOADIN, SCKIN Clock Outputs LOADOUT, PRGCKOUT, SCKOUT These on-board clock control signals are included to simplify Interfacing between the part and the frame buffer. Only two control input signals are necessary to get the part operational, CLOCK and CLOCK (ECL Levels). No additional signals or external glue logic are required to get the Pixel Port and Clock Control Circuit of the part operational. #### Pixel Port (Color Data) The ADV7151 has 32 pixel data inputs. These are organized as four (for 4:1 multiplexing) 8-bit wide indexed color data inputs. The part supports 8-bit Pseudo Color in 4:1, 2:1 and 1:1 multiplex modes. Figure 12. Multiplexed Color Inputs for the ADV7151 Color data is latched into the parts pixel port on every rising edge of LOADIN (see Timing Waveform Figure 3). The required frequency of LOADIN is determined by the multiplex rate, where $f_{LOADIN} = f_{CLOCK}/4$ 4:1 Multiplex Mode $f_{LOADIN} = f_{CLOCK}/2$ 2:1 Multiplex Mode $f_{LOADIN} = f_{CLOCK}$ 1:1 Multiplex Mode -12- Other pixel data signals latched into the device by LOADIN include $\overline{SYNC}$ , $\overline{BLANK}$ and PS0-PS1. Internally, data is pipelined through the part by the differential pixel clock inputs, CLOCK and CLOCK. The LOADIN control signal does not need to have a relationship to the pixel CLOCK (see "Pipeline Delay" section). A completely asynchronous LOADIN signal can be used with the ADV7151. Alternatively, the LOADOUT signal of the ADV7151 can be used. LOADOUT can be connected either directly or indirectly to LOADIN. Its frequency is automatically set to the correct LOADIN requirement. #### SYNC, BLANK The BLANK and composite SYNC video control signals drive the analog outputs to the blanking and sync levels respectively. These signals are latched into the part on the rising edge of LOADIN. The SYNC information is encoded onto the IOG analog signal when Bit CR22 of Command Register 2 is set to a Logic "1." The SYNC input is ignored if CR22 is set to "0." #### **SYNCOUT** In some applications where it is not permissible to encode \$\overline{\text{SYNC}}\$ on green (IOG), \$\overline{\text{SYNCOUT}}\$ can be used as a separate \$\overline{\text{TTL}}\$ digital \$\overline{\text{SYNC}}\$ output. This has the advantage over an independent (of the ADV7151) \$\overline{\text{SYNC}}\$ in that it does not necessitate knowing the absolute pipeline delay of the part. This allows complete independence between LOADIN/Rixel Data and CLOCK. The \$\overline{\text{SYNC}}\$ input is connected to the device as normal with Bit CR22 of Command Register 2 set to "0" thereby preventing \$\overline{\text{SYNC}}\$ from being encoded onto IOC. Bit \$\overline{\text{R12}}\$ of Command Register 1 is set to "1", anabling \$\overline{\text{SYNCOUT}}\$ with correct pipeline delay which is capable of directly driving the composite \$\overline{\text{SYNC}}\$ signal of a computer monitor. #### PS0-PS1 (Palette Priority Select Inputs) These pixel port select inputs determine whether or not the device is selected. This is determined on a pixel by pixel basis as the PS0-PS1 inputs are multiplexed in exactly the same format as the pixel port data. These controls allow for switching between multiple devices (see Appendix 4). If values of PS0 and PS1 don't match the values programmed into bits MR16 and MR17 of the mode register, then the outputs of the device are forced to 0 mA regardless of the state of the pixel and control data inputs. Otherwise the device is selected and acts as normal. #### Multiplexing The on-board multiplexers of the ADV7151 eliminate the need for external data serializer circuits. Multiple video memory devices can be connected, in parallel, directly to the device. Figure 13 shows four memory banks of 33 MHz memory connected to the ADV7151, running in 4:1 multiplex mode, giving a resultant pixel or dot clock rate of 132 MHz. As mentioned in the previous section, the ADV7151 supports a number of color data formats in 4:1, 2:1 and 1:1 multiplex modes. Figure 13. Direct Interfacing of Video Memory to ADV7151 In 1:1 multiplex mode, the ADV7151 is clocked using the LOADIN signal. This means that there is no requirement for differential ECL inputs on CLOCK and $\overline{\text{CLOCK}}$ . The pixel clock is connected directly to LOADIN. (Note the ECL CLOCK can still be used to generate LOADOUT, PRGCKOUT, etc.) #### **CLOCK CONTROL CIRCUIT** The ADV7151 has an integrated Clock Control Circuit (Figure 14). This circuit is capable of both generating the ADV7151's internal clocking signals as well as external graphics subsystem clocking signals. Total system synchronization can be attained by using the parts output clocking signals to drive the controlling graphics processor's master clock as well as the video frame buffers shift clock signals. #### CLOCK, CLOCK Inputs The Clock Control Circuit is driven by the pixel clock inputs, CLOCK and $\overline{\text{CLOCK}}$ . These inputs can be driven by a differential ECL oscillator running from a +5 V supply. Alternatively, the ADV7151 CLOCK inputs can be driven by a Programmable Clock Generator (Figure 15), such as the ICS1562. The ICS1562 is a monolithic, phase-locked-loop, clock generator chip capable of synthesizing differential ECL output frequencies of up to 220 MHz from a single low frequency reference crystal. Figure 14. Clock Control Circuit of the ADV7151 M = 1 IN 1:1 MULTIPLEX MODE Figure 15. PLL Clock Generator Driving the ECL Clock Inputs of the ADV7151 ### CLOCK CONTROL SIGNALS LOADOUT The ADV7151 generates a LOADOUT control signal which runs at a divided down frequency of the pixel CLOCK. The frequency is automatically set to the programmed multiplex rate, controlled by CR37 and CR36 of Command Register 3. $$\begin{split} f_{\rm LOADOUT} &= f_{\rm CLOCK}/4 & 4:1 \text{ Multiplex Mode} \\ f_{\rm LOADOUT} &= f_{\rm CLOCK}/2 & 2:1 \text{ Multiplex Mode} \\ f_{\rm LOADOUT} &= f_{\rm CLOCK} & 1:1 \text{ Multiplex Mode} \end{split}$$ The LOADOUT signal is used to directly drive the LOADIN pixel latch signal of the ADV7151. This is most simply achieved by tying the LOADOUT and LOADIN pins together. Alternatively, the LOADOUT signal can be used to drive the frame buffer's shift clock signals, returning to the LOADIN input delayed with respect to LOADOUT. Figure 16. LOADOUT vs. Pixel Clock Input (CLOCK, CLOCK) If it is not necessary to have a known fixed number of pipeline delays, then there is no limitation on the delay between LOAD-OUT and LOADIN (LOADOUT(1) and LOADOUT(2)). LOADIN and Pixel Data must conform to the setup and hold times $t_8$ and $t_9$ ). If however, it is required that the ADV7151 has a fixed number of pipeline delays ( $t_{\rm PD}$ ), LOADOUT and LOADIN must conform to timing specifications $t_{10}$ and $\tau$ – $t_{11}$ as illustrated in Figures 4 to 7. #### **PRGCKOUT** The PRGCKOUT control signal outputs a user programmable clock frequency. It is a divided down frequency of the pixel CLOCK (see Figure 8). The rising edge of PRGCKOUT is synchronous with the rising edge of LOADOUT. $f_{PRGCKOUT} = f_{CLOCK}/N$ where N = 4, 8, 16 or 32 One application of the PRGCKOUT is to use it as the master clock frequency of the graphics subsystems processor or controller. #### SCKIN, SCKOUT These video memory signals are used to minimize external support chips. Figure 17 illustrates the function that is provided. An input signal applied to SCKIN is AND-ed with the video blanking signal (BLANK). The resulting signal is output on SCKOUT. Figure 9 of the Timing Waveform section shows the relationship between SCKOUT, SCKIN and BLANK. Figure 17. SCKOUT Generation Circuit The SCKOUT signal is essentially the video memory shift control signal. It is stopped during the screen retrace. Figure 18 shows a suggested frame buffer to ADV7151 interface. This is a minimum chip solution and allows the ADV7151 control the overall graphics system clocking and synchronization. Pipeline Delay and On-Board Calibration The ADV7151 has a fixed number of pipeline delays ( $t_{\rm PD}$ ), so long as timings $t_{10}$ and $\tau$ - $t_{11}$ are met. However, if a fixed pipeline delay is not a requirement, timings $t_{10}$ and $\tau$ - $t_{11}$ can be ignored, a calibration cycle must be run and there is no restriction on LOADIN to LOADOUT timing. If timings $t_{10}$ and $\tau$ - $t_{11}$ are met the part will function correctly though with an increased number of pipeline delays: $t_{\rm PD}$ + N CLOCKS (for 4:1 Mode N = 4, for 2:1 Mode N = 2, for 1:1 Mode N = 0). The ADV7151 has on-board calibration circuitry which synchronizes pixel data and LOADIN with the internal ADV7151 clocking signals. Calibration is performed in two ways. During the devices initialization sequence by toggling two bits of the Mode Register, MR10 followed by MR15 or by writing a "1" to Bit CR10 of Command Register 1 which executes a calibration on every vertical sync. #### COLOR VIDEO MODES The ADV7151 supports two color video modes all at the maximum video rate. Command bits CR24–CR27 of Command Register 2 along with bit MR11 of Mode Register 1 determine the color mode. #### 8-Bit "Gamma" Pseudo Color (CR24, CR25, CR26, CR27 = X, X, 0, 0 and MR11 = 1) This mode sets the part into 8-bit Pseudo-Color operation. The pixel port accepts 8-bits of pixel data which indexes a 30-bit word in the Look-Up Table RAM. The Look-Up Table is configured as a 256 location by 30 bits deep RAM (10 bits each for Red, Green and Blue). The output of the RAM drives the DACs with 30-bit data (10 bits each for Red, Green and Blue). -14- REV. A Figure 19. 8-Bit to 30-Bit Pseudo-Color Configuration This mode allows for the display of 256 simultaneous colors out of a total palette of millions of addressable colors 8-Bit "Standard" Pseudo Color (CR24, CR25, CR26, CR27 = X,X,0,0 and MR11 = 0) This mode sets the part into 8 bit Pseudo-Color operation. The pixel port accepts 8-bits of pixel days which indexes a 24-bit word in the Look-Up Table RAM. The Look-Up Table is configured as a 256 location by 24 bits deep RAM (10 bits each for Red, Green and Blue). The output of the RAM drives the DACs with 24-bit data (8 bits each for Red, Green and Blue). Figure 20. 8-Bit to 24-Bit Pseudo-Color Configuration This mode allows for the display of 256 simultaneous colors out of a total palette of millions of addressable colors. MICROPROCESSOR (MPU) PORT The ADV7151 supports a standard MPU Interface. All the functions of the part are controlled via this MPU port. Direct access is gained to the Address Register, Mode Register and all the Control Registers as well as the Color Palette. The following sections describe the setup for reading and writing to all of the devices registers. #### MPU Interface The MPU interface (Figure 21) consists of a bidirectional, 10-bit wide databus and interface control signals $\overline{CE}$ , C0, C1 and R/ $\overline{W}$ . The 10-bit wide databus is user configurable as illustrated. Table II. Databus Width | Databus<br>Width | RAM/DAC<br>Resolution | Read/Write<br>Mode | |------------------|-----------------------|--------------------| | 10-Bit | 10-Bit | 10-Bit Parallel | | 10-Bit | 8-Bit | 8-Bit Parallel | | 8-Bit | 10-Bit | 8+2 Byte | | 8-Bit | 8-Bit | 8-Bit Parallel | Register Mapping The ADV7151 contains a number of on-board registers including the Mode Register (MR17–MR10), Address Register (A7–A0) and nine Control Registers as well as Red (R9–R0), Green (G9 G0) and Blue B9 B0) Color Registers. These registers control the entire operation of the part. Figure 22 shows the internal register configuration. Control lines C1 and C0 determine which register he MPU is accessing. C1 and C0 also determine whether the Address Register is pointing to the color registers and look-up table RAM or the control registers. If C1, C0 = 1, 0, the MPU has access to whatever control register is pointed to by the Address Register (A7–A0). If C1, C0 = 0, 1, the MPU has access to the Look-Up Table RAM (Color Palette) through the associated color registers. The $\overline{\rm CE}$ input latches data to or from the part. The R/W control input determines between read or write accesses. The Truth Tables III and IV show all modes of access to the various registers and color palette for both the 8-bit wide databus configuration and 10-bit wide databus configuration. It should be noted that after power-up, the devices MPU port is automatically set to 10-bit wide operation (see Power-On Reset section). Figure 21. MPU Port and Register Configuration #### **Color Palette Accesses** Data is written to the color palette by first writing to the address register, the address of the color palette location to be modified. The MPU performs three successive write cycles for each of the red, green and blue registers (10-bit or 8-bit). An internal pointer moves from red to green to blue after each write is completed. This pointer is reset to red after a blue write or whenever the address register is written. During the blue write cycle, the three bytes of red green and blue are concatenated into a single 30-bit/24-bit word and written to the RAM location as specified in the address register (A7–A0). The address register then automatically increments to point to the next RAM location and a similar red, green and blue palette write sequence is performed. The address register resets to 00H following a blue write cycle to color palette RAM location FFH. read. The MPU performs three successive read cycles from each of the red, green and blue locations (10-bit or 8-bit) of the RAM. An internal pointer moves from red to green to blue after each read is completed. This pointer is reset to red after a blue read or whenever the address register is written. The address register then automatically increments to point to the next RAM location and a similar red, green and blue palette read sequence is performed. The address register resets to 00H following a blue read cycle of color palette RAM location FFH. #### **Register Accesses** The MPU can write to or read from all of the ADV7151s registers. C0 and C1 determine whether the Mode Register or Address Register is being accessed. Access to these registers is direct. The Control Registers are accessed indirectly. The Address Register must point to the desired Control Register. <sup>\*</sup> THIS REGISTER IS READ ONLY. A READ CYCLE WILL RETURN ZEROS "00." Figure 22. Internal Register Configuration and Address Decoding Table III. Truth Table (10-Bit Databus Mode) | R/W | C1 | C0 | Databus (D9-D0) | Operation | Result | | | |----------------------------|----|----|-----------------|--------------------------------------------------------------|---------------------------------|--|--| | 0 | 1 | 1 | DB7-DB0 | Write to Mode Register | $DB7-DB0 \rightarrow MR17-MR10$ | | | | 0 | 0 | 0 | DB7-DB0 | Write to Address Register | $DB7-DB0 \rightarrow A7-A0$ | | | | 0 | 1 | 0 | DB7-DB0 | Write to Control Registers | DB7-DB0 → Control Registers | | | | | | | | (Particular Control Register Determined by Ac | ddress Register) | | | | 0 | 0 | 1 | DB9-DB0 | Write to RED Register | $DB9-DB0 \rightarrow R9-R0$ | | | | 0 | 0 | 1 | DB9-DB0 | Write to GREEN Register | $DB9-DB0 \rightarrow G9-G0$ | | | | 0 | 0 | 1 | DB9-DB0 | Write to BLUE Register | $DB9-DB0 \rightarrow B9-B0$ | | | | | | | | Write RGB Data to RAM Location Pointed to | by Address Register (A7–A0) | | | | | | | | Address Register = Address Register + 1 | | | | | 1 | 1 | 1 | DB7-DB0 | Read Mode Register | $MR17-MR10 \rightarrow DB7-DB0$ | | | | 1 | 0 | 0 | DB7-DB0 | Read Address Register | $A7-A0 \rightarrow DB7-DB0$ | | | | 1 | 1 | 0 | DB7-DB0 | Read Control Registers | Register Data → DB7–DB0 | | | | | | | | (Particular Control Register Determined by Address Register) | | | | | 1 | 0 | 1 | DB9-DB0 | Read RED RAM Location | R9–R0 → DB9–DB0 | | | | 1 | 0 | 1 | DB9-DB0 | Read GREEN RAM Location | $G9-G0 \rightarrow DB9-DB0$ | | | | 1 | 0 | 1 | DB9-DB0 | Read BLUE RAM Location | $B9-B0 \rightarrow DB9-DB0$ | | | | (RAM Location Pointed to l | | | | (RAM Location Pointed to by Address Regista | er (A7–A0) | | | | | | | | Address Register = Address Register + 1 | | | | -16- DB = Data Bit. Table IV. Truth Table (8-Bit Databus Mode)\* | R/W | C1 | C0 | Databus<br>(D7-D0) | Operation | Result | |---------|----------|------------------------------------------------|--------------------|-----------------------------------------------------------------------------------|---------------------------------| | 0 | 1 | 1 | DB7-DB0 | Write to Mode Register | $DB7-DB0 \rightarrow MR17-MR10$ | | 0 | 0 | 0 | DB7-DB0 | Write to Address Register | $DB7-DB0 \rightarrow A7-A0$ | | 0 | 1 | 0 | DB7-DB0 | Write to Control Registers | DB7-DB0 → Control Registers | | | | | | (Particular Control Register Determined by Add | dress Register (A7–A0)) | | 0 | 0 | 1 | DB9–DB2 | Write to RED Register | $DB9-DB2 \rightarrow R9-R2$ | | 0 | 0 | 1 | DB1-DB0 | Write to RED Register | $DB1-DB0 \rightarrow R1-R0$ | | 0 | 0 | 1 | DB9-DB2 | Write to GREEN Register | $DB9-DB2 \rightarrow G9-G2$ | | 0 | 0 | 1 | DB1-DB0 | Write to GREEN Register | $DB1-DB0 \rightarrow G1-G0$ | | 0 | 0 | 1 | DB9-DB2 | Write to BLUE Register | $DB9-DB2 \rightarrow B9-B2$ | | 0 | 0 | 1 | DB1-DB0 | Write to BLUE Register | $DB1-DB0 \rightarrow B1-B0$ | | | | | | Write RGB Data to RAM Location Pointed to Address Register = Address Register + 1 | by Address Register (A7–A0) | | 1 | 1) / | $\sqrt{1}$ | DB7-DB0 | Read Mode Register | $MR17-MR10 \rightarrow DB7-DB0$ | | 1 | / // | | DB7-DBQ | ∖ Read Address Register | $A7-A0 \rightarrow DB7-DB0$ | | | 1 /1 / | M 1 | DB7-QB0 | Read Control Registers | Register Data → DB7-DB0 | | | $\vee$ / | L ) | | (Pa <del>rticu</del> lar Control Register Determined by Add | | | 1 | 0 | $\phantom{aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa$ | DB9-DB2 | Read RED RAM Location | R9–R2 → DB9–DB2 | | 1 | 0 | 1 | DBJ-DB0 | Read RED RAM Location | $R1-R0 \rightarrow DB1-DB0$ | | 1 | 0 | 1 | DB9_DB2 | Read GREEN KAM Location | <b>Q</b> 9−G2 → DB9−DB2 | | 1 | 0 | 1 | DB1-DB0 | Read GREEN RAM Location | $G1-G0 \rightarrow DB1/DB0$ | | 1 | 0 | 1 | DB9-DB2 | Read BLUE RAM Location | 7 B9−B2 → DB9−10B2 | | 1 | 0 | 1 | DB1-DB0 | Read BLUE RAM Location | $B1-180 \rightarrow DB1-1DB0$ | | | | | | (RAM Location Pointed to by Address Register | (A7-Ab) | | | | | | Address Register = Address Register + 1 | | | DB = Da | uta Rit | | | 7 | | #### Power-On Reset On power-up, the ADV7151 executes a power-on reset sequence. This initializes the pixel port such that the pixel sequence ABCD starts at A. The Mode Register (MR17-MR10), Command Register 2 (CR27-CR20) and Command Register 3 (CR37-CR30) have all bits set to a Logic "1." The output clocking signals are also set during this reset period. PRGCKOUT = CLOCK/32LOADOUT = CLOCK/4 The power-on reset is activated when VAA goes from 0 V to 5 V. This reset is active for 1 µs. The ADV7151 should not be accessed during this reset period. The pixel clock should be applied at power-up. #### REGISTER PROGRAMMING The following section describes each register, including Address Register, Mode Register and each of the nine Control Registers in terms of its configuration. #### Address Register (A7-A0) As illustrated in the previous tables, the C0 and C1 control inputs, in conjunction with this address register specify which control register, or color palette location is accessed by the MPU port. The address register is 8 bits wide and can be read from as well as written to. When writing to or reading from the color palette on a sequential basis, only the start address needs to be written. After a red, green and blue write sequence, the address register is automatically incremented. #### MODE REGISTER MR1 (MR19-MR10) The mode register is a 10-bit wide register. However, for programming purposes, it may be considered as an 8-bit wide register (MR18 and MR19 are both reserved). It is denoted as MR17-MR10 for simplification purposes. <sup>\*</sup>Writing or reading 10-bit data (DB9-DB0) over an 8-bit databus (D7-D0) requires two write or two read cycles. DB9-DB2 is mapped to D7-D0 on the first cycle. DB1-DB0 is mapped to D1-D0 on the second cycle with D7-D2 ignored. The diagram shows the various operations under the control of the mode register. This register can be read from as well written to. In read mode, if MR18 and MR19 are read back, they are both returned as zeros. ### MODE REGISTER (MR17-MR10) BIT DESCRIPTION Reset Control (MR10) This bit is used to reset the pixel port sampling sequence. This ensures that the pixel sequence ABCD starts at A. It is reset by writing a "1" followed by a "0" followed by a "1." This bit must be run through this cycle during the initialization sequence. #### RAM-DAC Resolution Control (MR11) When this is programmed with a "1," the RAM is 30-bits deep (10 bits each for red, green and blue) and each of the three DACs is configured for 10-bit resolution. When MR11 is programmed with a "0," the RAM is 24 bits deep (8 bits each for red, green and blue) and the DACs are configured for 8-bit resolution. The two LSBs of the 10-bit DACs are pulled down to zero in 8-bit RAM-DAC mode. #### MPU Databus Width (MR12) This bit determines the width of the MPU port. It is configured as either a 10-bit wide (D9–D0) or 8-bit wide (D7–D0) bus. 10-bit data can be written to the device when configured in 8-bit wide mode. The 8 MSBs are first written on D7–D0, then the two LSBs are written over D1–D0. Bits D9–D8 are zeros in 8-bit mode. #### Operational Mode Control (MR14-MR13) When MR14 is "0" and MR13 if "1," the port operates in normal mode. #### Calibrate LOADIN (MR15) This bit automatically calibrates the on-board LOADIN/LOADOUT synchronization circuit. A "0" to "1" transition initiates calibration. This bit is set to "0" in normal operation. See "Pipeline Delay and Calibration" section. This bit must be run through this cycle during the initialization sequence. Palette Select Match Bits Control (MR17-MR16) These bits allow multiple palette devices to work together. When hits PS1 and PS0 match MR17 and MR16 respectively, the device is selected. If these bits do not match, the device is not selected and the analog video outputs drive 0 mA. See Appendix 4, "Multiple Palette Applications" #### **CONTROL REGISTERS** The ADV7151 has 9 control registers. To access each register, two write operations must be performed. The first write to the address register specifies which of the 9 registers is to be accessed. The second access determines the value written to that particular control register. #### Pixel Test Register #### (Address Reg (A7-A0) = 00H) This register is used when the device is in test/diagnostic mode. It is an 8-bit wide read-only register which allows the MPU to read data on the pixel port (see Appendix 6, "Test Diagnostics"). #### **DAC Test Register** #### (Address Reg (A7-A0) = 01H) This register is used when the device is in test/diagnostic mode. It is a 30-bit (10 bits each for RED, GREEN and BLUE) wide read-only register which allows MPU access to the DAC port (see Appendix 6, "Test Diagnostics"). ### SYNC, BLANK and I<sub>PLL</sub> Test Register (Address Reg (A7-A0) = 02H) This register is used when the device is in test/diagnostic mode. It is a 3-bit wide (3 LSBs) read/write register which allows MPU access to these particular pixel control bits (see Appendix 6, "Test Diagnostics"). #### **ID** Register -18- #### (Address Reg (A7-A0) = 03H) This is an 8-bit wide "Identification" read-only register. For the ADV7151 it will always return the hexadecimal value 8FH. REV. A #### Pixel Mask Register #### (Address Reg (A7-A0) = 04H) The contents of the pixel mask register are individually bit-wise logically AND-ed with the Red, Green and Blue pixel input stream of data. It is an 8-bit read/write register with D0 corresponding to R0, G0 and B0. For normal operation, this register is set with FFH. #### **COMMAND REGISTER 1 (CR1)** #### (Address Reg (A7-A0) = 05H) This register contains a number of control bits as shown in the diagram. CR1 is a 10-bit wide register. However for programming purposes, it may be considered as an 8-bit wide register (CR18 and CR19 are reserved). The diagram below shows the various operations under the control of CR1. This register can be read from as well as written to. In write mode, zero should be written to CR11 and CR13 to CR17. In read mode, CR11 and CR13 to CR19 are all returned as zeros. ### **COMMAND REGISTER 1 BIT DESCRIPTION Calibration Control (CR10):** This bit automatically calibrates the on-board LOADIN/LOADOUT synchronization circuit. MR15 of Mode Register MR1 must be set to "0." #### **SYNCOUT** Control (CR12): This bit specified whether the video SYNCOUT signal is to be enabled. On power up a "0" is written to the bit and "SYNCOUT" is set three state. Command Register 1 (CR1) (CR19-CR10) #### **COMMAND REGISTER 2 (CR2)** #### (Address Reg (A7-A0) = 06H) This register contains a number of control bits as shown in the diagram. CR2 is a 10-bit wide register. However for programming purposes, it may be considered as an 8-bit wide register (CR28 and CR29 are both reserved). The diagram shows the various operations under the control of CR2. This register can be read from as well written to. In read mode, CR28 and CR29 are both returned as zeros. ### COMMAND REGISTER 2 BIT DESCRIPTION P2 Trigger Polarity Control (CR20) This bit is used when the device is in test/diagnostic mode. It determines whether the pixel data is latched into the test registers in the rising or falling edge of P2 (see Appendix 6, "Test #### I<sub>PLL</sub> Trigger Control (CR21) This bit specifies whether the $I_{\rm PLL}$ output is triggered from $\overline{BLANK}$ or $\overline{SYNC}$ . #### **SYNC** Recognition Control (CR22) This bit specifies whether the video SYNC input is to be encoded onto the IOG analog output or ignored. #### Pedestal Enable Control (CR23) This bit specifies whether a 0 IRE or a 7.5 IRE blanking pedestal is to be generated on the video outputs. #### Color Mode Control (CR27-CR24) These 4 bits specify the color mode. To ensure compatibility with future products in the ADV715x product family, it is recommended that all these bits be set to a logical zero. Command Register 2 (CR2) (CR29-CR20) CR3. This register can be read from as well written to. In read mode, CR38 and CR39 are both returned as zeros. #### **COMMAND REGISTER 3 BIT DESCRIPTION** PRGCKOUT Frequency Control (CR31-CR30) These bits specify the output frequency of the PRGCKOUT output. PRGCKOUT is a divided down version of the pixel CLOCK. #### Pixel Multiplex Control (CR37-CR36) These bits specify the device's multiplex mode. It, therefore, also determines the frequency of the LOADOUT signal. LOADOUT is a divided down version of the pixel CLOCK. #### **Revision Register** #### (Address reg (A7-A0) = 0BH): This register is a read only register containing the revision of silicon. ### **DIGITAL-TO-ANALOG CONVERTERS (DACS) AND** VIDEO OUTPUTS The ADV7151 contains three high speed video DACs. The DAC outputs are represented as the three primary analog color signals IOR (red video), IOG (green video) and IOB (blue video). Other analog signals on the part include $I_{\rm PLL}$ and $R_{\rm REF}$ as well as complementary video outputs $\overline{IOR}$ , $\overline{IOG}$ , IOB. These complementary outputs can be used to drive differentially terminated video loads, they will have equal but opposite output levels to IOR, IOG and IOB when loaded with a resistive load similar to IOR, IOG and IOB. #### **DACs and Analog Outputs** The part contains three matched 10-bit digital to analog converters. The DACs are designed using an advanced, high speed, segmented architecture. The bit currents corresponding to each digital input are routed to either IOR, IOG, IOB (bit = "1") or $\overline{IOR}$ , $\overline{IOG}$ , $\overline{IOB}$ (bit = "0"). (Normally $\overline{IOR}$ , $\overline{IOG}$ , $\overline{IOB}$ = The analog video outputs are high impedance current sources. Each of the these three RGB current outputs are specified to directly drive a 37.5 $\Omega$ load (doubly terminated 75 $\Omega$ ). -21-REV. A Figure 23. DAC Output Termination (Doubly Terminated 75 $\Omega$ Load) #### Reference Input and $R_{\rm SET}$ An external 1.23 V voltage reference is required to drive the analog outputs of the ADV7151. The reference voltage is connected to the $V_{\rm REF}$ input. A resistor $R_{\rm SET}$ is connected between the $R_{\rm SET}$ input of the part and ground. For specified performance, $R_{\rm SET}$ has a value of 280 $\Omega.$ This corresponds to the generation of RS-343A video levels (with $\overline{\rm SYNC}$ on IOG and Pedestal = 7.5 IRE) into a doubly terminated 75 $\Omega$ load. Figure 24 illustrates the resulting video waveform and the Video Output Truth Table shows the corresponding control input stimuli. | Description | IOG (mA) | IOR, IOB (mA) | SYNC | BLANK | DAC Input Data | |----------------|--------------|---------------|------|-------|----------------| | WHITE LEVEL | 26.67 | 19.05 | 1 | 1 | 3FFH | | VIDEO | Video + 9.05 | Video + 1.44 | 1 | 1 | Data | | VIDEO to BLANK | Video + 1.44 | Video + 1.44 | 0 | 1 | Data | | BLACK LEVEL | 9.05 | 1.44 | 1 | 1 | 000H | | BLACK to BLANK | 1.44 | 1.44 | 0 | 1 | 000H | | BLANK LEVEL | 7.62 | 0 | 1 | 0 | xxxH | | SYNC LEVEL | 0 | 0 | 0 | 0 | xxxH | –22– REV. A #### Variations on RS-343A Various other video output configurations can be implemented by the ADV7151, including RS-170. Values of $R_{\rm SET}$ for particular output video formats/levels are calculated by using the equations for $R_{\rm SET}$ given in the "Pin Configuration" section. The table shows calculated values of $R_{\rm SET}$ for some of the most common variants on the RS-343A standard. The associated waveforms are shown in the diagrams. Table VI. | $R_{SET}(\Omega)$ | Video Signal | |-------------------|---------------------------------------------------------| | 265 | SYNC Decoded on IOG: Pedestal = 0 IRE | | 280 | No $\overline{\text{SYNC}}$ Decoded: Pedestal = 7.5 IRE | | 259 | No $\overline{\text{SYNC}}$ Decoded: Pedestal = 0 IRE | Figure 25. Composite Video Waveform $\overline{SYNC}$ Decoded on IOG; Pedestal = 0 IRE; $R_{SET}$ = 265 $\Omega$ Figure 26. Composite Video Waveform; Pedestal = 7.5 IRE; $R_{SET}$ = 280 $\Omega$ Figure 27. Composite Video Waveform; Pedestal = 0 IRE; $R_{SET}$ = 259 $\Omega$ #### IPLL Synchronization Output Control This output synchronization signal is used in applications where it is necessary to synchronize multiple palette devices (ADV7150 + ADV7151) to subpixel resolution. The $I_{\rm PLL}$ output from each device is in phase with it's analog RGB output signal. If multiple devices have differing output delays, the time difference can be measured from the $I_{\rm PLL}$ signals. This time difference is then used to phase shift the CLOCK inputs on one or other of the device inputs. The I<sub>PL</sub> signal is internally triggered by either the falling edge of SYNC of BLANK as determined by CR21 of Command Register 2. #### APPENDIX 1 #### BOARD DESIGN and LAYOUT CONSIDERATIONS The ADV7151 is a highly integrated circuit containing both precision analog and high speed digital circuitry. It has been designed to minimize interference effects on the integrity of the analog circuitry by the high speed digital circuitry. It is imperative that these same design and layout techniques be applied to the system level design such that high speed, accurate performance is achieved. The "Recommended Analog Circuit Layout" shows the analog interface between the device and monitor. The layout should be optimized for lowest noise on the ADV7151 power and ground lines by shielding the digital inputs and providing good decoupling. The lead length between groups of V<sub>AA</sub> and GND pins should by minimized so as to minimize #### Power Planes The ADV7151 and any associated analog circuitry should have it's own power plane, referred to as the analog power plane (VAA). This power plane should be connected to the regular PCB power plane (V<sub>CC</sub>) at a single point through a ferrite bead. This bead should be located within three inches of the ADV7151. The PCB power plane should provide power to all digital logic on the PC board, and the analog power plane should provide power to all ADV7151 power pins and voltage reference circuitry. Plane-to-plane noise coupling can be reduced by ensuring that portions of the regular PCB power and ground planes do not Recommended Analog Circuit Layout -24- #### Supply Decoupling For optimum performance, bypass capacitors should be installed using the shortest leads possible, consistent with reliable operation, to reduce the lead inductance. Best performance is obtained with 0.1 $\mu F$ ceramic capacitor decoupling. Each group of $V_{AA}$ pins on the ADV7151 must have at least one 0.1 $\mu F$ decoupling capacitor to GND. These capacitors should be placed as close as possible to the device. It is important to note that while the ADV7151 contains circuitry to reject power supply noise, this rejection decreases with frequency. If a high frequency switching power supply is used, the designer should pay close attention to reducing power supply noise and consider using a three terminal voltage regulator for supplying power to the analog power plane. #### Digital Signal Interconnect The digital inputs to the ADV7151 should be isolated as much as possible from the analog outputs and other analog circuitry. Also, these input signals should not overlay the analog power plane. Due to the high clock rates involved, long clock lines to the ADV/151 should be avoided to reduce noise pickup. Any active termination resistors for the digital inputs should be connected to the regular PCB power plane (V<sub>CC</sub>), and not the analog power plane. #### **Analog Signal Interconnect** The ADV7151 should be located as close as possible to the output connectors to minimize noise pick-up and reflections due to impedance mismatch. The video output signals should overlay the ground plane, and not the analog power plane, to maximize the high frequency power supply rejection. Digital Inputs, especially Pixel Data Inputs and clocking signals (CLOCK, LOADOUT, LOADIN etc.) should never overlay any of the analog signal circuitry and should be kept as far away as possible. For best performance, the analog outputs (IOR, IOG, IOB) should each have a 75 $\Omega$ load resistor connected to GND. These resistors should be placed as close as possible to the ADV7151 so as to minimize reflections. Normally, the differential analog outputs ( $\overline{\text{IOR}}$ , $\overline{\text{IOG}}$ , $\overline{\text{IOB}}$ ) are connected directly to GND. In some applications, improvements in performance are achieved by terminating these differential outputs with a resistive load similar in value to the video load. For a doubly terminated 75 $\Omega$ load, this means that $\overline{\text{IOR}}$ , $\overline{\text{IOG}}$ , $\overline{\text{IOB}}$ are each terminated with a $\sqrt[3]{7.5}\Omega$ resistor. APPENDIX TYPICAL FRAME BUFFER INTERFACE CLOCK **CLOCK GENERATOR** то CLOCK **PRGCKOUT** DIVIDE BY N DIVIDE BY M (+ N) (+M) LOADOUT SCKOUT CLOCK LATCH BLANK **GRAPHICS** BLANK PROCESSOR/ SYNC SYNC CONTROLLER SCKIN LOADIN ADV7151 VRAM (BANK A) 33MHz 8 **FRAME** VRAM TO 33MHz (BANK B) BUFFER/ PALETTE/RAM MULTIPLEXER 8 **VRAM** VIDEO MEMORY 33MHz & DAC (BANK C) VRAM (BANK D) 33MHz REV. A # APPENDIX 3 10-BIT DACS AND GAMMA CORRECTION #### 10-Bit DACs 10-bit RAM-DAC resolution allows for nonlinear video correction, in particular Gamma Correction. The ADV7151 allows for an increase in color resolution from 8-bit to 10-bit effective color without the necessity of a 10-bit deep frame buffer. The part operates as an 8-bit to 10-bit color look-up table. Up to now we have assumed that there exists a linear relationship between the actual RGB values input to a monitor and the intensity produced on the screen. This, however, is not the case. Half scale digital input (1000 0000) might correspond to only 20% output intensity on the CRT (Cathode Ray Tube). The intensity ( $I_{CRN}$ ) produced on a CRT by an input value $I_{IN}$ is where $\chi$ ranges from 2.0 to 2.8 If the individual values of $\chi$ for red, green and blue are known, then so called "Gamma Correction" can be applied to each of the three video input signals $(I_{\rm IN})$ therefore: $I_{IN(corrected)} = k(I_{IN})^{1/\chi} \qquad (K = 1, normally)$ Traditionally, there has been a tradeoff between implementing a nonlinear graphics function, such as gamma correction, and color dynamic range. The ADV7151 overcomes this by increasing the individual color resolution of each of the red, green and blue primary colors from 8 bits per color channel to 10 bits per channel (24 bits to 30 bits). #### Gamma Correction 8 Bits vs. 10 Bits | 8-Bit Data | Gamma<br>Corrected<br>(2.7) | Quantized to<br>8 Bits | Quantized to<br>10 Bits | |------------|-----------------------------|------------------------|-------------------------| | 240 | 0.977797 | 250 | 1001 | | 241 | 0.979304 | 250 | 1002 | | 242 | 0.980807 | 251 | 1004 | | 243 | 0.982306 | 251 | 1005 | | 244 | 0.983801 | 251 | 1007 | | 245 | 0.985292 | 252 | 1008 | | 246 | 0.986780 | 252 | 1010 | | 247 | 0.988264 | 252 | 1011 | | 248 | 0.989744 | 253 | 1013 | | 249 | 0.991220 | 253 | 1015 | | 250 | 0.992693 | 254 | 1016 | | 251 | 0.994161 | 254 | 1018 | | 252 | 0.995626 | 254 | 1019 | | 253 | 0.997088 | 255 | 1021 | | 254 | 0.998546 | 255 | 1022 | | 255 | 1.000000 | 255 | 1023 | The table highlights the loss of resolution when 8-bit data is gamma-corrected to a value of 2.7 and quantized in a traditional 8-bit system. Note that there is no change in the 8-bit quantized data for linear changes in the input data over much of the transfer function. On the other hand, when quantized to 10 bits via the 10-bit RAMs and 10-bit DACs of the ADV7151, all changes on the input 8-bit data are reflected in corresponding changes in the 10-bit data. The graph shows a typical gamma curve corresponding to a gamma value of 2.7. This is programmed to the red, green and blue RAMs of the color look-up table instead of the more traditional linear function. Different curves corresponding to any particular gamma value can be independently programmed to each of the red, green and blue RAMs. Other applications of the 10-bit RAM-DAC include closed-loop monitor color calibration. Gamma Correction Curve (Gamma Value = 2.7) #### **APPENDIX 4** MULTIPLE PALETTE APPLICATIONS #### **Palette Priority Select Inputs** The palette priority selection inputs allow up to four separate palette devices to be used in a single system to drive a single monitor. The IOR, IOG and IOB analog video output signals of each device are connected together, as shown. Signal inputs (PS0, PS1) determine on a pixel by pixel basis which palette device drives the monitor. This allows for implementation of multiple windows applications with each device acting as an independent palette. During initialization, each device is assigned two match bits, MR16 (PS0) and MR17 (PS1) in Mode Register MR1. PS0 and PS1 inputs will select one of the preprogrammed devices at any instant when PS0, PS1 matches MR16, MR17 respectively. PS0 and PS1 are multiplexed similar grams show an example of one ADV7150 (true-color RAM-DAC) operating in conjunction with three ADV7151s. Each displayed window on the monitor is driven by one of the four devices. Each device's analog output signals are connected together as shown. Note: Only one palette device is selected at any particular instant. The analog output levels of the unselected devices will be 0 mA. Other applications for the palette priority function using a minimum of two devices (one ADV7150 and one ADV7151) include: Cursor Overlay on 24-Bit Graphics Active Live Video Overlay (from Frame Grabber) Text/Character Generation and Overlay Multiple Devices Driving a Multiwindow Application # APPENDIX 5 INITIALIZATION AND PROGRAMMING #### **ADV7151 Initialization** After power has been supplied, the ADV7151 must be initialized. The Mode Register and Control Registers must be set. The values written to the various registers will be determined by the desired operating mode of the part, i.e., 4:1 Muxing/2:1 Muxing, etc. The following sections give examples of initialization for the ADV7151. | Exam | nle | 1 | |------|-----|---| | | | | Color Mode: 8-Bit Pseudo Color Multiplexing:4:1Databus8-BitRAM-DAC Resolution8-Bit SYNC Enabled on GREEN OUT Pedestal 7.5 IRE | Regist | er Initialization | C1 | C0 | $R/\overline{W}$ | Comment | |--------|-----------------------------------------|------------------|---------------|------------------------------------|--------------------------------------------------| | Write | $\frown$ | 1 | 1 | 0 | Resets to Normal Operation, 8-Bit Bus/RAM-DAC | | Write | 08H to Mode Register (MR1) | 1 | 1 | 0 | *(Initializes Pipelining | | Write | 09H to Mode Register (MR1) | 1 | 1 | 0 | *( " | | Wrke | 29H to Mode Register (MX1) | l | 1 | 0 | *(Calibrates LOADOUT/LOADIN Timing | | Write | 09H to Mode Register (MR1) | 1/ | $\widehat{1}$ | A. | *( " | | Write | | /0 / | 0 | 0 | Address Register Points to Pixel Mask Register | | Write | FFH to Pixel Mask register | 1/ | 0 | b / | Sets the Pixel Mask to All "1s" | | Write | 05H to Address Register (AAA) | 0 | 0 | b 1 | Address Register Points to Command Register 1 | | Write | 00H to Command Reg 1 (CR1) | . 1 | 0 | / <sub>0</sub> / / | | | Write | 06H to Address Register (A7–A0) | \ <sub>Q</sub> \ | <b>√</b> | 9// | Address Register Points to Command Register 2 | | Write | 0CH to Command Reg 2 (CR2) | 1 | <b>—</b> | 0 / | Sets 8-Bit Pseudo Color, 7/5 IRE, \$YNC on Green | | Write | 07H to Address Register (A7-A0) | 0 | 0 | 0 _ | Address Register Points to Command Register/3 | | Write | C0H to Command Reg 3 (CR3) | 1 | 0 | 0 | Sets 4:1 Multiplexing, PRGCKOUT & CLOCK/4 | | Color | Palette RAM Initialization | C1 | C0 | $\mathbf{R}/\overline{\mathbf{W}}$ | Comment | | Write | 00H to Address Register (A7-A0) | 0 | 0 | 0 | Address Register Points to Color Palette RAM | | Write | 00H (Red Data) to RAM Location (00H) | 0 | 1 | 0 | (Initializes Palette RAM | | Write | 00H (Green Data) to RAM Location (00H) | 0 | 1 | 0 | ( to a Linear Ramp** | | Write | 00H (Blue Data) to RAM Location (00H) | 0 | 1 | 0 | ( | | Write | 01H (Red Data) to RAM Location (01H) | 0 | 1 | 0 | ( | | Write | 01H (Green Data) to RAM Location (01H) | 0 | 1 | 0 | ( | | Write | 01H (Blue Data) to RAM Location (01H) | 0 | 1 | 0 | ( | | • | • • | • | • | • | ( | | • | | | | • | | | Write | FFH (Red Data) to RAM Location (FFH) | 0 | 1 | 0 | | | Write | FFH (Green Data) to RAM Location (FFH) | 0 | 1 | 0 | | | Write | FFH (Blue Data) to RAM Location (FFH) | 0 | î | 0 | (RAM Initialization Complete | | | , , , , , , , , , , , , , , , , , , , , | | | | | <sup>\*</sup>These four command lines reset the ADV7151. The pipelines for each of the Red, Green and Blue pixel inputs are synchronously reset to the Multiplexer's "A" input. Mode Register Bit MR10 is written by a "1" followed by "0" followed by "1." LOADIN/LOADOUT timing is internally synchronized by writing a "0" followed by a "1" followed by a "0" to Mode Register MR15. The initialization must be performed in this order. These four command lines cannot be condensed into two command lines that initialize pipelining and calibrate the LOADIN/LOADOUT timing simultaneously. -28- REV. A <sup>\*\*</sup>This sequence of instructions would, of course, normally be coded using some form of loop instruction. Example 2 Color Mode: 8-Bit Gamma Corrected Pseudo Color (10 Bits) Multiplexing: 4:1 Databus 10-Bit RAM-DAC Resolution 10-Bit SYNC Ignored Pedestal 0 IRE Calibration Every Vertical Sync | Registe | er Initialization | C1 | C0 | $R/\overline{W}$ | Comment | |---------|-----------------------------------------|-------------------------------|-----------------|------------------|------------------------------------------------| | _ | 0FH to Mode Register (MR1) | 1 | 1 | 0 | Resets to Normal Operation, 10-Bit Bus/RAM-DAC | | Write | 0EH to Mode Register (MR1) | 1 | 1 | 0 | *(Initializes Pipelining | | Write | 0FH to Mode Register (MR1) | 1 | 1 | 0 | *( " | | Write | 2FH to Mode Register (MR1) | 1 | 1 | 0 | *(Calibrates LOADOUT/LOADIN Timing | | Write | 0FH to Mode Register (MR1) | 1 | 1 | 0 | *( " | | Write | 94H to Address Register (A7–A0) | 0 | 0 | 0 | Address Register Points to Pixel Mask Register | | Write | FFN to Pixel Mask register | 1 | 0 | 0 | Sets the Pixel Mask to All "1s" | | Write | 05H to Address Register (A7–A0) | 0 | 0 | 0 | Address Register Points to Command Register 1 | | /Write | 00H to Command Reg 1 (CR1) | 1 | 0 | 0 | Calibrates every Vertical Sync | | Write | 06H to Address Register (A/-A0) | 0 | 0 | 0 | Address Register Points to Command Register 2 | | Write | 00H to Command Reg 2 (CR2) | _ | 0 | 0 | Sets Pseudo-Color, 0 IRE, No SYNC | | | 07H to Address Register (AV-A0) | 0_ | 9 | 0 | Address Register Points to Command Register 3 | | | C1H to Command Reg 3 (CR2) | $\overline{1}$ | V | 0 / | 7Sets 4:1 Multiplexing, PRGCKOUT = CLOCK/8 | | Color 1 | Palette RAM Initialization | C1 | Ço ) | R/W | Comment | | | 00H to Address Register (A7–A0) | 0 | b l | 'o/ / | Address Register Points to Color Palette RAM | | Write | 000H (Red Data) to RAM Location (00H) | 0 , | $I_1$ / | d / | (Initializes Palette RAM | | Write | | $\underbrace{\hspace{1cm}}_0$ | V | b / | ( to a "Gamma" Ramp | | Write | 000H (Blue Data) to RAM Location (00H) | <del>_</del> | $\overline{}_1$ | / <sub>0</sub> | | | Write | xxxH (Red Data) to RAM Location (01H) | 0 | 1 | <u>_</u> | | | Write | xxxH (Green Data) to RAM Location (01H) | 0 | 1 | 0 | | | Write | xxxH (Blue Data) to RAM Location (01H) | 0 | 1 | 0 | | | | | | | | | | | | | | | | | Write | 3FFH (Red Data) to RAM Location (FFH) | 0 | 1 | 0 | $\sim$ 7 | | Write | 3FFH (Green Data) to RAM Location (FFH) | 0 | 1 | 0 | | | Write | 3FFH (Blue Data) to RAM Location (FFH) | 0 | 1 | 0 | (RAM Initialization Complete | | write | 51-11 (Dide Data) to KAM Location (FFA) | U | 1 | U | (MAN) Initialization Complete | <sup>\*</sup>These four command lines reset the ADV7151. The pipelines for each of the Red, Green and Blue pixel inputs are synchronously reset to the Multiplexer's "A" input. Mode Register Bit MR10 is written by a "1" followed by "0" followed by "1." LOADIN/LOADOUT timing is internally synchronized by writing a "0" followed by a "1" followed by a "0" to Mode Register MR15. The initialization must be performed in this order. These four command lines cannot be condensed into two command lines that initialize pipelining and calibrate the LOADIN/LOADOUT timing simultaneously. #### REGISTER DIAGNOSTIC TESTING The previous examples show the register initialization sequence for the ADV7151. These show control data going to the registers and palette RAM. As well as this writing function, it may also be necessary, due to system diagnostic requirements, to confirm that correct data has been transferred to each register and palette RAM location. There are two ways to incorporate register value/RAM value checking. 1. READ after each WRITE. After data is written to a particular register, it can be read back immediately. The following table shows an example with Command Registers CR2 and CR3. | C1 | C0 | $R/\overline{W}$ | D0-D7 | Comment | |----|----|------------------|-------|---------------------------------| | 0 | 0 | 0 | 06H | Select Command Register 2 (CR2) | | 1 | 0 | 0 | H00 | Sets 8-Bit Pseudo-Color, No | | | | | | Pedestal, SYNC Not Recognized | | 1 | 0 | 1 | 00H | Command Reg 2 Value Read-Back | | 0 | 0 | 0 | 07H | Select Command Register 3 (CR3) | | 1 | 0 | 0 | 40H | Set 2:1 Mux Mode | | 1 | 0 | 1 | 40H | Command Reg 3 Value Read-Back | READ after all WRITEs completed. All registers and the color palette RAM are written to and set. Once this is complete, all registers are again accessed but this time in Read-Only mode. The table below shows this method for Command Registers CR2 and CR3. | C1 | $\mathbf{C0}$ | $\mathbb{R}/\overline{\mathbb{W}}$ | D0-D7 | Comment | |----|---------------|------------------------------------|-------------|---------------------------------| | 0 | 0 | 0 | 06H | Select Command Register 2 (CR2) | | 1 | 0 | 0 | 00H | Sets 8-Bit Pseudo-Color, No | | | | | | Pedestal, SYNC Not Recognized | | 0 | 0 | 0 | 07 <b>H</b> | Select Command Register 3 (CR3) | | 1 | 0 | 0 | 40H | Set 2:1 Mux Mode | | 0 | 0 | 0 | 06H | Select CR2 | | 1 | 0 | 1 | 00H | CR2 Value Read-Back | | 0 | 0 | 0 | 07 <b>H</b> | Select CR3 | | 1 | 0 | 1 | 40H | CR3 Value Read-Back | | | | | | | It is clear that this latter case requires more command lines than the previous READ after each WRITE case. # APPENDIX 6 TEST DIAGNOSTICS The ADV7151 contains on board circuitry which enables both device and system level test diagnostics. The test circuitry can be used to test the frame buffer memory as well as the functionality of the ADV7151. A number of test registers are integrated into the part which effectively allow for monitoring of the graphics pipeline. Pixel data is read from the graphics pipeline independent of the pixel CLOCK. The pixel data itself contains the triggering information that latches data into the test registers. This allows for system diagnostics in a continuously clocked graphics system. The test register data is then read by the microprocessor over the MPU. Access to the test registers is as described in the "Microprocessor (MPU) Port" section. This section also gives the address decode locations for the various test registers. #### Test Trigger (P2) The test trigger is decoded from the pixel data stream. Bit P2 [A-D] is assigned the task of latching pixel data into the test registers. A "0" to "1" or a "1" to "0" (as determined by bit CR20 of Command Register 2) transition on P2, fills the test register with the corresponding pixel data. This effectively means that a sequence of data travels along the graphics pipeline, with the test registers taking a sample only when there is a transition on bit P2. The following example shows a sequence with the ADV7151 preset to sample the graphics pipeline on a low to high transition of P2. | Pixel 0: | 0000 | | |---------------|-------|----------------------------------| | Pixel 1: | 0000 | | | Pixel 2: | 0000 | | | Pixel 3: | 0100 | Pixel 3 Latched to Test Register | | Pixel 4: | 0000 | | | | | | | | | | | Pixel n-1: | 1011 | | | Pixel n: | 1111; | Pixel n Latched to Test Register | | Pixel $n+1$ : | 1111 | | In the above sequence of pixels, there is a rising edge on P2 on Pixel 3. The data for Pixel 3 therefore gets latched into the Pixel Test Register. Pixel 3 continues down the graphics pipeline and after a number of clocks gets latched into the DAC Test Register. This data can then be read from the Pixel Test Register and the DAC Test Registers over the MPU Port. This data will remain in the Pixel Test Registers and the DAC Test Registers until the next rising edge of P2 causes new data to be latched in. In the above example, the next rising edge of P2 occurs on the Pixel n input. Therefore the data in the Pixel Test Registers and DAC Test Registers must be read over the MPU before the Pixel n data is applied, otherwise they will be overwritten by the Pixel n data and the Pixel 3 data will be lost. #### Pixel Test Register The read-only Pixel Test Register is 8 bits wide. It is situated directly after the Pixel Mask Register. After data is latched into this register by a transition on P2, it is read in three cycles over the MPU Port as described in the "Microprocessor (MPU) Port" section. #### **DAC Test Register** The DAC Test Register is latched with data some CLOCKs after the Pixel Test Register. The DAC Test Register is a 30-bit wide read-only register, corresponding to 10 bits each for red, green and blue data. It is located after the Color Palette RAM. If the RAM-DAC is in 8-bit resolution mode, the upper two bits of the red green and blue data will be zero. After data is latched into the DAC Test Register by a transition on P2, it is read in three or six cycles over the MPU Port as described in the "Microprocessor (MPU) Port" section. #### SYNC, BLANK and I<sub>PLL</sub> Test Register This is an 8-bit wide register but with only three effective bits. The three lower bits correspond to $\overline{SYNC}$ , $\overline{BLANK}$ and $I_{PLL}$ respectively. The upper bits should be masked in software. This register is at the same position in the graphics pipeline as the DAC Test Register. When pixel data is latched into the DAC Test Register, the corresponding status of $\overline{SYNC}$ , $\overline{BLANK}$ and $I_{PLL}$ is latched into this register. It is read over the MPU Port as described in the "Microprocessor (MPU) Port" section. (Note: If BLANK is low, the corresponding pixel data to the DAC Test Register will be all "0s".) # APPENDIX 7 THERMAL AND ENVIRONMENTAL CONSIDERATIONS The ADV7151 is a very highly integrated monolithic silicon device. This high level of integration, in such a small package, inevitably leads to consideration of thermal and environmental conditions in which the ADV7151 must operate. Reliability of the device is significantly enhanced by keeping it as cool as possible. In order to avoid destructive damage to the device, the absolute maximum junction temperature of 150°C must never be exceeded. Certain applications, depending on pixel data rates, may require forced air cooling or external heatsinks. The following data is intended as a guide in evaluating the operating conditions of a particular application so that optimum device and system performance is achieved. It should be noted that information on package characteristics published herein may not be the most up to date at the time of reading this. Advances in package compounds and manufacture will inevitably lead to improvements in the thermal data. Please contact your local sales office for the most up to date information Rower Dissipation The diagram shows graphs of power dissipation in warts versus pixel clock frequency for the ADV7.51. <sup>\*</sup> THE "WORST CASE ON-SCREEN PATTERN" CORRESPONDS TO FULL SCALE TRANSITION ON EACH PIXEL VALUE FOR EVERY CLOCK EDGE (00H, FFH, 00H,...). THE "TYPICAL ON-SCREEN PATTERN" CORRESPONDS TO LINEAR CHANGES IN THE PIXEL INPUT (I.E., A BLACK TO WHITE RAMP). IN GENERAL, COLOR IMAGES TEND TO APPROXIMATE THIS CHARACTERISTIC. Typical Power Dissipation vs. Pixel Rate #### Package Characteristics The table of thermal characteristics shows typical information for the ADV7151 (100-Lead Plastic Power QFP) using various values of airflow. Junction to Case $(\theta_{\rm JC})$ . Thermal resistance for this particular part is: $\theta_{JC}$ (100-Lead Plastic Power QFP) = 1.0 °C/W (Note: $\theta_{JC}$ is independent of airflow.) Table A. Thermal Characteristics vs. Airflow | Air Velocity<br>(Linear feet/min) | 0<br>(Still Air) | 50 | 100 | 200 | |-----------------------------------|------------------|----|-----|-----| | $\theta_{IA}$ (°C/W) | | | | | | No Heatsink | 35 | 31 | 28 | 25 | | EG&G D10100-28 Heatsink | 32 | 28 | 25 | 22 | | Thermalloy 2290 Heatsink | 25 | 21 | 18 | 15 | The junction temperature of the device in a specific application is given by: $$T_{J} = T_{A} + P_{D} (\theta_{JC} + \theta_{CA})$$ (1) or $$T_{I} = T_{A} + P_{D} (\theta_{IA}) \tag{2}$$ where: $T_I = Junction Temperature of Silicon (°C)$ $T_A = Ambient Temperature (°C)$ $P_0 = /Power Dissipation (W)$ $\theta_{IC} \neq J$ Junction to Case Thermal Resistance (°C/W) CA = Case to Ambient Therma Resistance (°C/W) $\theta_{IA} = \text{Junction to Ambient Thermal Resistance}$ (°) Package Enhancements The standard OFP package has been enhanced to a Power Qualize package. This supports an improved thermal performance compared to standard QFP. In this case, the die is attached to a heatslug so that the power that is dissipated can be conducted to the external surface of the package. This provides a highly efficient path for the transfer of heat to the package surface. The package configuration also provides an efficient thermal path from the ADV7151 to the Printed Circuit Board via the leads. #### Heatsinks The maximum silicon junction temperature should be limited to $100^{\circ}$ C. Temperatures greater than this will reduce long term device reliability. To ensure that the silicon junction temperature stays within prescribed limits, the addition of an external heatsink may be necessary. Heatsinks, will reduce $\theta_{JA}$ as shown in the "Thermal Characteristics vs. Airflow" table. #### **APPENDIX 8** #### PACKAGE OUTLINE DIMENSIONS Dimensions shown in inches and (mm). #### 100-Lead Plastic Quad Flatpack S-100