# TMC22090/22091 TMC22190/22191 # Digital Video Encoders / Layering Engine The TMC22X9X digital video encoders convert digital computer image or graphics data (in RGB, YC<sub>B</sub>C<sub>R</sub>, or color indexed format or a CCIR-601 signal into a standard analog baseband television (NTSC or PAL) signal with a modulated color subcarrier. PAL-M and NTSC without pedestal are also available from the TMC22091/191. Both composite (single lead) and S-VIDEO (separate chroma and luma) formats are active simultaneously at the three analog output pins, each of which generates a standard video-level signal into doubly-terminated $75\Omega$ load. The TMC22X9X accepts digitized video from the companion TMC22070 Genlocking Video Digitizer. Soft switching between video sources is done under either hardware or programmable data level control. The TMC22190/191 offers a 4-layer keying capability, bypassable CLUTs, and 30 overlay colors. The TMC22X9X is fabricated in a submicron CMOS process and packaged in 84-lead PLCCs. Performance is guaranteed from 0°C to 70°C. Logic Symbol ### **Features** - ◆ All digital video encoding - ◆ Internal digital oscillators, no crystals required - Multiple input formats supported - Input formats supported - 24-bit and 15-bit GBR/RGB - YCBCR422 or 444 - Color indexed - 30 overlay colors (TMC22190/191) - Fully programmable timing - ♦ Supports input pixel rates of 10 to 15 Moos - 256 x 8 x 3 color look-up tables (bypassable on TMC22190/191) - ♦ 8-bit mask register - ◆ 8-bit composite digital video input - Hardware and 24-bit data keving - Synchronizes with TMC22070 genlocking video digitizer - 8:8:8 video reconstruction - SMPTE 170M NTSC or CCIR report 624 PAL compatible - TMC22091/191 also supports PAL-M and NTSC without pedestal - ♦ Simultaneous S-VIDEO (Y/C) NTSC/PAL output - 10-bit D/A conversion (three channels) - Controlled edge rates - 3 power-down modes - Built-in color bars and modulated ramp test signals - ◆ JTAG (IEEE Std 1149.1-1990) test interface - Single +5V power supply - ♦ 84-lead PLCC package # Contents | General Description | | |-------------------------------|-------| | 22X9X Part Comparison Table | 27 | | Pixel Data Input Formats | 30 | | Pin Functions | 31 | | Package Interconnection Table | 33 | | Control Registers | 36 | | A <sub>1-0</sub> Functions | 37 | | Control Register Map | 37 | | Control Register Defintions | 38-39 | | Color Look-up Tables | 40-48 | | TCBCR422 Pixel Data Sequence | | | Gamma Correction | 51 | | Video Timing Parameters | 51 | | Horizontal Programming | 52 | | Vertical Programming | 52 | | NTSC Field/Line Sequence | 53 | | PAL Field/Line Sequence | 54 | | PAL-M Field/Line Sequence | 56 | | Timing Parameters Table | | | VITS Signal Insertion | 60 | | Subcarrier Programming | | | SCH Phase Error Correction | 62 | | Video Test Signals | 62 | | Microprocessor Interface | | | Operational Timing | | | Reset Timing | | | Pixel Data Input Timing | | | Master Mode | 66 | |------------------------------------|-------| | Slave Mode | | | Genlock Mode | | | Internal and External PDC | | | Layering | 69-72 | | Layering Priority Table | 72 | | Hardware and Data Keying | 72 | | Table D, E, F | 73 | | Genlock Interface | 73 | | Internal Filters | 75 | | JTAG Test Interface | 76 | | Equivalent Input/Output Circuits | 78 | | Three-state Levels and Timing | 78 | | Absolute Maximum Ratings | 79 | | Operating Conditions | 80-81 | | Electrical Characteristics | 82 | | Switching Characterisitics | 83 | | System Performance Characheristics | 84 | | Typical performance Waveforms | 85-87 | | Application Notes | 88 | | External Analog Filters | 88 | | Grounding sTrategy | 89 | | PC Board Layout | 90 | | Read/Write Sequences | | | Pin Assignments | | | Package Drawing | | | Ordering Information | | #### **Functional Block Diagram** ## **General Description** The TMC22090/091/190/191 are totally-integrated fully-programmable digital video encoders with simultaneous composite and Y/C (S-VIDEO) outputs. The TMC22x9x video outputs are compatible with SMPTE 170M NTSC, CCIR Report 624 PAL, PAL-M, and NTSC without pedestal television standards. No external component selection or tuning is required. The encoders accept digital image data at the PD port in one of several formats, which are matrixed into luminance and chrominance components. The chrominance signals are modulated onto a digitally synthesized subcarrier. The luminance and chrominance signals are separately interpolated to twice the pixel rate, and converted to analog levels by 10-bit D/A converters. They are also digitally combined and the resulting composite signal is output by a third 10-bit D/A converter. This composite signal may be keyed (pixel rate switching) with a second composite digital video signal presented to the encoder. The output video frames may be internally timed by the TMC22x9x, synchronized with the external frame buffer, or slaved to the companion Genlocking Video Digitizer (TMC22070). All operational parameters are fully programmable over a standard microprocessor port. Table 1 shows the key features that distinguish the members of the TMC22x9x family. All of the information presented in this data sheet applies to all of the TMC22x9x unless otherwise noted. Statements, paragraphs, tables, and figures that apply to only one or two of the encoders will have notation specifying the applicable part number. ### **Timing** The encoder operates from a single clock at twice the system pixel rate. This frequency may be set between 20 MHz and 30 MHz (pixel rates of 10 Mpps to 15 Mpps). Within this range are included CCIR-601, D2 NTSC, and square-pixel formats, as Table 1. Comparing the TMC22x9x Encoders | Feature | 22090 | 22091 | 22190 | 22191 | |------------------------------------------------------|-------|-------|-------|-------| | OL <sub>4-0</sub> pixel inputs for 30 overlay colors | No | No | Yes | Yes | | Number of video layers supported | 2 | 2 | 4 | 4 | | BYPASS\ input for bypassing CLUTs | No | No | Yes | Yes | | Composite digital video from D <sub>7-0</sub> | Yes | Yes | Yes | Yes | | Luminance data from D <sub>7-0</sub> | No | Yes | No | Yes | | Luminance I/O processing | No | Yes | No | Yes | | Extended EH and SL intervals | No | Yes | No | Yes | | User-controllable SETUP | No | Yes | No | Yes | | Individual D/A power-down mode | No | Yes | No | Yes | | NTSC without SETUP | No | Yes | No | Yes | | PAL-M | No | Yes | No | Yes | well as a variety of computer-specific pixel rates. An array of programmable timing registers allows the software selection of all pertinent signal parameters to produce NTSC (with or without 7.5 IRE pedestal) and PAL, and PAL-M outputs. #### Input Formatting The input section accepts a variety of video and graphics formats, including 24-bit GBR and RGB, 15-bit GBR and RGB, YC<sub>B</sub>C<sub>R</sub>422, YC<sub>B</sub>C<sub>R</sub>444, and 8-bit color-indexed data (Figure 1a and 1b). The input section of the TMC22x9x includes a key comparator which monitors the pixel data port with three independent 8-bit comparators, and invokes a video key when the selected registers match the incoming data. #### Mask Register A Mask Register is provided which is logically ANDed with incoming color-index data to facilitate pixel animation and other special graphics effects. The Mask Register is ahead of the Data Key comparators and is enabled only when color-index input is selected. Mask Register programming and operation are similar to that of the 171/176 family of graphics RAMDACS. #### Color Lookup Table The Color Lookup Table (CLUT) is a 256 x 8 x 3 random-access memory, and provides means for offset, gain, gamma, and color correction in RGB and $YC_BC_R$ operating modes. It provides a full 24-bit color lookup function for color-index mode and can be loaded in the same manner, with the same data, as a standard VGA RAMDAC. #### ColorSpace Conversion Matrix and Interpolator The matrix converts RGB data (whether from RGB inputs or color-indexed CLUT data) into Y, B-Y, R-Y format for encoding. In input configurations where the pixel input is already in Y, B-Y, R-Y format, the matrix is bypassed. When pixel data is input in $YC_BC_R422$ format, the interpolation filters produce $YC_BC_R444$ for encoding. #### Sync Generator The TMC22x9x can operate in Master, Genlock, or Slave modes. In Master and Genlock modes, the encoder internally generates all timing and sync signals, and provides Horizontal Sync, Vertical Sync, and Pixel Data Control (PDC) to the external frame buffer circuitry. PDC is independently selectable to function as an input or an output. In Genlock mode, the TMC22x9x timing is controlled by the TMC22070 Genlocking Video Digitizer over the CVBS<sub>7-0</sub> bus, GVSYNC\, and GHSYNC\. The Figure 1a. Pixei Data Format Figure 1b. Pixel Data Format (TMC22190/191 when CLUTs are Bypassed) encoder, in turn, produces VHSYNC\, VVSYNC\, and PDC for the frame buffer interface. In Slave mode, VHSYNC\, VVSYNC\, and PDC (optional) are inputs to the TMC22x9x, and determine when new lines, frames, and active picture areas begin. It becomes the responsibility of the external controlling circuitry to establish the correct timing for these signals. Horizontal and vertical synchronization signals are digitally generated by the TMC22x9x with controlled rise and fall times on all sync edges, the beginning and end of active video, and the burst envelope. All elements of horizontal sync timing are programmable, as are the frequency, phase, and duration of color burst. #### Video Input The TMC22x9x accepts genlocked synchronization data and digital composite video signals from the TMC22070 Genlocking Video Digitizer over the 8-bit CVBS bus. The encoder synchronizes its digital subcarrier oscillator to the video input from the TMC22070 with this data. The composite video data output from the TMC22070 is passed on to the internal video switch for keying with the encoded pixel data. #### **Chroma Modulator** A 32-bit digital subcarrier synthesizer feeds a quadrature modulator, producing a digital chrominance signal. The relative phases of the burst and active video portions of the subcarrier can be individually adjusted to compensate for external phase errors and to effect a hue control. #### Interpolation Filters Interpolation filters on the luminance and chrominance signals double the pixel rate in preparation for D/A conversion. This band-limited process greatly simplifies the output filtering required following the D/A converters and dramatically reduces $\sin(x)/x$ distortion. An interpolation filter on the CVBS data similarly raises the sample rate of the video signal, for mixing with the encoded pixel data. #### Composite Video Switch The Composite Video Switch selects between the composite video input (CVBS) and the composite encoded pixel data on a pixel-by-pixel basis, under the control of a key function. Keying may be managed by hardware or software. The hardware key input (KEY pin) directly controls the video switch. The encoder may be programmed to operate with a data key, represented by three 8-bit registers that compare with the 24 input bits. They operate in all input modes and may be individually enabled or disabled. #### D/A Converters The analog outputs of the TMC22x9x are the outputs of three 10-bit D/A converters, operating at twice the pixel clock rate. The outputs are capable of driving standard video levels into a doubly-terminated $75\Omega$ coaxial video cable (37.5 $\Omega$ total load). An internal voltage reference is provided which can be used to provide reference current for the three D/A converters. For accurate video levels, an external fixed or variable voltage reference source is recommended. The video signal levels from the TMC22x9x may be adjusted to overcome the insertion loss of analog low-pass output filters. The D/A converters on the TMC22091/191 may be powered-down via Control Register 0E bits 5 and 6. The COMPOSITE D/A is controlled by bit 6 and the LUMA and CHROMA D/A converters are controlled by bit 5. #### Microprocessor Interface The microprocessor interface employs a 13 line format. The RESET\ pin sets all internal state machines to their initialized conditions, disables the analog outputs, sets the internal SRESET\ bit LOW (reset condition), and places the encoder in a power-down mode. All register and CLUT data are maintained while in power-down mode. Returning the RESET\ pin HIGH synchronizes the internal pixel clock. If the HRESET bit is set HIGH, line 1 field 1 is started when RESET\ goes HIGH, and SRESET\ is ignored. If HRESET is LOW, the encoder remains idle after RESET\ goes HIGH until Control Register bit SRESET\ is set HIGH, which initiates line 1 field 1. Two address lines are provided and decoded for access to the internal control registers, and CLUT. Controls and CLUT are reached by loading a desired address through the 8-bit D<sub>7-0</sub> port, followed by the desired data (read or write) for that address. Both the CLUT and the control registers are self-indexing, allowing continuous reads or writes to successive addresses. #### JTAG Test Interface The TMC22x9x includes a standard 4-line JTAG (IEEE Std 1149.1-1990) test interface port, providing access to all digital input/output data pins. This is provided to facilitate component and board-level testing. #### Test/Validation Mode The TMC22x9x may be configured to produce standard color bars or a 40 IRE modulated (or unmodulated) video ramp, independent of any pixel or video data input. Color bars are useful as an idle system output signal. The test signals may be employed to verify proper operation of the analog video signal chain. #### **Pin Functions** The pins may be divided into nine categories: - 1. Clocks - 2. Frame Buffer Interface - 3. Genlock Interface - Microprocessor Interface - Video Outputs - Analog Interface - 7. JTAG Test Interface - Power and Ground - Factory test (22090/091) #### Clocks **PXCK** This 20 to 30 MHz clock is internally divided by 2 to generate the internal pixel clock, PCK, which a LOW on RESET\ forces LOW. PXCK drives the entire TMC22x9x, except the asynchronous microprocessor interface and the semi-synchronous LDV data input clock. All internal registers are strobed on the rising edge of PXCK. LDV On each rising edge of LDV, data on PD<sub>23-0</sub> are latched into the input preload register, for transfer into the input demultiplexer on the next rising edge of PCK. #### Frame Buffer Interface PD<sub>23-0</sub> In YC<sub>R</sub>C<sub>R</sub>, GBR, RGB, and colorindexed pixel data enter the TMC22x9x on PD<sub>23-0</sub>. The specific format is found in Figures 1a and 1b. LDV is the clock that controls the loading of pixel data. VHSYNC\ In Master and Genlock modes, the TMC22x9x outputs horizontal sync on this pin. In Slave modes, the TMC22x9x accepts and locks to horizontal sync input on this pin (with vertical sync on VVSYNC\). VHSYNC\ and VVSYNC\ must be coincident such that they are clocked into the TMC22x9x on the same rising edge of PXCK. VVSYNC\ In two-line (separate V and H sync signals) Master and Genlock modes, the TMC22x9x outputs vertical block sync (VVSYNC\ LOW for the 2.5 (PAL) or 3 (NTSC) lines on which vertical sync pulses occur). In composite sync (H and V sync on same signal) Master and Genlock modes, the TMC22x9x outputs horizontal sync, vertical sync, and equalization over this pin. In Slave mode, the TMC22x9x accepts and locks to vertical sync input on this pin (with horizontal sync on VHSYNC\). VHSYNC\ and VVSYNC\ must be coincident such that they are clocked into the TMC22x9x on the same rising edge of PXCK. PDC In Master mode, the TMC22x9x forces PDC HIGH when and only when it wants active video from the frame buffer. During blanking (syncs, equalization, burst, and porches), it forces PDC LOW, signalling that it will ignore any data presented over PD<sub>23-0</sub>. When PDC is used as an input, forcing it HIGH puts the TMC22x9x into the active video state. Forcing PDC LOW leaves blank and burst unaffected, but forces the TMC22x9x to output black burst. **KEY** When the HKEN control bit is set HIGH and hardware key pin, KEY, is HIGH, video data entering on CVBS<sub>7-0</sub> are routed to the COMPOSITE output. This control signal is pipelined so the pixel that is presented to the PD port when the KEY signal is invoked is at the midpoint of the soft key transition. When HKEN is LOW, KEY is ignored. Like PD data, KEY is clocked into the TMC22x9x on the rising edge of LDV. OL<sub>4-0</sub> (22190) (22190) 30 of the 256 locations of the CLUTs may be reserved for overlay operation. These CLUT locations are directly accessed by five input pins, $OL_{4-0}$ . $OL_{4-0}$ are entered into the TMC22190 on a pixel-by-pixel basis and select which of the 30 overlay colors is to be encoded. When all five $OL_{4-0}$ inputs are LOW, no overlay occurs. BYPASS\ (22190) (22191) When BYPASS\ is HIGH, the CLUTs are in the pixel data path within the TMC22190/191. When BYPASS\ is LOW, pixel data bypasses the CLUTs. BYPASS\ is active only for certain modes of the Layering Control Register (LCR) when the Format Control Register bit 6 is HIGH. #### Genlock Interface GHSYNC\ In Genlock mode, the TMC22x9x will start a new horizontal line (blank-to-sync-edge transition) with each falling edge of GHSYNC\. In non-genlock modes, the TMC22x9x ignores GHSYNC\. The internal pixel clock, PCK, is aligned with the falling edge of VHSYNC\ or GHSYNC\ (Genlock mode). GVSYNC\ In Genlock mode, the TMC22x9x will start a new vertical sync sequence at line 1 field 1 whenever GVSYNC\ and GHSYNC\ are coincident such that they are clocked into the TMC22x9x on the same rising edge of PXCK. If GVSYNC\ falls at any other time, the TMC22x9x will assume that this marks the start of field 2, and will ignore it (in odd-field sync mode) or (in all-field sync mode) respond by generating a single vertical sync pulse, followed by 2 (PAL) or 2.5 (NTSC) lines of vertical sync, keyed to the next falling edge on GHSYNC\. See Interface Control Register bit 0 for odd-field and all-field operation. CVBS<sub>7-0</sub> The encoder receives digitized video, subcarrier phase, and subcarrier frequency over this 8-bit bus at the PCK rate. This data may be provided by the companion TMC22070 Genlocking Video Digitizer. In Genlock mode, the TMC22x9x expects subcarrier phase and frequency data during each line's horizontal sync interval, as well as video data when keying is engaged, transferred at the PCK rate. #### Microprocessor Interface D<sub>7-0</sub> All control parameters are loaded into and read back over this 8-bit port. For digital testing, the five lower bits can also serve as a two-cycle 10-bit data output port. For D/A converter testing. it can be used as a 10-bit two-cycle input port, facilitating, for example, ramp-based D/A converter linearity tests. As in a RAMDAC, this control governs A<sub>1-0</sub> whether the microprocessor interface selects a table address or reads/writes table contents. It also governs setting and verification of the TMC22x9x's internal operating modes, also over port D<sub>7-0</sub>. CS\ When CS\ is HIGH, the microprocessor interface port, D7-0, is set to HIGH impedance and ignored. When CS\ is LOW, the microprocessor can read or write parameters over D7-0. One additional falling edge of CS\ is needed to move input data to its assigned working registers. R/W\ When R/W\ and CS\ are LOW, the microprocessor can write to the control registers or CLUT over D<sub>7-0</sub>. When R/W\ is HIGH and CS\ is LOW, it can read the contents of any CLUT address or control register over D<sub>7-0</sub>. RESET\ Bringing RESET\ LOW sets the software reset control bit. SRESET\. LOW, forcing the internal state machines to their starting states and disabling all outputs. Bringing RESET\ HIGH synchronizes the internal pixel clock (PCK = PXCK / 2) to maintain a defined pipeline delay through the TMC22x9x. If HRESET is set HIGH, the encoder is enabled when RESET\ goes HIGH. If HRESET is LOW, the host restarts the TMC22x9x by setting SRESET\ HIGH. RESET\ does not affect the CLUT or the control registers, except SRESET\. ### Video Output COMPO-Analog output of composite D/A SITE converter, nominally 1.35 volt peak-topeak into a 37.5 $\Omega$ load. LUMA Analog output of luminance D/A converter, nominally 1.35 volt peak-topeak into a $37.5\Omega$ load. CHROMA Analog output of chrominance D/A converter, nominally 1.35 volt peak-topeak into a 37.5 $\Omega$ load. ### **Analog Interface** VRFF External voltage reference input. internal voltage reference output, nominally 1,235 V. COMP Connection point for 0.1uf decoupling capacitor. Connection point for external current-RREE setting resistor for D/A converters. The resistor (392 $\Omega$ ) is connected between R<sub>REF</sub> and A<sub>GND</sub>. Output video levels are inversely proportional to the value of RREF. #### **JTAG Test Interface** TDI Boundary scan data input port. Boundary scan (HIGH)/normal TMS operation (LOW) selector. TCK Boundary scan clock. TDO Boundary scan data output port. #### **Power Supply** Positive digital power supply. $V_{DD}$ $V_{DDA}$ Positive analog power supply. Digital Ground. DGND Analog Ground. AGND #### **Test** TEST Reserved for factory testing. These (22090)pins have no effect on the operation (22091)but do function as JTAG registers. They should be grounded directly or pulled down to ground with $1k\Omega$ or smaller resistors. Table 2. Package Interconnections | Signal Type | Name | Function | Value | Package Pin | |------------------|----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--------------------------------------------------------| | Clocks | PXCK | Master Clock Input | TTL | 79 | | | LDV | Pixel Data Load Clock | TTL | 78 | | Frame Buffer I/O | PD <sub>23-0</sub><br>VHSYNC\<br>VVSYNC\<br>PDC<br>KEY<br>OL <sub>4-0</sub><br>BYPASS\ | Pixel Data Inputs Horizontal Sync I/O Vertical Sync I/O Pixel Data Control Hardware Key Input Overlay Data Inputs (22190/191) CLUT Bypass Control (22190/191) | TTL<br>TTL<br>TTL<br>TTL<br>TTL<br>TTL | 52-63, 66-77<br>12<br>13<br>11<br>4<br>29, 48-51<br>28 | | Genlock I/O | GHSYNC\ | Genlock Horizontal Sync | CMOS | 83 | | | GVSYNC\ | Genlock Vertical Sync | CMOS | 82 | | | CVBS <sub>7-0</sub> | Composite Video Inputs | TTL | 44-47, 84, 1-3 | | μProc I/O | D <sub>7-0</sub><br>A <sub>1-0</sub><br>CS\<br>RESET\<br>R/W\ | Data I/O Port<br>μProc Port Controls<br>Chip Select<br>Master Reset Input<br>Bus Read/Write Control | TTL<br>TTL<br>TTL<br>TTL | 14-21<br>8-9<br>6<br>5<br>7 | | Video Output | COMPOSITE | NTSC/PAL Video | 1 V P-P | 33 | | | LUMA | Luminance-only Video | 1 V P-P | 35 | | | CHROMA | Chrominance-only Video | 1 V P-P | 37 | | Reference | V <sub>REF</sub> | Voltage Reference Input | +1.23 V | 30 | | | COMP | Compensation Capacitor | 0.1 μF | 39 | | | R <sub>REF</sub> | Current-setting Resistor | 392 Ω | 31 | | JTAG I/O | TDI | Data Input Port | TTL | 25 | | | TMS | Scan Select Input | TTL | 24 | | | TCK | Scan Clock Input | TTL | 23 | | | TDO | Data Output Port | TTL | 22 | | Power | V <sub>DDA</sub> | Analog Power Supply | +5 V | 40-43 | | | V <sub>DD</sub> | Digital Power Supply | +5 V | 27, 64, 81 | | Ground | A <sub>GND</sub> | Analog Ground | 0.0 V | 32, 34, 36, 38 | | | D <sub>GND</sub> | Digital Ground | 0.0 V | 10, 26, 65, 80 | | Test | TEST | Factory testing (22090/091) | 0.0 V | 28, 29, 48-51 | ### **Control Registers** The TMC22x9x is initialized and controlled by a set of registers which provide a high degree of control over the TMC22x9x's operating parameters. The registers are organized into 13 categories: - 1. Global Control - 2. Format Control - 3. Interface Control - 4. Test Control - 5. Key Control - 6. Misc. Control (22091/191) - 7. Standards Control (22091/191) - 8. Layering Control (22190/191) - 9. Key Value - 10. Timing - 11. Subcarrier - 12. Test I/O - 13. Mask Register An external controller loads the Control Registers through a standard interface port. It also loads the CLUT and verifies (reads) its contents or those of the Control Registers. The port is governed by pins CS\, R/W\, and $A_{1-0}$ . The Address Register for the CLUT and the Control Register pointer automatically increment to allow successive writes to sequential addresses. In the CLUT, the Address Register has two additional bits which increment in modulo-three to sequentially access the red, green, and blue portions. All three colors must be written when any CLUT address is changed. The control register autoincrement follows the sequence indicated in the Control Register Map. When it reaches address 40, it stops incrementing, allowing multiple reads or writes of test data from/to the TESTDAT register. To exit the test mode, reset the Control Register pointer by setting $A_{1-0}$ , $D_{7-0}$ , and R/W\ LOW and then bring CS\ LOW. Address 1F is a read-only status register. It is addressed by the autoincrement sequencer. Any data may be written into this port at that time but it will not be stored. When address 50 is accessed, no autoincrement takes place, allowing multiple writes to the Mask Register. Table 3. Microprocessor Port Control | A <sub>1-0</sub> | R/W\ | Action | |------------------|------|-------------------------------------------------------| | 00 | 0 | Load D <sub>7-0</sub> into Control Register pointer. | | 00 | 1 | Read Control Register pointer on D <sub>7-0</sub> . | | 01 | 0 | Load D <sub>7-0</sub> into CLUT Address Register. | | 01 | 1 | Read CLUT Address Register on D <sub>7-0</sub> . | | 10 | 0 | Write D <sub>7-0</sub> to addressed Control Register. | | 10 | 1 | Read addressed Control Register on D <sub>7-0</sub> . | | 11 | 0 | Write D <sub>7-0</sub> to addressed CLUT location. | | 11 | 1 | Read addressed CLUT location on D <sub>7-0</sub> . | Table 4. Control Register Map | Reg | Bit | Mnemonic | Function | Reg | Bit | Mnemonic | Function | |----------------|---------------|----------------------------|-----------------------------------------------------------------------------------------------------------|----------------|-------------------|----------------------------|------------------------------------------------------------------------------------------------------------------| | | | | Global Control Register | 04<br>04 | 4<br>3-1 | SKEXT<br>LAYMODE | Data key operation select<br>LSBs of Layer Assignments | | 00 | 7-5<br>4 | SRESET | (reserved)<br>Software reset | 04 | 0 | SKEN | select<br>Data key enable | | 00<br>00 | 3 | PAL<br>LUMDIS | Standard select, NTSC or PAL Luminance input disable | | | | Key Value Registers | | 00<br>00 | 0 | CHRDIS<br>HRESET | Chrominance input disable Software reset disable | 05<br>06 | 7-0<br>7-0 | DKEY | Green/red/Y data key value<br>Blue/green/C <sub>B</sub> data key value<br>Red/blue/C <sub>B</sub> data key value | | | _ | | Format Control Register | 07 | 7-0 | FKEY | | | 01<br>01 | 7<br>6 | LCREN | (reserved) Layering Control Register enable (22190/191) | 08-00 | | | (reserved) Misc. Control Register | | 01<br>01 | 5<br>4 | RAMPEN<br>CB\ | Modulated ramp test Color bar test | OE. | 7 | EEEN | | | 01<br>01 | 3-2<br>1-0 | FORMAT<br>INMODE | PD <sub>23-0</sub> input format select<br>PD <sub>23-0</sub> input mode select | 0E<br>0E | 6<br>5 | EFEN<br>COMPD/A<br>SVIDD/A | Register 0E and 0F enable<br>COMPOSITE D/A disable<br>LUMA/CHROMA D/A disable | | | | | Interface Control Register | OE<br>OE<br>OE | 3 2 | FKREN<br>RATIO<br>TFLK | Luminance processing enabled<br>Luminance ratio select<br>Luminance pass threshold select | | 02<br>02<br>02 | 7<br>6<br>5-4 | VITSEN<br>SHCY<br>TBASE | VITS lines enable<br>Short-cycle test mode<br>Time-base source select | 0E<br>0E | 0 | T512<br>CB100 | EH/SL offset select<br>NTSC/PAL Color Bars | | 02<br>02 | 3<br>2 | SOUT<br>FBDIS | Sync output mode select<br>Frame buffer signals disable | | | | Standards Control Register | | 02<br>02 | 1 | PDCDIR<br>FLDLK | PDC master, slave select<br>Field lock select | OF | 7 | EFEN | Same as Reg 0E bit 7 but read-<br>only | | | | | Test Control Register | OF<br>OF<br>OF | 6<br>5<br>4 | SIX25<br>PALID<br>SETUP | 625/525 line per frame select Phase alternate line select 7.5 IRE Pedestal Enable | | 03<br>03 | 7 | LIMEN | (reserved)<br>Luminance limiter enable | 0F<br>0F | 3-2<br>1-0 | YGAIN<br>CGAIN | Luminance gain settings Chrominance gain settings | | 03<br>03<br>03 | 5<br>4<br>3 | TESTEN<br>HOLDEN<br>TSTMSB | Test enable<br>MSBs/LSBs hold select<br>LSBs, MSBs in/out select | | | | Timing Registers | | 03<br>03 | 2 | LUMTST<br>8FSUBR | LUMA channel test<br>8-field subcarrier reset enable | 10<br>11 | 7-0<br>7-0 | SY<br>BR | Horizontal sync tip length<br>Breezeway length | | 03 | 0 | CHRTST | CHROMA channel test Key Control Register | 12<br>13<br>14 | 7-0<br>7-0<br>7-0 | BU<br>CBP<br>XBP | Burst length Color back porch length | | 04 | 7 | | (reserved) | 15<br>16 | 7-0<br>7-0<br>7-0 | VA<br>VC | Extended color back porch 8 LSB<br>Active video 8 LSB<br>Active video start 8 LSB | | 04<br>04 | 6<br>5 | HKEN<br>BUKEN | Hardware key enable<br>Burst key enable | 17 | 7-0<br>7-6 | VB<br>XBP | Active video end 8 LSB Extended color back porch 2 MSB | | 04<br>04 | 4<br>3 | SKEXT<br>DKDIS | Data key operation select<br>Green/red/Y data key disable | 18<br>18 | 5-4<br>3-2 | VA<br>VC | Active video 2 MSB Active video start 2 MSB | | 04<br>04<br>04 | 1 0 | EKDIS<br>FKDIS<br>SKEN | Blue/green/C <sub>B</sub> data key disable<br>Red/blue/C <sub>R</sub> data key disable<br>Data key enable | 18<br>19<br>1A | 1-0<br>7-0<br>7-0 | VB<br>FP<br>EL | Active video end 2 MSB Front porch length Equalization pulse LOW length | | J-7 | | 31 to 14 | Layering Control Register (22190/191) | 1B<br>1C<br>1D | 7-0<br>7-0<br>7-0 | EH<br>SL<br>SH | Equalization pulse HIGH length<br>Vertical sync LOW length<br>Vertical sync HIGH length | | 04<br>04 | 7<br>6 | LAYMODE<br>HKEN | MSB of Layer Assignments select<br>Hardware key enable | 1E<br>1F<br>1F | 7-0<br>7-5<br>4-0 | CBL<br>FIELD<br>LTYPE | Color bar length Field identification Line type identification | | 04 | 5 | BUKEN | Burst key enable | | | | | Notes: - Functions are listed in the order used for reading and writing. - 2. For each register listed above, all bits not listed are reserved and should be set to zero to ensure proper operation. - The meaning of Register 04 (Key Control Register/Layering Control Register) is determined by Format Control Register bit 6 (22190/191) Table 4. Control Register Map (continued) | Reg | Bit | Mnemonic | Function | |----------|------------|------------------|--------------------------------------------------------------------| | | | | Subcarrier Registers | | 20 | 7-0 | FREQL | Subcarrie frequency 4th byte | | 21<br>22 | 7-0<br>7-0 | FREQ3<br>FREQ2 | (LSBs) Subcarrier frequency 3rd byte Subcarrier frequency 2nd byte | | 23 | 7-0 | FREQM | Subcarrier frequency 1st byte (MSBs) | | 24<br>25 | 7-0<br>7-0 | SYSPHL<br>SYSPHM | Video phase offset LSBs<br>Video phase offset MSBs | | 26<br>27 | 7-0<br>7-0 | BURPHL<br>BURPHM | Burst phase offset LSBs<br>Burst phase offset MSBs | | 28-3F | | | (reserved) | | | | | Test I/O Register | | 40 | 7-0 | TESTDAT | Test data input/output | | | | | Mask Register | | 50 | 7-0 | MASK | Mask register | | İ | | | Y-Component Register | | 60 | 7-0 | Y | Y-comportent input/output | | | | l | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | • | | | | | | | | | | | | | 1 | | | | # **Control Register Definitions** | Reg | Bit | Mnemonic | Function | |-----|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | Global Control Register | | 00 | 7-5 | | (reserved) | | 00 | 4 | SRESET | Software reset. When LOW, resets and holds internal state machines and disables outputs. When HIGH (normal), starts and runs state machines and enables outputs. | | 00 | 3 | PAL | Video standard select. When LOW, the NTSC standard is generated with 7.5 IRE pedestal. When HIGH, PAL standard video is generated. In the TMC22091/191, this bit is ignored if Register 0E bit 7 is HIGH, enabling the 0E and 0F registers. | | 00 | 2 | LUMDIS | Luminance input disable. When LOW (normal), luminance (Y) data from external frame buffer is enabled. When HIGH, luminance (Y) data into the TMC22x9x is forced to 0 IRE but sync pulses continue from the LUMA output. | | 00 | 1 | CHRDIS | Chrominance input disable. When LOW (normal), burst and frame buffer data into the TMC22x9x are enabled. when HIGH, burst and frame buffer data are suppressed, enabling monochrome operation. | | 00 | 0 | HRESET | Software reset enable.<br>SRESET is forced LOW<br>when the RESET\ pin is | | Reg | Bit | Mnemonic | Function | |-----|-----|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | taken LOW. State machines are reset and held. When HRESET is LOW, RESET\ may be taken HIGH at any time. The TMC22x9x is enabled and a new frame is begun with line 1, field 1 on the next PXCK after SRESET is set HIGH. The D/A converters are powered down while RESET\ is LOW. When HRESET is HIGH, a new frame is begun with line 1, field 1 on the next PXCK after RESET\ is taken HIGH. SRESET is ignored. The D/A converters remain active during the reset sequence. | | 01 | 7 | | Format Control Register (reserved) | | 01 | 6 | LCREN<br>(22190)<br>(22191) | Layering Control Register enable. When LOW, the Layering Control Register is not available and Key Control Register functions are enabled. In this mode, the TMC22190/191 functions like the TMC22090/091. When HIGH, the Layering Control Register takes the place of the Key Control Register and enables the layering functions. Data loaded into the Key or Layering Control Registers will remain but have a different meaning if this bit is changed. | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 01 | 5 | RAMPEN | Modulated ramp test. When LOW (normal), the TMC22x9x encodes and outputs video corresponding to input data. When RAMPEN and CB\ are both HIGH, an internally generated 40 IRE modulated ramp is produced, preempting input data. | | 01 | 4 | CB/ | Color bar test. When HIGH (normal), the TMC22x9x encodes and outputs video corresponding to input data. When CB RAMPEN, and Format Control Register bit 0 are LOW, internally generated color bars are produced, preempting input data. | | 01 | 3-2 | FORMAT | PD <sub>23-0</sub> input format select. Two bits select RGB, GBR, or YC <sub>B</sub> C <sub>R</sub> input data. When bits 3 and 2 are: 00, the CLUT output is interpreted as RGB and is converted to YC <sub>B</sub> C <sub>R</sub> . 10, the CLUT output is interpreted as GBR, and is converted to YC <sub>B</sub> C <sub>R</sub> . 11, the CLUT output is interpreted as YC <sub>B</sub> C <sub>R</sub> . 11, the CLUT output is interpreted as YC <sub>B</sub> C <sub>R</sub> . 01, is reserved Bits 3 and 2 must be 00 or 10 when the Layering Control Register is enabled (22190/191). | | 01 | 1-0 | INMODE | PD <sub>23-0</sub> input mode select.<br>These two bits set up the<br>TMC22x9x for either 444,<br>422, 15-bit, or 8-bit input | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | modes. 00, 24-bit/pixel GBR, RGB, or YC <sub>B</sub> C <sub>R</sub> 444 data enters from PD <sub>23-0</sub> 01, YC <sub>B</sub> C <sub>R</sub> 422 data enters from PD <sub>23-8</sub> ; C <sub>R</sub> and C <sub>B</sub> alternate from PD <sub>15-8</sub> 10, 15-bit/pixel GBR or RGB data from PD <sub>14-0</sub> 11, 8-bit/pixel color indexed data enters from PD <sub>7-0</sub> . Bits 1 and 0 must be 00, 01, or 11 when the Layering Control Register is enabled (22190/191). Interface Control Register | | 02 | 7 | VITSEN | VITS lines enable. When LOW, all UBB lines in the vertical interval are black burst regardless of input data. When HIGH, all UBB lines in the vertical interval become UVV active video and are dependent upon input data. | | 02 | 6 | SHCY | Short-cycle test mode.<br>When LOW, normal<br>operation is enabled. when<br>HIGH, EH (equalization<br>pulse HIGH length) and SL<br>(vertical sync LOW length)<br>are shortened by 256. | | 02 | 5-4 | TBASE | Time-base source select. These two bits set up the TMC22x9x for either genlock or frame buffer control of timing. When bits 5 and 4 are: 00, the encoder counts out its own time-base from input clock PXCK. | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | 01, the encoder locks to<br>synchronizing signals<br>from external genlock.<br>10, the encoder locks to<br>synchronizing signals<br>from frame buffer<br>controller. | | 02 | 3 | SOUT | Sync output mode select. When LOW, VHSYNC\ and VVSYNC\ output separate horizontal and vertical sync pulses. When HIGH, composite sync (H and V) is output on VVSYNC\ while horizontal sync is output on VHSYNC\. | | 02 | 2 | FBDIS | Frame buffer signals enable. When LOW, VVSYNC\ and VHSYNC\ outputs to frame buffer are enabled. When HIGH, VVSYNC\ and VHSYNC outputs to frame buffer are disabled. | | 02 | 1 | PDCDIR | PDC master/slave select. When LOW, PDC is an output where the encoder is requesting data from the frame buffer. When HIGH, PDC is an input, and directs the encoder to accept data from the frame buffer. | | 02 | 0 | FLDLK | Field lock select. When LOW, (in Slave mode) the encoder locks to each new field. When HIGH, the encoder locks to field 1 only. | | | | | Test Control Register | | 03 | 7 | | (reserved) | | | | T | | |-----|-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Reg | Bit | Mnemonic | Function | | 03 | 6 | LIMEN | Luminance limiter enable.<br>When LOW, all luminance<br>values are passed to<br>modulator. when HIGH,<br>luminance values are<br>limited to 101 IRE. | | 03 | 5 | TESTEN | Test enable. When LOW, normal operation is enabled. When HIGH, TESTDAT <sub>7-0</sub> (Register 40) is connected to the composite output (READ) and D/A converters (WRITE) for test. | | 03 | 4 | HOLDEN | MSBs/LSBs hold select. When LOW, alternates MSBs and LSBs in test, at PXCK rate. When HIGH, reads/writes only MSBS or LSBS in test (per TSTMSB, bit 3) | | 03 | 3 | TSTMSB | LSBS,MSBS hold select. When LOW, connects 2 LSBs to TESTDAT <sub>1-0</sub> for testing when TESTEN is HIGH. When HIGH, connects 8 MSBs to TESTDAT <sub>7-0</sub> for testing when TESTEN is HIGH. | | 03 | 2 | LUMTST | LUMA channel test. When LOW (normal), the luminance D/A converter is driven from luminance channel. When HIGH, the luminance D/A converter is driven from TESTDAT for testing when TESTEN is HIGH. | | 03 | 1 | 8FSUBR | 8-field subcarrier reset enable. When LOW, the internal subcarrier | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | generator is reset with frequency and phase data from FREQ, SYSPH, and BURPH registers every eight fields. When HIGH, the internal subcarrier generator free-runs on the basis of frequency and phase data from the last time it was reset. When RESET\ goes LOW, the subcarrier frequency and phase will be reset from FREQ, SYSPH, and BURPH after field 8. | | 03 | 0 | CHRTST | CHROMA channel test. When LOW (normal), the chrominance D/A converter is driven from chrominance channel. When HIGH, the chrominance D/A converter is driven from TESTDAT when TESTEN is HIGH. | | | ! | | Key Control Register | | 04 | 7 | | (reserved) | | 04 | 6 | HKEN | Hardware key enable.<br>When LOW, the KEY input<br>pin ignored. When HIGH,<br>the KEY input pin is<br>enabled. | | 04 | 5 | BUKEN | Burst key enable. When LOW, output video burst is generated on TMC22x9x. When HIGH, output burst is taken from genlock input data. | | 04 | 4 | SKEXT | Data key operation select.<br>When LOW, data keying is<br>allowed only during active<br>video. When HIGH, data | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | keying is allowed during active video and blanking. | | 04 | 3 | DKDIS | Green/red/Y data key disable. When LOW, green/red/Y input data is enabled for data keying. When HIGH, green/red/Y input data is ignored for data keying. This function is enabled when Layering Control Register is enabled (22190/191). | | 04 | 2 | EKDIS | Blue/green/C <sub>B</sub> data key disable. When LOW, Blue/green/C <sub>B</sub> input data is enabled for data keying. When HIGH, Blue/green/C <sub>B</sub> input data is ignored for data keying. This function is enabled when Layering Control Register is enabled (22190/191). | | 04 | 1 | FKDIS | Red/blue/C <sub>R</sub> data key disable. When LOW, red/blue/C <sub>R</sub> input data is enabled for data keying. When HIGH, red/blue/C <sub>R</sub> input data is ignored for data keying. This function is enabled when Layering Control Register is enabled (22190/191). | | 04 | 0 | SKEN | Data key enable. When LOW, data keying is disabled. When HIGH, data keying is enabled. | | | | | Layering Control Register (22190/191) | | 04 | 7 | LAYMODE | MSB of Layer Assignments select | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 04 | 6 | HKEN | Hardware key enable. When LOW, the KEY input pin ignored. When HIGH, the KEY input pin is enabled. | | 04 | 5 | BUKEN | Burst key enable. When LOW, output video burst is generated on TMC22190/191. When HIGH, output burst is taken from genlock input data. | | 04 | 4 | SKEXT | Data key operation select. When LOW, data keying is allowed only during active video. When HIGH, data keying is allowed during active video and blanking. | | 04 | 3-1 | LAYMODE | three LSBs of Layer<br>Assignments select | | 04 | 0 | SKEN | Data key enable. When LOW, data keying is disabled. When HIGH, data keying is enabled. | | | | | Key Value Registers | | 05 | 7-0 | DKEY | Green/red/Y data key value. Eight bits hold the match value which triggers keying on red/Y. | | 06 | 7-0 | EKEY | Blue/green/U data key<br>value. Eight bits hold the<br>match value which triggers<br>keying on green/U. | | 07 | 7-0 | FKEY | Red/blue/V key value.<br>Eight bits hold the match<br>value which triggers keying<br>on blue/V. | | | | | | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | Misc. Control Register<br>(22091/191) | | 0E | 7 | EFEN | Register 0E and 0F enable. When LOW, the functions of Register 0E and 0F are disabled. When HIGH, Registers 0E and 0F are active. When Registers 0E and 0F are enabled, Register 00 bit 3 is ignored. | | | | | For TMC22091/191,<br>Register 0E bit 7 will read<br>back whatever value was<br>written. For<br>TMC22090/190 Register 0E<br>bit 7 will only read back<br>LOW. | | 0E | 6 | COMPD/A | COMPOSITE D/A disable. When HIGH, the COMPOSITE D/A converter is powered-down. When LOW, the D/A is enabled. | | 0E | 5 | SVIDD/A | LUMA/CHROMA D/A disable. When HIGH, the LUMA and CHROMA D/A converters are powered- down. When LOW, they are enabled. | | 0E | 4 | FKREN | Luminance processing enable. When FKREN is HIGH, the KEY input defines the function of CVBS input data. When the KEY input is HIGH, CVBS data is keyed over PD input data. When KEY is LOW, CVBS data is assumed to be luminance data delayed by one field. | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | When FKREN is LOW, the KEY input operates normally, switching between CVBS and PD data. | | 0E | 3 | RATIO | Luminance ratio control bit. When LOW, 1/2 of current luminance and 1/2 of field delayed luminance from the CVBS input are added to yield a new combined luminance value. When RATIO is HIGH, 3/4 of current luminance is added to 1/4 of the delayed luminance to produce a new luminance value. | | 0E | 2 | TFLK | Luminarice-pass threshold. The difference between current luminance and delayed luminance (from the CVBS inputs) is compared against a preset threshold set by TFLK. When TFLK is LOW, the high threshold must be exceeded to trigger the combining of current and delayed luminance (according to RATIO). If the higher threshold is not exceeded, current luminance is passed without modification. | | | | | When TFLK is HIGH, a lower threshold is used to trigger the combining of current and delayed luminance. | | 0E | 1 | T512 | EH/SL offset control bit.<br>When LOW, the true value<br>of EH and SL is offset by | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | 256. When HIGH, the true value for EH and SL is offset by 512. | | 0E | 0 | CB100 | NTSC/PAL color bars<br>select. When HIGH, color<br>bars with 100% white level<br>are selected. When LOW,<br>color bars will have 75%<br>white level. | | | | | Standards Control<br>Register (22091/191) | | 0F | 7 | EFEN | Same as Register 0E bit 7, but read-only. | | 0F | 6 | SIX25 | Select 625 lines per frame.<br>When HIGH, the encoder<br>assumes 625 line per<br>frame. When LOW, 525<br>lines per frame are<br>assumed. | | OF | 5 | PALID | PAL select. When HIGH,<br>Phase alternate line (PAL)<br>operation is selected.<br>When LOW, operation<br>conforms to NTSC<br>standards. | | 0F | 4 | SETUP | Setup enable. When HIGH, a 7.5 IRE Pedestal is added to the output video. when LOW, no pedestal is added. | | 0F | 3-2 | YGAIN | Luminance gain settings<br>are adjusted to conform to<br>the following NTSC and<br>PAL standards:<br>00 NTSC without SETUP<br>01 NTSC-A and PAL-M<br>10 PAL-I and PAL-N<br>11 (reserved) | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0F | 1-0 | CGAIN | Chrominance gain settings are adjusted to conform to the following NTSC and PAL standards: 00 NTSC without SETUP 01 NTSC-A and PAL-M 10 PAL-I and PAL-N 11 (reserved) | | | | | Timing Registers | | 10 | 7-0 | SY | Horizontal sync tip length.<br>This 8-bit register holds a<br>value extending from 0 to<br>255 PCK cycles. | | 11 | 7-0 | BR | Breezeway length. This 8-<br>bit register holds a value<br>extending from 0 to 255<br>PCK cycles. | | 12 | 7-0 | BU | Burst length. This 8-bit register holds a value extending from 0 to 255 PCK cycles. | | 13 | 7-0 | СВР | Color back porch length.<br>This 8-bit register holds a<br>value extending from 0 to<br>255 PCK cycles. | | 14 | 7-0 | XBP | Extended color back porch 8 LSBs. This 8-bit register holds the LSBs of a 10-bit value extending from 0 to 1023 PCK cycles. The two MSBs are located in control register 18. | | 15 | 7-0 | VA | Active video 8 LSBs. This<br>8-bit register holds the<br>LSBs of a 10-bit value<br>extending from 0 to 1023<br>PCK cycles. The two<br>MSBs are located in control<br>register 18. | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 16 | 7-0 | vc | Active video start 8 LSBs. This 8-bit register holds the LSBs of a 10-bit value which is the initial half active video length extending from 0 to 1023 PCK cycles. The two MSBs are located in control register 18. | | 17 | 7-0 | VB | Active video end 8 LSBs This 8-bit register holds the LSBs of a 10-bit value which is the end half active video length extending from 0 to 1023 PCK cycles. The two MSBs are located in control register 18. | | 18 | 7-6 | XBP | Extended color back porch 2 MSBs. These two bits hold the MSBs of a 10-bit value extending from 0 to 1023 PCK cycles. The LSBs are located in control register 14. | | 18 | 5-4 | VA | Active video 2 MSB. These two bits hold the MSBs of a 10-bit value extending from 0 to 1023 PCK cycles. The LSBs are located in control register 15. | | 18 | 3-2 | vc | Active video start 2 MSBs. These two bits hold the MSBs of a 10-bit value which is the initial half active video length extending from 0 to 1023 PCK cycles. The LSBs are located in control register 16. | | 18 | 1-0 | VB | Active video end 2 MSBs. These two bits hold the | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | MSBs of a 10-bit value which is the end half active video length extending from 0 to 1023 PCK cycles. The LSBs are located in control register 17. | | 19 | 7-0 | FP | Front porch length. This 8-<br>bit register holds a value<br>extending from 0 to 255<br>PCK cycles. | | 1A | 7-0 | EL | Equalization pulse LOW length. This 8-bit register holds a value from 0 to 255 PCK cycles. | | 18 | 7-0 | EH | Equalization pulse HIGH length. This 8-bit register holds a value extending from 0 to 255 PCK cycles. This value, when added to 256 (or 512), determines the final pulse length in the range of 256 to 511 (or 767) PCK cycles. | | 10 | 7-0 | SL | Vertical sync LOW length. This 8-bit register holds a value from 0 to 255 PCK cycles. This value, when added to 256 (or 512), determines the final pulse length in the range of 256 to 511 (or 767) PCK cycles. | | 1D | 7-0 | SH | Vertical sync HIGH length.<br>This 8-bit register holds a<br>value extending from 0 to<br>255 PCK cycles. | | 1E | 7-0 | CBL | Color bar length. This 8-bit register holds a value which is the length of each color bar displayed extending from 0 to 255 PCK cycles. | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1F | 7-5 | FIELD | Field identification (read only). These three bits are updated 12 PXCK periods after each VHSYNC\. They allow the user to determine field type on a continuous basis. | | 1F | 4-0 | LTYPE | Line type identification (read only). These five bits are updates 5 PXCK periods after each VHSYNC\. They allow the user to determine line type on a continuous basis. | | | | | Subcarrier Registers | | 20 | 7-0 | FREQL | Subcarrier frequency 4th byte (LSBs). This 8-bit register holds the LSB (bits 7-0) of the 32-bit subcarrier frequency value (nongenlock modes). The next eight most significant bits are held in Register 21. | | 21 | 7-0 | FREQ3 | Subcarrier frequency 3rd byte. This 8-bit register holds bits 15:8 of the subcarrier frequency value (non-genlock modes). The next eight most significant bits are held in Register 22. | | 22 | 7-0 | FREQ2 | Subcarrier frequency 2nd<br>byte. This 8-bit register<br>holds bits 23-16 of the<br>subcarrier frequency value<br>(non-genlock modes). The<br>eight MSBs are held in<br>Register 23. | | 23 | 7-0 | FREQM | Subcarrier frequency 1st<br>byte (MSBs). This 8-bit<br>register holds the MSBs | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | (bits 31-24) of the 32-bit<br>subcarrier frequency value<br>(non-genlock modes). | | 24 | 7-0 | SYSPHL | Video phase offset LSBs. This 8-bit register holds the 8 LSBs of color subcarrier phase offset during active video. | | 25 | 7-0 | SYSPHM | Video phase offset MSBs.<br>This 8-bit register holds the<br>8 MSBs of color subcarrier<br>phase offset during active<br>video. | | 26 | 7-0 | BURPHL | Burst phase offset LSBs.<br>This 8-bit register holds the<br>8 LSBs of burst phase<br>offset for color adjustment. | | 27 | 7-0 | BURPHM | Burst phase offset MSBs.<br>This 8-bit register holds the<br>8 MSBs of burst phase for<br>color adjustment. | | | | | Test I/O Register | | 40 | 7-0 | TESTDAT | Test data input/output. This 8-bit register holds MSBs or LSBs, as determined by the Test Control Register. This control address does not autoincrement during read or write operations. To exit the test mode, reset the Control Register pointer by setting A <sub>1-0</sub> and R/W\ LOW and then bring CS\ LOW. | | | | | Mask Register | | 50 | 7-0 | MASK | Mask register. This 8-bit register holds an 8-bit word that is logically ANDed with | | Reg | Bit | Mnemonic | Function | |-----|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | the incoming data presented to the three CLUTs in color-index mode This register is a write-only register. | | 60 | 7-0 | Y | Y-Component Register Y-component register. This register holds the contents of the luminance value before the Sync and Blank Insert circuitry of the encoder. Loading the Control Register pointer with 60 <sub>h</sub> brings 8-bit Y values out on the D <sub>7-0</sub> port. | | | | | | | | | | | ### Color Lookup Table The CLUT can be used in a variety of ways, depending on the data format and source presented to the PD port. The CLUT is loaded like a RAMDAC, sequentially writing one byte to each of the three locations associated with the selected CLUT address. These three locations are referred to as Tables D, E, and F (not R,G, and B because they may or may not contain RGB information). and are loaded in that sequence. The address will increment automatically after the three values at one address are written or read. #### Color-index Modes In color-index (CI) mode, the CLUT is used to store the color look-up data, translating the 8-bit source pixel data into 24-bit RGB colors. Table D holds red data, Table E is green data, and Table F holds blue Data. The incoming data are presented to the three tables in parallel, and a 24-bit output is produced. When the encoder is connected in parallel with a RAMDAC in a VGA system, the CLUT can be loaded simultaneously with the CLUT in the output RAMDAC. If a 6-bit RAMDAC is employed, 6 bits can be loaded via data pins D<sub>7-2</sub> (MSB justified). The two LSBs should be set to 00 for optimal black level representation, but the largest error introduced by extraneous data in the LSBs is 3/4 LSB (at 6 bits). The encoder wiil produce the closest possible translation of the VGA colors in the encoded video environment. #### GBR/RGB Modes The nominal configuration for GBR/RGB modes is unity gain (CLUT data = CLUT address) for PAL and NTSC. Other transfer functions, such as gain adjustment, offset, and gamma correction, are easily loaded. The color data is loaded into the tables in G-B-R sequence in GBR mode, and R-G-B sequence in RGB mode. #### Luminance/Color Difference Modes The TMC22x9x expects Y, B-Y, and R-Y signals at the input to its modulator section. When presenting CCIR-601 YC $_B$ C $_R$ or digitized Y, B-Y, R-Y data to the CLUT, gain and offset factors are needed. Table 5 specifies the recommended transfer functions. CLUTs are loaded in Y-C $_B$ -C $_R$ sequence. ### **Overlay Operation** For the TMC22090/091 and TMC22190/191 (when Format Control Register Bit 6 = LOW), the $OL_{4-0}$ inputs are inactive. In CCIR-601 operation, the nominal data range for Y is from 16 to 235 and for $C_B$ and $C_R$ is from 16 to 240. This means that CLUT locations 0 to 15 and 241 to 255 are available for overlay colors. When the overlay locations are addressed (by forcing CLUT addresses outside the normal CCIR-601 data range), the addressed CLUT data is encoded resulting in the specific color found in that CLUT location. Overlay colors information stored in the unused CLUT locations must be Y, B-Y, R-Y values. Y, B-Y, and R-Y values are found from RGB values by: Y = 0.299 R + 0.587 G + 0.114 BB-Y = -0.299 R - 0.587 G + 0.886 B R-Y = 0.701 R - 0.587 G - 0.114 B For the TMC22190/191, when the Format Control Register Bit 6 = HIGH, Overlay is controlled by the OL<sub>4-9</sub> inputs which directly access CLUT locations, 01 thru 0F and F1 thru FF. The values stored in these CLUT locations are to be in RGB format. Table 5. CLUT Transfer Functions for NTSC and PAL. | Input Format ( | CLUT Address) | Transfer Equations | Output Format (CLUT Data) | | | | | | |----------------|---------------|-------------------------------------|---------------------------|----------|--|--|--|--| | Component | Data Range | | Component Data Rang | | | | | | | R | 0 to 255 | 1-1 | R <sub>O</sub> | 0 to 255 | | | | | | G | 0 to 255 | 1-1 | G <sub>O</sub> | 0 to 255 | | | | | | B | 0 to 255 | 1-1 | B <sub>O</sub> | 0 to 255 | | | | | | Y | 16 to 235 | $Y_O = Y * 1.1644 - 18.63$ | Y <sub>O</sub> | 0 to 255 | | | | | | C <sub>B</sub> | +/-112 | $(B-Y)_O = C_B * 1.0126$ | (B-Y) <sub>O</sub> | +/-113 | | | | | | C <sub>R</sub> | +/-112 | $(R-Y)_O = C_R * 0.8011$ | (R-Y) <sub>O</sub> | +/-90 | | | | | | Y | 0 to 255 | 1-1 | Y <sub>O</sub> | 0 to 255 | | | | | | B-Y | +/-127 | (B-Y) <sub>O</sub> = (B-Y) * 0.893 | (B-Y) <sub>O</sub> | +/-113 | | | | | | R-Y | +/-127 | (R-Y) <sub>O</sub> = (R-Y) * 0.7065 | (R-Y) <sub>O</sub> | +/-90 | | | | | Table 6. CLUT Locations Addressed by Overlay Inputs (22190/191) | OL <sub>4-0</sub> | CLUT location | |-------------------|---------------| | 00 | No Overlay | | 01 | 01 | | 02 | 02 | | | | | | •••• | | 0E | 0E | | 0F | 0F | | 10 | No Overlay | | 11 | F1 | | 12 | F2 | | | •••• | | | •••• | | 1E | FE | | 1F | FF | ## Color-space Conversion in the Matrix When the input pixels are in RGB, GBR, or color-index format and the CLUTs are bypassed (22190/191), the Matrix remains enabled, converting RGB data to color-difference format. When the input pixels are in 444 format (YC<sub>B</sub>C<sub>R</sub>444, RGB, GBR, CI), the Interpolator (which converts 422 to 444) is not active. When the input pixels are in YC<sub>B</sub>C<sub>R</sub> format, the CLUTs are enabled and scale that data to color-difference values, leaving the Matrix inactive. In color-index mode, the Matrix is active, converting the RGB CLUT output data to color-difference values. **Format Control Register Pixel Data Format FORMAT** INMODE BYPASS\ = LOW BYPASS\ = HIGH Bit 3.2 Bit 1.0 CLUTs bypassed **CLUTs** enabled 00 (RGB) 00 (444) RGB YC<sub>R</sub>C<sub>R</sub>444 00 01 (422) RGB YC<sub>B</sub>C<sub>B</sub>422 00 10 (15-bit) RGB RGB15 00 11 (CI) RGB CI 01 reserved XX reserved 10 (GBR) 00 (444) **GBR** YC<sub>R</sub>C<sub>R</sub>444 10 01 (422) **GBR** YC<sub>B</sub>C<sub>B</sub>422 GBR15 10 10 (15-bit) **GBR** 10 11 (CI) **GBR** CI 11 not allowed not allowed Table 7. Pixel Input Operation for Format Control Register bit 6 = HIGH (22190/191) Figure 2. Pixel Data (PD<sub>23-0</sub>) Sequence for YC<sub>B</sub>C<sub>B</sub>422 XX Note that the pixel input sequence begins on the first LDV pulse after PDC goes HIGH. 27003A #### **Gamma Correction** Gamma is built into broadcast television systems as a correction factor for nonlinearity in the signal path. These nonlinearities occur in image acquisition (nonlinear conversion of light into current in a vidicon) and at the display (nonlinear conversion of voltage into beam current in a CRT and phosphor nonlinearity in converting current into light). To minimize the number of nonlinear amplifiers needed, these factors were combined into a single term, Gamma, which is applied to the signal at the camera (there are fewer cameras than receivers). Gamma is employed in television production to give a particular "feel" to a picture, hence it is not a fixed value, even within a given television system. A Gamma corrector transfer function takes the form of Output = k (Input) $^{1/\gamma}$ where a typical Gamma is 2.2 for NTSC, 2.8 for PAL. Computer systems usually ignore Gamma in driving a display monitor. Each R, G, and B channel is treated as linear. When encoding a computer display output to video, the user must decide whether to apply a gamma correction factor and, if so, what value. It is a good assumption that, since the digital video input over the CVBS bus is in composite form, it has been Gamma corrected. Gamma correction is applied in the RGB domain. When operating in YC<sub>B</sub>C<sub>R</sub>, for example when encoding a CCIR-601 signal, Gamma should have already been applied. Gamma correction is readily added to the RGB transfer equations shown in Table 5. Figure 3. Typical Gamma Curve for NTSC. # **Video Timing** The TMC22x9x can be programmed to accommodate a wide range of system timing requirements. With a line locked pixel rate of 10 to 15 Mpps, the digitally synthesized horizontal waveforms and subcarrier frequency and phase are determined from 24 registers that are loaded by a controller. #### **Horizontal Programming** Horizontal interval timing is fully programmable, and is established by loading the timing registers with the durations of each horizontal element, the duration expressed in PCK clock cycles. In this way, any pixel clock rate between 10 MHz and 15 MHz can be accommodated, and any desired standard or non-standard horizontal video timing may be produced. Figure 4 illustrates the horizontal blanking interval with timing register identification. Horizontal timing parameters can be calculated as follows: where N is the value loaded into the appropriate timing register, and PCK is the pixel clock period. Horizontal timing resolution is two PXCK periods. PXCK must be chosen such that it is an even integer multiple of the horizontal line frequency. This ensures that the horizontal line period, H, contains an integer number of pixels. The horizontal line comprises the sum of appropriate elements. $$H = FP + SY + BR + BU + CBP + VA$$ When programming horizontal timing, subtract 5 PCK periods from the calculated values of CBP and add 5 PCK periods to the calculated value for VA. Figure 4. Horizontal Blanking Interval Timing Table 8. Horizontal Timing Specifications | Parameter | NTSC-M<br>(μs) | PAL-I<br>(μs) | PAL-M<br>(μs) | |-----------|----------------|---------------|---------------| | FP | 1.5 | 1.65 | 1.9 | | SY | 4.7 | 4.7 | 4.95 | | BR | 0.6 | 0.9 | 0.9 | | BU | 2.5 | 2.25 | 2.25 | | CBP | 1.6 | 2.55 | 1.8 | | VA | 52.6556 | 51.95 | 51.692 | | Н | 63.5556 | 64.0 | 63.492 | #### **Vertical Programming** Vertical interval timing is also fully programmable, and is established by loading the timing registers with the durations of each vertical timing element, the duration expressed in PCK clock cycles. In this way as with horizontal programming, any pixel rate between 10 and 15 Mpps can be accommodated, and any desired standard or non-standard vertical video timing may be produced. Like horizontal timing parameters, vertical timing parameters are calculated as follows: where N is the value loaded into the appropriate timing register, and PCK is the pixel clock period. The Vertical Interval comprises several different line types based upon H, the Horizontal line time. $$H = (2 \times SL) + (2 \times SH)$$ [Vertical sync pulses] = $(2 \times EL) + (2 \times EH)$ [Equalization pulses] The VB and VC lines are added to produce the half-lines needed in the vertical interval at the beginning and end of some fields. These must properly mate with components of the normal lines. $$VB = CBP + VA - XBP = H/2 - CBP$$ $VC = VA - (EL + EH) = VA - H/2$ where Equalization HIGH and LOW pulses (EL + EH) = H/2 and the Extended Color Back Porch, XBP = VA + CBP - VB. XBP begins after the end of burst, BU, taking the place of CBP in vertical interval UBV lines. Figure 5. Vertical Sync and Equalization Pulse Detail Table 9. Vertical Timing Specifications | Parameter | NTSC-M | PAL-I | PAL-M | |-----------|---------|-------|--------| | | (µs) | (μs) | (μs) | | H | 63.5556 | 64 | 63.492 | | EH | 29.4778 | 29.65 | 29.45 | | EL | 2.3 | 2.35 | 2.3 | | SH | 4.7 | 4.7 | 4.65 | | SL | 27.1 | 27.3 | 27.1 | Figure 6. NTSC Vertical Interval Table 10. NTSC Field / Line Sequence and Identification | FIE | Field 1<br>FIELD ID = x00 | | | Field 2<br>LD ID = | x01 | FIE | Field 3<br>LD ID = | x10 | FIE | Field 4<br>FIELD ID = x11 | | | |------|---------------------------|--------|------------|--------------------|-------|------|--------------------|-------|------------|---------------------------|-------|--| | Line | ID | LTYPE | Line | ID | LTYPE | Line | ID | LTYPE | Line | ID | LTYPE | | | 1 | EE | 00 | 264 | EE | 00 | 1 | EE | 00 | 264 | EE | 00 | | | 2 | EE | 00 | 265 | EE | 00 | 2 | EE | 00 | 265 | EE | 00 | | | 3 | EE | 00 | 266 | ES | 01 | 3 | EE | 00 | 266 | ES | 01 | | | 4 | SS | 03 | 267 | SS | 03 | 4 | SS | 03 | 267 | SS | 03 | | | 5 | SS | 03 | 268 | SS | 03 | 5 | SS | 03 | 268 | SS | 03 | | | 6 | SS | 03 | 269 | SE | 02 | 6 | SS | 03 | 269 | SE | 02 | | | 7 | EE | 00 | 270 | EE | 00 | 7 | EE | 00 | 270 | EE | 00 | | | 8 | EE | 00 | 271 | EE | 00 | 8 | EE | 00 | 271 | EE | 00 | | | 9 | EE | 00 | 272 | EB | 10 | 9 | EE | 00 | 272 | EB | 10 | | | 10 | UBB | 0D | 273 | UBB | OD | 10 | UBB | 0D | 273 | UBB | 0D | | | | | | | | | ••• | | | | | | | | 20 | UBB | 0D | 282 | UBB | 0D | 20 | UBB | OD | 282 | UBB | OD | | | 21 | UVV | 0F | 283 | UBV | 0E | 21 | UVV | 0F | 283 | UBV | 0E | | | 22 | UVV | 0F | 284 | UVV | 0F | 22 | UVV | OF | 284 | UVV | 0F | | | | | <br>0F | <br>504 | | | | | | | | | | | 262 | UVV | | 524<br>525 | UVV | OF. | 262 | UVV | OF | 524<br>505 | UVV | OF | | | 263 | UVE | 0C | 525 | UVV | 0F | 263 | UVE | 0C | 525 | UVV | 0F | | **EEEqualization pulse** SEHalf-line vertical sync pulse, half-line equalization pulse SSVertical sync pulse ESHalf-line equalization pulse, half-line vertical sync pulse EBEqualization broad pulse UBB Black burst UVV Active video UVEHalf-line video, half-line equalization pulse UBVhalf-line black, half-line video Master and Genlock mode details of VHSYNC\, VVSYNC\, and composite VVSYNC\ (SOUT = HIGH) outputs are shown in Figures 6 and 7. When VHSYNC\ and VVSYNC\ are used as inputs (Slave mode), their falling edges mark the beginning of the sync interval and the width of the input pulse is specified under Operating Conditions. Figure 7. PAL Vertical Interval Table 11. PAL Field / Line Sequence and Identification | | Field 1 and 5<br>FIELD ID = 000, 100 | | | eld 2 and<br>0 ID = 00 | | | eld 3 and<br>D ID = 01 | | Field 4 and 8<br>FIELD ID = 011, 11 | | | | |------|--------------------------------------|-------|------|------------------------|---------|------|------------------------|----------|-------------------------------------|-----|-------|--| | Line | ID | LTYPE | Line | ID | LTYPE | Line | ID | LTYPE | Line | ID | LTYPE | | | 1 | SS | 03 | 313 | ES | 01 | 626 | SS | 03 | 938 | ES | 01 | | | 2 | SS | 03 | 314 | SS | 03 | 627 | SS | 03 | 939 | SS | 03 | | | 3 | SE | 02 | 315 | SS | 03 | 628 | SE | 02 | 940 | SS | 03 | | | 4 | EE | 00 | 316 | EE | 00 | 629 | EE | 00 | 941 | EE | 00 | | | 5 | EE | 00 | 317 | EE | 00 | 630 | EE | 00 | 942 | EE | 00 | | | 6 | -BB | 05 | 318 | EB | 10 | 631 | UBB | 0D | 943 | EB | 10 | | | 7 | UBB | OD | 319 | UBB | OD | 632 | UBB | 0D | 944 | -BB | 05 | | | 8 | UBB | OD | 320 | UBB | 0D | 633 | UBB | OD | 945 | UBB | OD | | | | | | | | | | | | | | | | | 22 | UBB | OD | 335 | UBB | 0D | 647 | UBB | OD | 960 | UBB | OD | | | 23 | UBV | 0E | 336 | UVV | 0F | 648 | UBV | 0E | 961 | UVV | 0F. | | | 24 | UVV | 0F | 337 | UVV | 0F | 649 | UVV | 0F | 962 | UVV | OF | | | | | | | | <u></u> | | | <u>:</u> | | | | | | 308 | UVV | 0F | 621 | UVV | OF | 933 | UVV | OF | 1246 | UVV | 0F | | | 309 | UVV | 0F | 622 | -VV | 07 | 934 | UVV | 0F | 1247 | UVV | 0F | | | 310 | -VV | 07 | 623 | -VE | 04 | 935 | UVV | 0F | 1248 | -VE | 04 | | | 311 | EE | 00 | 624 | EE | 00 | 936 | EE | 00 | 1249 | EE | 00 | | | 312 | EE | 00 | 625 | EE | 00 | 937 | EE | 00 | 1250 | EE | 00 | | **EEEqualization pulse** SEHalf-line vertical sync pulse, half-line equalization pulse SSVertical sync pulse ESHalf-line equalization pulse, half-line vertical sync pulse EBEqualization broad pulse UBB Black burst -BBBlack burst with color burst suppressed UVV Active video -VVActive video with color burst suppressed UVEHalf-line video, half-line equalization pulse -VEHalf-line video, half-line equalization pulse, color burst suppressed. UBVhalf-line black, half-line video Figure 8. PAL-M Vertical Interval Table 12. PAL-M Field / Line Sequence and Identification | | Field 1 and 5<br>FIELD ID = 000, 100 | | | eld 2 and<br>D ID = 00 | | | eid 3 and<br>D ID = 01 | _ | | eld 4 and<br>0 ID = 01 | | |-------------------------------------------------------------------------------------------|--------------------------------------|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------|--------------------------------------------------------------|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------------| | Line | Ð | LTYPE | Line | ID | LTYPE | Line | ID | LTYPE | Line | ID | LTYPE | | 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br><br>17<br>18<br><br>259<br>260<br>261<br>262 | SS SS EE EE BB BB UV : VE EE EE | 03<br>03<br>03<br>00<br>00<br>05<br>05<br>0D<br>0F<br>0F<br>04<br>00<br>00 | 263<br>264<br>265<br>266<br>267<br>268<br>269<br>270<br>271<br><br>279<br>280<br>281<br><br>521<br>522<br>523 | ES<br>SS<br>SE<br>EE<br>EB<br>-BB<br>UBB<br>UBV<br>UVV<br>:-VV<br>EE | 01<br>03<br>03<br>02<br>00<br>00<br>10<br>05<br>1D<br><br>0F<br>0F<br>07<br>00. | 1 2 3 4 5 6 7 8 17 18 258 259 260 261 262 | SS<br>SS<br>SS<br>EE<br>EE<br>-BB<br>UBB<br>UVV<br>-VE<br>EE | 03<br>03<br>03<br>00<br>00<br>05<br>05<br>05<br>.:.<br>0F<br>07<br>04<br>00<br>00 | 263<br>264<br>265<br>266<br>267<br>268<br>269<br>270<br>271<br><br>279<br>280<br>281<br><br>521<br>522<br>523 | ES<br>SS<br>SE<br>EE<br>EB<br>-BB<br>UBB<br>UVV<br>UVV<br>EE | 01<br>03<br>02<br>00<br>00<br>10<br>05<br>1D<br><br>0F<br>0F<br>0F | | | | | 524<br>525 | EE<br>EE | 00<br>00 | | | | 524<br>525 | EE | 00<br>00 | **EEEqualization pulse** SEHalf-line vertical sync pulse, half-line equalization pulse SSVertical sync pulse ESHalf-line equalization pulse, half-line vertical sync pulse EBEqualization broad pulse UBB Black burst -BBBlack burst with color burst suppressed UVV Active video -VVActive video with color burst suppressed UVEHalf-line video, half-line equalization pulse -VEHalf-line video, half-line equalization pulse, color burst suppressed. UBVhalf-line black, half-line video **Table 13. Standard Timing Parameters** | | Field | Horizontal | Pixel | PXCK | l | | | | TI | mina | Regis | ter (h | ex) | | | | | | | |-----------------|--------------|----------------|----------------|-------|----------|----------|----------|-----------|----|----------|----------|--------|---------|------------|----------|-----------------------|-----------------------|----------|-----------| | Standard | Rate<br>(Hz) | Freq.<br>(kHz) | Rate<br>(Mpps) | Freq. | SY<br>10 | BR<br>11 | BU<br>12 | CBP<br>13 | | VA<br>15 | VC<br>16 | | Note 18 | 1 FP<br>19 | EL<br>1A | EH <sup>2</sup><br>1B | SL <sup>2</sup><br>1C | SH<br>1D | CBL<br>1E | | NTSC sqr. pixel | 59.94 | 15.734266 | 13.50 | 24.54 | 3A | 07 | 1F | 0F | 23 | 8B | 05 | 77 | 65 | 12 | 1C | 6A | 4D | 3A | 52 | | NTSC CCIR-601 | 59.94 | 15.734266 | | 27.00 | 40 | 08 | 22 | 11 | 3F | CB | 1E | 9D | 65 | 14 | 1F | 8E | 6E | 3F | 59 | | NTSC 4x Fsc | 59.94 | 15.734266 | | 28.64 | 43 | 09 | 24 | 12 | 54 | F7 | 30 | B5 | 65 | 15 | 21 | A6 | 84 | 43 | 5F | | PAL sqr. pixel | 50.00 | 15.625000 | 13.50 | 29.50 | 45 | OD | 21 | 21 | 6D | 03 | 2B | B7 | 75 | 19 | 23 | B5 | 93 | 45 | 61 | | PAL CCIR-601 | 50.00 | 15.625000 | | 27.00 | 40 | OC | 1E | 1D | 4D | C3 | 13 | 93 | 65 | 16 | 20 | 90 | 71 | 3F | 58 | | PAL 15 Mpps | 50.00 | 15.625000 | | 30.00 | 46 | OD | 22 | 21 | 73 | 11 | 31 | BF | 75 | 19 | 23 | BD | 9A | 47 | 62 | | PAL-M sqr.pixel | 60.00 | 15.750000 | 13.50 | 25.01 | 3E | 0B | 1C | 13 | 26 | 86 | FE | 8B | 61 | 18 | 1D | 70 | 53 | 3A | 52 | | PAL-M CCIR-60 | 60.00 | 15,750000 | | 27.00 | 44 | 0C | 1E | 13 | 26 | Bf | 12 | 99 | 65 | 1A | 1F | 8E | 6E | 3F | 57 | | PAL-M 4x Fsc | 60.00 | 15,750000 | | 28.60 | 47 | 0D | 20 | 15 | 4C | E8 | 22 | AC | 65 | 1B | 21 | A5 | 84 | 42 | 5D | Note: - XBP, VA, VC, and VB are 10-bit values. The 2 MSBs for these four variables are in Timing Register See Table 4. - EH and SL are 9-bit values. A most significant "1" is forced by the TMC22x9x since EH and SL must range from 256 to 511. Extending the range of EH and SL to 767 is possible in the TMC22091/191. Only the eight LSBs are stored in Timing Registers 1B and 1C. - Every calculated timing parameter has a minimum value of 5 except EH and SL which have minimum values of 256. #### VITS Signal Insertion In both NTSC and PAL, the TMC22x9x can be set up to allow VITS signals in the vertical interval in place of normal black burst lines (UBB). This is controlled by the Interface Control Register bit 7. If this bit is LOW, UBB lines are black burst and are independent of TMC22x9x input data. If the bit is HIGH, all vertical interval UBB lines become UVV. UVV lines are active video and depend upon data input to the TMC22x9x. VITS lines may be used for inserting special test signals or for passing captioning data through the encoder. #### **Edge Control** SMPTE 170M NTSC and Report 624 PAL video standards call for specific rise and fall times on critical portions of the video waveform. The TMC22x9x does this automatically, requiring no user intervention. The TMC22x9x digitally defines slopes compatible with SMPTE 170M NTSC or CCIR Report 624 PAL on all vital edges: - 1. H and V Sync leading and trailing edges. - 2. Burst envelope. - 3. Active video leading and trailing edges. ### **Subcarrier Programming** The color subcarrier is produced by an internal 32-bit digital frequency synthesizer which is completely programmable in frequency and phase. Separate registers are provided for phase adjustment of the color burst and of the active video, permitting external delay compensation, color adjustment, etc. In Master or Slave mode, the subcarrier is internally synchronized to establish and maintain a specified relationship between the leading edge of horizontal sync and color burst phase (SCH). In NTSC and PAL, SCH synchronization is performed every eight fields, on field 1 of the eight-field sequence. Proper subcarrier phase is maintained through the entire eight fields, including the 25 Hz offset in PAL systems. See the description of 8FSUBR under Test Control Register bit 1 for the subcarrier reset function. In Genlock mode, the phase and relative frequency of the incoming video is transmitted by the TMC22070 Genlocking Video Digitizer over the CVBS bus at the beginning of each line, which synchronizes the digital subcarrier synthesizer. When control register bit BUKEN is HIGH and digitized burst from the TMC22070 is passed through to the reconstruction D/A converter, the reference subcarrier for the chrominance modulator is still synthesized within the encoder. #### NTSC Subcarrier For NTSC encoding, the subcarrier synthesizer frequency has a simple relationship to the pixel clock period, repeating over 2 lines: The decimal value is: FREQ = $$(455 / 2) \times 2^{32}$$ (pixels / line) This value must be converted to binary and split into four 8-bit registers, FREQM, FREQ2, FREQ3. and FREQL. The number of pixels / line is: Pixels / line = (2 / PXCK frequency)(H period) SYSPH establishes the appropriate phase relationship between the internal synthesizer and the chroma modulator. The nominal value for SYSPH is zero. Other values for SYSPH must be converted to binary and split into two 8-bit registers, SYSPHM and SYSPHL. Burst Phase (BURPH) sets up the correct relative NTSC modulation angle. The value for BURPH is: BURPH = SYSPH + 8.192 = SYSPH + $\pi/4$ This value must be converted to binary and split into two 8-bit registers, BURPHM and BURPHL. #### **PAL Subcarrier** The PAL relationship is more complex, repeating only once in 8 fields (the well-known 25 Hz offset): FREQ = $$(1135/4) + (1/625)$$ x $2^{32}$ (pixels / line) This value must be converted to binary and split as described previously for NTSC. The number of pixels / line is found as in NTSC. For PAL, the decimal value for SYSPH is found from: SYSPH = FREQ $/ 2^{17}$ This value must be converted to binary and split into two 8-bit registers, SYSPHM and SYSPHL. Burst Phase in PAL is identical to SYSPH. Therefore, the same values for SYSPHM and SYSPHL must be used for BURPHM and BURPHL. #### **PAL-M Subcarrier** FREQ = $$(909 / 4) \times 2^{32}$$ (pixels / line) SYSPH = FREQ / 2<sup>17</sup> = BURPH | Tahla 14 | Standard Subcarrier Parameter | ro | |----------|-------------------------------|----| | | | | | Standard | Field | Horizontal | Pixel | PXCK | Subcarrier | | Subcarrier Register (hex) | | | | | | | | | |-----------------|--------------|----------------|---------------|----------------|----------------|--------------|---------------------------|--------------|--------------|-------------|-------------|-------------|-------------|--|--| | | Rate<br>(Hz) | Freq.<br>(kHz) | Rate<br>(MHz) | Freq.<br>(MHz) | Freq.<br>(MHz) | BURPHM<br>27 | BURPHL<br>26 | SYSPHM<br>25 | SYSPHL<br>24 | FREQM<br>23 | FREQ2<br>22 | FREQ3<br>21 | FREQU<br>20 | | | | NTSC sqr. pixel | 59.94 | 15.734266 | 12.27 | 24.54 | 3.57954500 | 20 | 00 | 00 | 00 | 4A | AA | AA | C7 | | | | NTSC CCIR-601 | 59.94 | 15.734266 | 13.50 | 27.00 | 3.57954500 | 20 | 00 | 00 | 00 | 43 | E0 | F8 | 3E | | | | NTSC 4x Fsc | 59.94 | 15.734266 | 14.32 | 28.64 | 3.57954500 | 20 | 00 | 00 | 00 | 40 | 00 | 00 | 00 | | | | PAL sqr. pixel | 50.00 | 15.625000 | 14.75 | 29.50 | 4.43361875 | 00 | 00 | 00 | 00 | 4C | F3 | 18 | 19 | | | | PAL CCIR-601 | 50.00 | 15.625000 | 13.50 | 27.00 | 4.43361875 | 00 | 00 | 00 | 00 | 54 | 13 | 15 | 96 | | | | PAL 15 Mpps | 50.00 | 15.625000 | 15.00 | 30.00 | 4.43361875 | 00 | 00 | 00 | 00 | 4B | AA | Ċ6 | Ă1 | | | | PAL-M sqr.pixel | 60 | 15.750 | 12.50 | 25.01 | 3.57561149 | 00 | 00 | 00 | 00 | 49 | 45 | 00 | 51 | | | | PAL-M CCIR-601 | 60 | 15,750 | 13.50 | 27.00 | 3.57561149 | 00 | 00 | 00 | 00 | 43 | DF | 3F | D7 | | | | PAL-M 4x Fsc | 60 | 15,750 | 14.30 | 28.60 | 3.57561149 | 00 | 00 | 00 | 00 | 40 | 10 | 66 | F5 | | | #### **SCH Phase Error Correction** SCH refers to the timing relationship between the 50% point of the leading edge of horizontal sync and the positive or negative zero-crossing of the color burst subcarrier reference. SCH error is usually expressed in degrees of subcarrier phase. In PAL, SCH is defined for line 1 of field 1, but since there is no color burst on line 1, SCH is usually measured at line 7 of field 1. The need to specify SCH relative to a particular line in PAL is due to the 25 Hz offset of PAL subcarrier frequency. Since NTSC has no such 25 Hz offset, SCH applies to all lines. The SCH relationship is only important in the TMC22x9x when two video sources are being combined or if the composite video output is externally combined with another video source. In these cases, improper SCH phasing will result in a noticeable horizontal jump of one image with respect to another and/or a change in hue proportional to the SCH error between the two sources. SCH phasing can be adjusted by modifying BURPH and SYSPH values by equal amounts. SCH is advanced/delayed by one degree by increasing/decreasing the value of BURPH and SYSPH by approximately B6<sub>h</sub>. An SCH error of 15° is corrected with SYSPH and BURPH offsets of AAA<sub>h</sub>. #### Video Test Signals The TMC22x9x has two standard video test waveforms available for evaluating video signal integrity. These are selected and controlled by the Format Control Register. Setting the Format Control Register bits 0, 4, and 5 LOW generates standard color bars at the COMPOSITE output (Figure 9), the luminance component stair-step signal at the LUMA output, and the chrominance component on the CHROMA output. The six colors are 100% saturated PAL and 75% saturated for NTSC. The exact location of each color vector (subcarrier amplitude, subcarrier phase) can be measured using industry-standard instrumentation (vectorscope). The percentage color saturation is selectable via Control Register 0E, bit 0 in the TMC22091/191. The color bar test pattern produced comprises eight equal-width bars during VA, the active video period. The Timing Register value for CBL is found from: $$CBL = \{ (VA + 7)/8 \}$$ If CBL is larger than this, the color bars are truncated at the end of VA. If CBL is smaller than VA / 8, the color bar sequence will repeat, starting with another white bar. From left to right color bars 1 to 8 should be white, yellow, cyan, green, magenta, red, blue, and black. See Figures 35, 36, 41, 42, 47, 48. The modulated ramp waveform is enabled by setting the Format Control Register to 30h. It comprises constant-amplitude and constant-phase subcarrier modulation superimposed on a linear ramp which slews from black to white during the active video portion of each horizontal line interval (Figure 10). This waveform is useful in making differential gain and differential phase measurements on the video signal. Differential gain is a measure of the variation in saturation of a color as the luminance component is varied from black to white. Differential phase is a measure of the variation in hue of a color as the luminance component is varied from black to white. Differential gain and differential phase are measured with a vectorscope. See Figures 39, 40, 45, 46. 2-63 Figure 9. 100% Color Bars With 100% and 75% Chrominance Saturation Figure 10. Modulated Ramp Waveform # **Microprocessor Interface** The microprocessor interface employs a 13-line interface, with an 8-bit data bus and two address bits: four addresses are required for device programming and CLUT/register management. Address bit 0 selects between control registers and CLUT memory. Address bit 1 selects between reading/writing the register addresses and reading/writing register or CLUT data. When writing, the address is presented along with a LOW on the R/W\ pin during the falling edge of CS\. Eight bits of data are presented on D7-0 during the subsequent rising edge of CS\. One additional falling edge of CS\ is needed to move input data to its assigned working registers. Figure 11. Microprocessor Port - Write Timing Figure 12. Microprocessor Port - Read Timing In read mode, the address is accompanied by a HIGH on the R/W\ pin during a falling edge of CS\. The data output pins go to a low-impedance state $t_{DOZ}$ ns after CS\ falls. Valid data is present on $D_{7-0}$ $t_{DOM}$ after the falling edge of CS\. Because this port operates asynchronously with the pixel timing, there is an uncertainty in this data valid output delay of one PXCK period. This uncertainty does not apply to $t_{DOZ}$ . The RESET\ pin restores the TMC22x9x to field 1 line 1 and places the encoder in a power-down state (if HRESET is LOW). Bit 4 of the Global Control Register (SRESET) is set LOW. All other control words and CLUT contents are left unchanged. Returning RESET\ HIGH synchronizes the internal clock with PXCK and restores power to the device outputs. ### Reading Pixel Data from the D7-0 Port The microprocessor port of the TMC22x9x may be used to extract digital video pixels. The eight MSBs of the up-sampled and interpolated pixel data that go to the COMPOSITE D/A converter can also be sent to the $D_{7\text{-}0}$ port and read for subsequent processing. When the Test Control Register is loaded with 28 $_{\rm h}$ and the Control Register pointer is loaded with 40 $_{\rm h}$ , the D $_{7\text{-}0}$ port will begin outputting 8-bit composite pixels synchronous with respect to PXCK. To halt the pixel flow from D $_{7\text{-}0}$ , simply bring CS\ HIGH. The TMC22091/191 has an additional feature that allows luminance pixel data to be read from the $D_{7-0}$ . In this case the eight MSBs of luminance found just prior to the Sync and Blank Insert block are routed to the microprocessor port. When the Control Register pointer is loaded with $60_h$ , the $D_{7-0}$ port will begin outputting 8-bit luminance pixels synchronous with respect to PXCK. To halt the pixel flow from $D_{7-0}$ , simply bring CS\ HIGH. ## **Operational Timing** The TMC22x9x operates in three distinct modes: - Master mode. The encoder independently produces all internal timing and provides digital sync to the host controller. - Slave mode. The encoder accepts horizontal and vertical sync from the controller and synthesizes the video output accordingly. - Genlock mode. The encoder accepts horizontal and vertical sync from the companion TMC22070 Genlocking Video Digitizer, synchronizes itself to the incoming video, and provides appropriate H Sync and V Sync to the host. It synchronizes Pixel Data input in two ways: - a. Internal PDC. The encoder internally generates the Pixel Data Control (PDC) Figure 13. Reset Timing - PCK Synchronization signal which calls for data input from the external pixel source. External PDC. The encoder receives a PDC signal from the host and accepts Pixel Data based on that input. ### Reset Timing The TMC22x9x operates from a master clock (PXCK) at twice the pixel rate. Some internal circuitry employs a clock at the pixel rate, PXCK / 2. In Master mode, the PCK to PXCK timing relationship is set on the rising edge of RESET\. In Figure 13, PCK is denoted by odd PXCK counts. When RESET\ is taken LOW with sufficient setup time (t<sub>SR</sub>) before a rising edge of PXCK, the internal state machines are reset and the device is put into a mode as dictated by the Global Control Register bits 0 and 4. In Master mode, when the RESET\ pin is taken HIGH, the internal clock timing is established. In Slave and Genlock mode, this timing is established by VHSYNC\ and GHSYNC\ respectively. The first PXCK following this RESET\ rising edge is designated as PXCK 1. Where it is significant, reference PXCK timing will be shown with numbered rising edges. A designation of 2N clocks refers to an even number of PXCK rising edges from device reset. If RESET\ is not shown and clock numbering does not refer to 2N, timing is relative to signals shown in the diagram only. ### **Pixel Data Input Timing** PXCK is internally divided by 2 to generate an internal pixel clock, PCK which is not accessible from the pins of the TMC22x9x. To ensure the correct relationship between PCK and pixel data, PCK is locked to VHSYNC\ or GHSYNC\ (Slave or Genlock mode, respectively). In Master mode, VHSYNC\ is produced on the rising edge of PCK allowing external circuitry to synchronize the generation of pixel data and LDV which also operates at 1/2 the rate of PXCK. The rising edge of LDV clocks the 24-bit pixel data into three 8-bit registers while PCK clocks that data through the pixel data path within the TMC22x9x. It is therefore necessary to meet the set-up and hold timing between pixel data and LDV as well as LDV and PCK. Figure 14. Slave Mode PD Port Interface Timing (Genlock Mode) Figure 15. Master Mode Timing ### Master Mode In Master mode, initial timing is determined from the RESET\ input, and subsequent cycles result from programmed values in the Timing Control Registers. The Horizontal Sync output, VHSYNC\, goes LOW 18 PXCK clock cycles after the device is reset. The 50% point of the falling edge of sync LOW on line 4 of field 1 (NTSC) or line 1 of field 1 (PAL) occurs at the COMPOSITE and LUMA outputs 56 clocks after reset, or 38 clocks after VHSYNC\. ### Slave Mode In Slave mode, the 50% point of the falling edge of sync occurs 46 PXCK clocks after the falling edge of VHSYNC\, which is an input signal to the TMC22x9x. This must be provided by the host to begin every line. If it is early, the line will be started early, maintaining the 52 clock delay to output. If it comes late, the front porch portion of the output waveform will be extended as necessary. Figure 17. Genlocked Mode Timing ### Genlocked Mode In Genlocked mode, the encoder receives sync signals over the GHSYNC\ and GVSYNC\ inputs, and provides VHSYNC\ and VVSYNC\ to the host. The 50% sync amplitude point occurs 50 PXCK clocks after GHSYNC\ goes LOW, while VHSYNC\ is produced at clock 13. If GHSYNC\ is late, the front porch is lengthened, if is is early, front porch is shortened. #### **Pixel Data Control** The Pixel Data Control (PDC) signal determines the active picture area. It may be an input or an output, as determined by the Interface Control Register bit 1. The position (number of PCK cycles) of the rising edge of PDC relative to the falling edge of VHSYNC\ can be found by summing SY, BU, BR, and CBP. ### **External Pixel Data Control** When used as an input, PDC goes HIGH four PXCK cycles before the first valid pixel of a line is presented to the PD input port. If this signal is late Figure 18. External Pixel Data Control # TMC22X9X (with respect to the horizontal blanking interval programmed in the timing control registers), the Color Back Porch (CBP) will be extended. If it is early, incoming pixel data will be ignored until the end of the CBP. #### Internal Pixel Data Control When programmed as an output, PDC goes HIGH four PXCK periods prior to the end of CBP (as programmed in the horizontal timing registers) which is also four PXCK cycles prior to required input of the first pixel of a line. Pixels produced by the encoder appear at the analog outputs (COMPOSITE, LUMA, CHROMA) 40 clocks after they are registered into the PD port. Note that the pixels enter at one-half the PXCK rate. The encoded signal passes through interpolation filters which generate intermediate output values, improving the output frequency response and greatly simplifying the external reconstruction filter. The interpolated pixels are designated PI in the diagram. Figure 19. Internal Pixel Data Control ### Layering with the TMC22190/191 The "layering" capabilities of the TMC22190/191 are powerful and flexible. Layering is a video production concept where various images or patterns are superimposed (keyed) over each other to form a final image that is the layered composite of the input images. Four layers with the following priority are defined for the TMC22190/191: - The DOWNSTREAM KEY layer keys over all other layers. - The FOREGROUND layer keys over MIDGROUND and BACKGROUND, but not over DOWNSTREAM KEY. - The MIDGROUND layer keys over BACKGROUND, but not over FOREGROUND or DOWNSTREAM KEY. - The BACKGROUND layer never keys over any other layer. It is important not to confuse layers with sources. The TMC22190/191 can be programmed to assign any of its input sources (RGB, $YC_RC_B$ , CVBS bus, Overlay bits) to any of the four layers. The ability to combine various video sources into a 4-layer composite image is a very powerful tool in the production of computer/live video. The TMC22190/191 performs layering operations entirely in the digital domain, enabling precise digital control. ### A 4-Layer Example For this layering example, a BACKGROUND image (Figure 20) is generated. This image comprises shaded matte levels varying from black at the top of the screen to white at the bottom. This could just as well be a color image which will be seen wherever no other image appears through the layering process. The MIDGROUND image comprises a happy face superimposed over a white rectangle. Only the happy face and the white rectangle are of interest for this image and therefore, the portion of the image outside that area will be replaced by the BACKGROUND image when MIDGROUND is keyed over BACKGROUND. A key signal is generated on a pixel-by-pixel basis. It indicates Figure 20. 2-Layer Image Construction BACKGROUND which image is active. The key signal for keying MIDGROUND over BACKGROUND is shown to the right of the MIDGROUND image. This represents a single bit signal mapped over the image. When the signal is black (logic LOW), the MIDGROUND image is active, when it is white (logic HIGH), the BACKGROUND is active. The results of layering MIDGROUND over BACKGROUND images are shown in the 2-layer composite image Figure 20. A FOREGROUND image comprises a shaded matte rectangle with "HI KIDS!" alpha characters in its center. This is to be superimposed over the previous 2-layer composite image. The key signal needed for superimposing FOREGROUND over other images is shown to the right of the FOREGROUND image. This represents a single bit signal mapped over the image. When the signal is black (logic LOW), the FOREGROUND image is active, when it is white (logic HIGH), the composite image is active. A new 3-layer composite image, FOREGROUND over MIDGROUND over BACKGROUND, is shown Figure 21. Adding a 3rd Layer in Figure 21. A DOWNSTREAM KEY image comprises the white alpha characters "HAPPY FACE", and black alpha characters "Time". This is to be superimposed over the previous 3-layer composite image. The key signal needed for superimposing DOWNSTREAM KEY image over the other composite images is shown to the right. This represents a single bit signal mapped over the image. When the signal is black (logic LOW), the DOWNSTREAM KEY image is active, when it is white (logic HIGH), the previous composite image is active. The final 4-layer composite image, DOWNSTREAM KEY over FOREGROUND over MIDGROUND over BACKGROUND, is shown in Figure 22. In this illustration, all four source images are static (not moving). The images input to the TMC22190/191 can just as well be "live" (from video camera or VCR sources) as long as: 1. Data from those sources is in an input format that the TMC22x9x can accept, and POREGROUND HI KIDS! A 27037A Raytheon Semiconductor Figure 22. Adding a 4th Layer 3-LAYER COMPOSITE The sources either synchronize the TMc22x9x (Genlock mode) or are synchronized by the TMC22x9x (Master or Slave mode). Key signals may be generated external to the TMC22x9x (Hardware Keying) and use the KEY input pin for control. Key signals may also be generated within the TMC22x9x (Data Keying) by the comparison of input color data with color data stored in the TMC22x9x. ### 2-Layer Keying with the TMC22090/091 The TMC22090/091 facilitates the keying of PD port input data over the CVBS bus input data. Keying is controlled on a pixel-by-pixel basis by either the KEY input pin of the internal Data Key function. The first two layers in the previous 4-Layer Example apply to the TMC22090/091. The result of keying is an effect where a MIDGROUND source image (i.e. Happy Face from PD data) is superimposed over a BACKGROUND source image (i.e. variable matte color from CVBS data). # Assigning Video Sources to Layers with the TMC22190/191 Digital video inputs to the TMC22190/191 (PD, CVBS, Overlay) are assigned to the four layers by choosing one of 16 modes of the Layering Control Register. OVERLAY is always keyed (switched on a pixel-by-pixel basis from active to transparent) by the OL<sub>4-0</sub> inputs. OVERLAY can not be programmed to the BACKGROUND layer. The CVBS digital video bus can be assigned to any of the four layers and is keyed by the KEY input signal or internal Data Key comparators. In modes 0 thru 7, the CLUTs are not bypassed and the BYPASS\ input is ignored. Table 15. Layer Assignments, Image Sources, and Keying Controls (22190/191) | LCR 04 | BACKGROUND | MIDGRO | DUND | FOREGR | OUND | DOWNSTRE | EAM KEY | |---------|----------------------------------------------|-----------------------------------------|-------------------|-----------------------------------------|-------------------|-----------------------------------------|-------------------| | LAYMODE | Image Source | Image Source | Keying Control | Image Source: | Keying Control: | Image Source: | Keying Control | | 0 | PD(YCBCR, RGB, CI) | CVBS | KEY or Data Key | | - | • | • | | 1 | PD(YCRCR, RGB, CI) | CVBS | KEY or Data Key | OVERLAY | OL40 | - | • | | 2 | PD(YC <sub>B</sub> C <sub>B</sub> , RGB, CI) | CVBS | KEY | PD(YCRCR, RGB, CI) | Data Key\ | OVERLAY | OLLO | | 3 | PD(YCBCR, RGB, CI) | CVBS | KEY | PD(YCBCR, RGB, CI) | Data Key | OVERLAY | OL <sub>40</sub> | | 4 | CVBS | OVERLAY | OL <sub>4-0</sub> | PD(YCBCR, RGB, CI) | KEY or Data Key | | | | 5 | CVBS | PD(YCRCR, RGB, CI) | KEY or Data Key | OVERLAY | OL40 | - | - | | 6 | PD(YCBCR, RGB, CI) | CVBS | KEY | OVERLAY | OL <sub>4-0</sub> | PD(YCBCB, RGB, CI) | Data Key\ | | 7 | PD(YCBCR, RGB, CI) | CVBS | KEY | OVERLAY | OL <sub>4-0</sub> | PD(YCBCR, RGB, CI) | Data Key | | 8 | PD(YC <sub>R</sub> C <sub>R</sub> , CI) | CVBS | KEY or Data Key | | - | | - | | 9 | PD(RGB) | PD(YC <sub>R</sub> C <sub>R</sub> , CI) | BYPASS\ | CVBS | KEY or Data Key | OVERLAY | OL <sub>4-0</sub> | | l à l | PD(RGB) | CVBS | KEY or Data Key | PD(YC <sub>R</sub> C <sub>R</sub> , CI) | BYPASS\ | OVERLAY | OL <sub>4-0</sub> | | В | PD(RGB) | CVBS | KEY or Data Key | OVERLAY | OL <sub>4-0</sub> | PD(YC <sub>B</sub> C <sub>R</sub> , CI) | BYPASS\ | | С | PD(RGB) | PD(YC <sub>B</sub> C <sub>R</sub> , CI) | BYPASS\ | OVERLAY | OL <sub>4-0</sub> | CVBS | KEY or Data Key | | D | CVBS | PD(RGB) | KEY | PD(YC <sub>R</sub> C <sub>R</sub> , CI) | BYPASS\ | OVERLAY | OLAO | | Ě | CVBS | OVERLAY | OL <sub>4-0</sub> | PD(RGB) | KEY | PD(YC <sub>B</sub> C <sub>B</sub> , CI) | BYPASS\ | | F | PD(RGB) | OVERLAY | OL <sub>4-0</sub> | CVBS | KEY or Data Key | PD(YCBCB, CI) | BYPASS\ | Notes: ### Hardware Keying The KEY input switches the COMPOSITE D/A converter input from the luminance and chrominance combiner output to the CVBS data bus on a pixel-by-pixel basis. This is a "soft" switch, executed over four PXCK periods to minimize out-of-band transients. Keying is accomplished in the digital composite video domain. The video signal from the CVBS bus is only present on the COMPOSITE output. The CHROMA and LUMA outputs continue to present encoded PD port data when CVBS is active. Hardware keying is enabled by the Key Control Register bit 6. Normally, keying is only effective during the Active Video portion of the waveform (as determined by the VA registers 15 and 18. That is, the Horizontal Blanking interval is generated by the encoder state machine even if the KEY signal is held HIGH through Horizontal Blanking. However, it is possible to allow digital Horizontal Blanking to be passed through from the CVBS bus to the COMPOSITE output by setting Key Control Register bit 5 HIGH. In this mode, KEY is always active, and may be exercised at will. The KEY input is registered into the encoder just like Pixel Data is clocked into the PD port. It may be considered a 25th Pixel Data bit. It is internally pipelined, so the midpoint of the key transition occurs at the output of the pixel that was input at the same time as the KEY signal. ### Data Keving Data Keying internally generates a Key signal that acts exactly as the external KEY signal. There are three Key Value Registers 05, 06, and 07 that are matched against the input data to the three CLUTs. These tables are designated D. E. and F. because they contain different information depending on the input mode selected: For LAYMODE = 0 to 7. Pixel Data always passes through the CLUTs. FORMAT, INMODE, and the BYPASS\ pin selects the input format for PD<sub>23-0</sub> according to Table 7. For LAYMODE = 8 to F and BYPASS\ = HIGH, Data Key is disabled. Asserting the signal listed under "Keying Control." enables the corresponding "Signal Source:". Signals with "\" are asserted by a logic LOW. Figure 23. Hardware Keving The key registers may be individually enabled using bits 3,2,1 of the Key Control Register. Bit 4 of the same register enables/disables data Keying in its entirety. Data Keying and Hardware Keying are logically ORed: when both are enabled, either one will result in a key switch to the CVBS channel. The key comparison is based on the input data to the CLUTs. When operating in color-index mode, all three CLUTs receive the same input value, so any one of the three registers is sufficient to identify a key value. The outputs of all enabled key registers are ANDed to produce the KEY signal. If more than one key register are enabled and their key values are not identical, no key will be generated. Table 16. Table D, E, F Contents | Mode | Table D | Table E | Table F | |--------------------------------|---------|----------------|----------------| | RGB | Red | Green | Blue | | GBR | Green | Blue | Red | | YC <sub>B</sub> C <sub>R</sub> | Y | C <sub>B</sub> | C <sub>R</sub> | | CI | CI | CI | CI | #### Genlock Interface The TMC22x9x can bring digital composite video into its CVBS port, accompanied by separate horizontal and vertical sync signals. It has been designed to couple tightly with the companion TMC22070 Genlocking Video Digitizer, but other sources may use this port as well. Digital composite video is in standard 8-bit binary format at a PXCK / 2 rate. Synchronization with the internal PXCK / 2 is established by the phasing of the GHSYNC\ input. Subcarrier frequency and phase data are received by the encoder over the CVBS bus as 4-bit nibbles on CVBS<sub>3-0</sub> during the horizontal sync period. Field identification is also required for the TMC22x9x internal sync generator. The 14th nibble of the sequence contains no relevant data. The TMC22070 provides these data - the Genlock Reference Signal (GRS). Figure 24. Data Keying Figure 25. Geniock Interface Timing Figure 26. Frequency/Phase Data Transfer # **Filtering** The TMC22x9x incorporates internal digital filters to establish appropriate bandwidths and simplify external analog filter designs. #### Color-Difference Low-Pass Filters The chrominance portion of a composite video signal must be sufficiently bandlimited to avoid cross-color and cross-luminance distortion, and to preclude exceeding the allowable bandwidth of a video channel. The color-difference low-pass filters on the TMC22x9x establish chrominance bandwidths which meet the specifications outlined in CCIR Report 624-3, Table II, Item 2.6, for system I over a range of pixel rates from 12.27 Mpps to 14.75 Mpps. Equal bandwidth is established for both color-difference channels. Figure 27. Color-Difference Low-Pass Filter Response ### Interpolation Filters The Chroma Modulator output and the luminance data path are digitally filtered with sharp-cutoff low-pass interpolation filters. These filters ensure that aliased subcarrier, chrominance, and luminance frequencies are sufficiently suppressed in the frequency band above base-band video and below the pixel frequency (f<sub>S</sub>/4 to 3f<sub>S</sub>/4, where f<sub>S</sub> is the PXCK frequency). Since these are fixed-coefficient digital filters, their filter characteristics depend upon clock rate. Figures 25 and 26 show the frequency response for two pixel rates, 12.27 MHz and 14.75 MHz. Figure 28. Chroma Modulator and Luminance Interpolation Filter Full Spectrum Response Figure 29. Chroma Modulator and Luminance Interpolation Filter Passband Detail Virtually all digital-to-analog reconstruction systems exhibit a high frequency roll-off as a result of the zero-order hold characteristic of classic D/A converters. This response is commonly referred to as a sin(x)/x response. It is a function of the sampling rate of the output D/A. The TMC22x9x's digital interpolation filters convert the data stream to a sample rate of twice the pixel rate. This results in much less high frequency $\sin(x)/x$ rolloff and the output spectrum between $f_S/4$ and $3f_S/4$ contains very little energy. Since there is so little signal energy in this frequency band, the demands placed on the output reconstruction filter are greatly reduced. The output filter needs to be flat to $f_S/4$ and have good rejection at $3f_S/4$ . The relaxed requirements greatly simplify the design of a filter with good phase response and low group delay distortion. A small amount of peaking may be used to compensate residual $\sin(x)/x$ rolloff. Figure 30. Sin(x)/x Response At 1x Pixel-Rate Conversion Figure 31. Sin(x)/x Response At 2X Pixel-Rate Conversion ### **JTAG Test Interface** The JTAG test port accesses registers at every digital I/O pin except the JTAG test port pins. Table 17 shows the sequence of the test registers. The register number (Reg) indicates the order in which the register data is loaded and read (Reg 1 is loaded and read first, therefore it is at the end of the serial path). The scan path is 59 registers long. The six TEST pins of the TMC22090/091 function as JTAG registers. The JTAG port is a 4-line interface, following IEEE Std. 1149.1-1990 specifications. The Test Data Input (TDI) and Test Mode Select (TMS) inputs are referred to the rising edge of the Test Clock (TCK) input. The Test Data Output (TDO) is referred to the falling edge of TCK. Table 17. JTAG Interface Connections | Reg | Pin | Signal | Reg | Pin | Signal | Reg | Pin | Signal | |-----|-----|------------------------|-----|-----|-------------------|-----|-----|-------------------| | 1 | 28 | BYPASS\ (TEST) | 21 | 62 | PD <sub>13</sub> | 41 | 2 | CVBS₁ | | 2 | 29 | OL <sub>4</sub> (TEST) | 22 | 63 | PD <sub>12</sub> | 42 | 3 | CVBS <sub>0</sub> | | 3 | 44 | CVBS <sub>7</sub> | 23 | 66 | PD <sub>11</sub> | 43 | 4 | KEY | | 4 | 45 | CVBS <sub>6</sub> | 24 | 67 | PD <sub>10</sub> | 44 | 5 | RESET | | 5 | 46 | CVBS <sub>5</sub> | 25 | 68 | PD <sub>9</sub> | 45 | 6 | CS\ | | 6 | 47 | CVBS <sub>4</sub> | 26 | 69 | PD <sub>8</sub> | 46 | 7 | R/W∖ | | 7 | 48 | OL <sub>3</sub> (TEST) | 27 | 70 | PD <sub>7</sub> | 47 | 8 | A <sub>1</sub> | | 8 | 49 | OL <sub>2</sub> (TEST) | 28 | 71 | PD <sub>6</sub> | 48 | 9 | A <sub>o</sub> | | 9 | 50 | OL <sub>1</sub> (TEST) | 29 | 72 | PD <sub>5</sub> | 49 | 11 | PĎC | | 10 | 51 | OL <sub>0</sub> (TEST) | 30 | 73 | PD <sub>4</sub> | 50 | 12 | VHSYNC\ | | 11 | 52 | PD <sub>23</sub> | 31 | 74 | PD <sub>3</sub> | 51 | 13 | VVSYNC\ | | 12 | 53 | PD <sub>22</sub> | 32 | 75 | PD <sub>2</sub> | 52 | 14 | D <sub>7</sub> | | 13 | 54 | PD <sub>21</sub> | 33 | 76 | PD <sub>1</sub> | 53 | 15 | D <sub>6</sub> | | 14 | 55 | PD <sub>20</sub> | 34 | 77 | PD <sub>0</sub> | 54 | 16 | D <sub>5</sub> | | 15 | 56 | l PD₁α l | 35 | 78 | LDV | 55 | 17 | $D_4$ | | 16 | 57 | l PD₁s l | 36 | 79 | PXCK | 56 | 18 | D <sub>3</sub> | | 17 | 58 | PD <sub>17</sub> | 37 | 82 | GVSYNC\ | 57 | 19 | $D_2$ | | 18 | 59 | PD <sub>16</sub> | 38 | 83 | GHSYNC\ | 58 | 20 | $D_1^-$ | | 19 | 60 | PD <sub>15</sub> | 39 | 84 | CVBS <sub>3</sub> | 59 | 21 | D <sub>0</sub> | | 20 | 61 | PD <sub>14</sub> | 40 | 1 | CVBS <sub>2</sub> | | | - | Figure 32. JTAG Test Port Timing Figure 33. Equivalent Analog Input Circuit Figure 34. Equivalent Analog Output Circuit Figure 35. Equivalent Digital Input Circuit Figure 36. Equivalent Digital Output Circuit Figure 37. Transition Levels for Three-State Measurements # Absolute Maximum Ratings (beyond which the device may be damaged) | Power Supply Voltage | 0.5 to +7.0V | |---------------------------------------------------------------|------------------------------| | Digital Inputs Applied Voltage <sup>2</sup> | 0.5 to Vpp+0.5V | | Applied Voltage <sup>2</sup><br>Forced Current <sup>3,4</sup> | -20.0 to 20.0 mA | | Digital Outputs | | | Applied Voltage <sup>2</sup> Forced Current <sup>3,4</sup> | 0.5 to V <sub>DD</sub> +0.5V | | Forced Current <sup>3,4</sup> | 20.0 to 20.0mA | | Short Circuit Duration (Single output in HIGH state to GND) | 1 second | | Analog Output Short Circuit Duration (Single output to GND) | infinite | | Temperature | | | Operating, case | 60 to +130°C | | Operating, Junction, Plastic package | +150°C | | Lead, soldering (10 seconds) | +300°C | | Vapor phase soldering (1 minute) | +220°C | | Storage | 65 to +150°C | ### Notes: - Absolute maximum ratings are limiting values applied individually while all other parameters are within specified operating conditions. Functional operation under any of these conditions is NOT implied. - 2. Applied voltage must be current limited to specified range, and measured with respect to GND. - 3. Forcing voltage must be limited to specified range. - 4. Current is specified as conventional current, flowing into the device. # TMC22X9X # **Operating Conditions** | | Temperature Range | | | | | | | |---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|------------------------------------|---------------|-------------------------------------------------------|----------------|--|--| | | | | | | | | | | Paramete | er | Min | Nom | Max | Units | | | | V <sub>DD</sub> | Power Supply Voltage | 4.75 | 5.0 | 5.25 | ٧ | | | | V <sub>IH</sub> | Input Voltage, Logic HIGH TTL Compatible Inputs, all but PXCK TTL Compatible Input PXCK CMOS Compatible Inputs | 2.0<br>2.5<br>(2/3)V <sub>DD</sub> | | V <sub>DD</sub><br>V <sub>DD</sub><br>V <sub>DD</sub> | V<br>V | | | | V <sub>IL</sub> | Input Voltage, Logic LOW<br>TTL Compatible Inputs<br>CMOS Compatible Inputs | GND<br>GND | | 0.8<br>(1/3)V <sub>DD</sub> | V | | | | I <sub>OH</sub> | Output Current, Logic HIGH<br>Output Current, Logic LOW | | | -2.0<br>4.0 | mA<br>mA | | | | V <sub>REF</sub> | External Reference Voltage D/A Converter Reference Current (I <sub>REF</sub> = V <sub>REF</sub> / R <sub>REF</sub> , flowing | 2.1 | 1.235<br>3.15 | 4.4 | V<br>mA | | | | R <sub>REF</sub> | out of the R <sub>REF</sub> pin) Reference Resistor, V <sub>REF</sub> = Nom. | 281 | 392 | 588 | Ω | | | | R <sub>OUT</sub> | Total Output Load Resistance | | 37.5 | | Ω | | | | TA | Ambient Temperature, Still Air | 0 | | 70 | °C | | | | Pixel Inte | erface | | | | | | | | f <sub>PXL</sub><br>f <sub>PXCK</sub> | Pixel Rate<br>Master Clock Rate, 2x pixel rate | 12.27<br>24.54 | | 15<br>30 | Mpps<br>MHz | | | | t <sub>PWHPX</sub> | PXCK Pulse Width, HIGH<br>PXCK Pulse Width, LOW | 10<br>10 | | | ns<br>ns | | | | t <sub>SP</sub><br>t <sub>HP</sub><br>t <sub>HP</sub> | Hold Time, PD and KEY | | | | ns<br>ns<br>ns | | | | t <sub>XL</sub><br>t <sub>PWHLDV</sub><br>t <sub>PWLLDV</sub> | Delay Time, LDV LDV Pulse Width, HIGH | | | | ns<br>ns<br>ns | | | # **Operating Conditions** | | | Tem | perature Rai | nge | | |----------------------------------------------------------------|--------------------------------------------------------------------------------------------------|----------------|--------------|-----|----------------| | | | | | 1 | | | Paramete | er | Min | Nom | Max | Units | | <sup>t</sup> PWLVH | VHSYNC∖ Pulse Width, LOW | 6 | | 15 | PXCK periods | | t <sub>PWHVV</sub> | VVSYNC\ Pulse Width, LOW | 0.5 | | 3 | H | | Genlock | Interface | | | | | | tsgi<br>t <sub>HGI</sub> | Setup Time, GHSYNCGVSYNCCVBS Hold Time, GHSYNC GVSYNCCVBS | 10<br>0 | | | ns<br>ns | | Micropro | ocessor Interface | | | | | | <sup>t</sup> PWLCS<br><sup>t</sup> PWLCS<br><sup>t</sup> PWHCS | CS\ Pulse Width, LOW, w/ KEY Reg.<br>CS\ Pulse Width, LOW, w/o KEY Reg.<br>CS\ Pulse Width, HIGH | 95<br>55<br>30 | | | ns<br>ns<br>ns | | t <sub>SA</sub><br>t <sub>HA</sub> | Address Setup Time<br>Address Hold Time | 10<br>0 | | | ns<br>ns | | t <sub>SD</sub> | Data Setup Time (write)<br>Data Hold Time (write) | 15<br>0 | | | ns<br>ns | | t <sub>SR</sub><br>t <sub>HR</sub> | Reset Setup Time<br>Reset Hold Time | 24<br>2 | | | ns<br>ns | | JTAG Int | JTAG Interface | | | | | | f <sub>TCK</sub> | Test Clock (TCK) Rate | | | 20 | MHz | | t <sub>PWLTCK</sub> | TCK Pulse Width, LOW<br>TCK Pulse Width, HIGH | 25<br>10 | | | ns<br>ns | | t <sub>STP</sub><br>t <sub>HTP</sub> | Test Port Setup Time, TDI, TMS<br>Test Port Hold Time, TDI, TMS | 10<br>3 | | | ns<br>ns | Note: 1. Timing reference points are at the 50% level. # TMC22X9X ### **Electrical Characteristics** | | | | Temperature Range | | | | |---------------------------------------------------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-------------------|--------------|-----------|--------------------------| | | | | , | Standard | | | | Paran | neter | Conditions | Min | Тур | Max | Units | | I <sub>DD</sub><br>I <sub>DDQ</sub> | Power Supply Current <sup>1</sup> Power Supply Current <sup>1</sup> (D/A disabled) | V <sub>DD</sub> =Max,f <sub>PXCK</sub> =30MHz<br>V <sub>DD</sub> =Max,f <sub>PXCK</sub> =30MHz | | 300 | 350<br>90 | mA<br>mA | | V <sub>RO</sub><br>I <sub>BR</sub> | Voltage Reference Output<br>Input Bias Current, V <sub>REF</sub> | V <sub>REF</sub> = Nom | 0.988 | 1.235<br>100 | 1.482 | V<br>μΑ | | II. | Input Current, Logic HIGH<br>Input Current, Logic LOW | $V_{DD} = Max$ , $V_{IN} = 4.0V$<br>$V_{DD} = Max$ , $V_{IN} = 0.4V$ | : | | 10<br>-10 | μ <b>Α</b><br>μ <b>Α</b> | | V <sub>OH</sub><br>V <sub>OL</sub> | Output Voltage, Logic HIGH<br>Output Voltage, Logic LOW | I <sub>OH</sub> = Max<br>I <sub>OL</sub> = Max | 2.4 | | 0.4 | <b>&gt;</b> | | l <sub>OZH</sub><br>l <sub>OZL</sub> | Hi-Z Leakage current, HIGH<br>Hi-Z Leakage current, LOW | $V_{DD} = Max$ , $V_{IN} = V_{DD}$<br>$V_{DD} = Max$ , $V_{IN} = GND$ | | | 10<br>-10 | μ <b>Α</b><br>μ <b>Α</b> | | c <sub>l</sub> co | Digital Input Capacitance<br>Digital Output Capacitance | T <sub>A</sub> = 25°C, f = 1MHz<br>T <sub>A</sub> = 25°C, f = 1MHz | | 4<br>10 | 10 | pF<br>pF | | V <sub>OC</sub><br>R <sub>OUT</sub><br>C <sub>OUT</sub> | Video Output Compliance Volta<br>Video Output Resistance<br>Video Output Capacitance | age<br>I <sub>OUT</sub> = 0 mA, f = 1 MHz | -0.3 | 15<br>15 | 2.0<br>25 | V<br>kΩ<br>pF | Note 1. Typical $I_{DD}$ with $V_{DD}$ =+5.0 Volts and $T_A$ =25°C, Maximum $I_{DD}$ with $V_{DD}$ =+5.25 Volts and $T_A$ =0°C. # **Switching Characteristics** | | N. S. C. R. S. C. | | Temp | erature F | Range | | |----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|---------|-----------|------------------|----------------------| | | | | | | | | | Paran | neter | Conditions | Min | Тур | Max | Units | | PIPES | Pipeline Delay <sup>3</sup> | PD to Analog Out | 44 | 44 | 44 | PXCK<br>periods | | t <sub>DOM</sub><br>t <sub>DOM</sub><br>t <sub>HOM</sub> | Output Delay, CS\ to Icw-Z Output Delay, CS\ to Data Valid Output Delay, CS\ to Data Valid Output Hold Time, CS\ to hi-Z | | 8<br>10 | | 23<br>125<br>100 | ns<br>ns<br>ns<br>ns | | t <sub>DOTP</sub> | Output Delay, TCK to TDO Valid<br>Output Hold Time, TCK to TDO | | | 5 | 30 | ns<br>ns | | t <sub>DOS</sub> | Output Delay | PXCK to VHSYNC<br>VVSYNC PDC | | | 25 | ns | | t <sub>R</sub> | D/A Output Current Risetime<br>D/A Output Current Falltime | 10% to 90% of full-scale<br>90% to 10% of full-scale | | 2 2 | | ns<br>ns | | t <sub>DOV</sub> | Analog Output Delay | | | 20 | | ns | ## Notes: - 1. Timing reference points are at the 50% level. - 2. Analog $C_{LOAD}$ <10 pF, $D_{7-0}$ load <40 pF. - Pipeline delay, with respect to PXCK, is a function of the phase relationship between the internally generated PCK (PXCK/2) and PXCK, as established by the hardware reset). - 4. t<sub>DOM</sub> (without KEY Register) = 1 PXCK + 54 ns = 100 ns worst-case at PXCK=24.54 MHz. # TMC22X9X ### **System Performance Characteristics** | | | Temp | | | | |------------------------------------|--------------------------------------------------------------------------------------------------------|------|------------|--------------|---------------------| | | | , | Standard | | | | Param | eter Conditions | Min | Тур | Max | Units | | RES | D/A Converter Resolution | 10 | 10 | 10 | Bits | | E <sub>LI</sub><br>E <sub>LD</sub> | Integral Linearity Error<br>Differential Linearity Error | | | 0.25<br>0.15 | %<br>% | | E <sub>G</sub> | Gain Error | | | ±5 | % FS | | dp<br>dg | Differential Phase PXCK = 24.54 MHz,40 IRE Ramp <sup>3</sup> PXCK = 24.54 MHz,40 IRE Ramp <sup>3</sup> | | 0.5<br>0.9 | | degree<br>% | | SKEW | CHROMA to LUMA Output Skew | | 0 | 1 | ns | | PSRR | Power Supply Rejection Ratio $C_{COMP}$ =0.1 $\mu$ F, f=1kHz | | 0.5 | | %/%ΔV <sub>DD</sub> | ### Notes - 1. TTL input levels are 0.0 and 3.0 Volts, 10%-90% rise and fall times <3 ns. - 2. Analog C<sub>LOAD</sub> <10 pF, D<sub>7-0</sub> load <40 pF. - 3. NTSC Figure 38. NTSC Vectors Figure 40. NTSC Horizontal Blanking Interval Figure 42. NTSC Differential Gain Figure 39. NTSC Color Bars Waveform Figure 41. NTSC Vertical Blanking Interval Figure 43. NTSC Differential Phase Figure 44. PAL Vectors Figure 46. PAL Horizontal Blanking Interval Figure 48. PAL Differential Gain Figure 45. PAL Color Bars Waveform Figure 47. PAL Vertical Blanking Interval Figure 49. PAL Differential Phase Figure 50. Color Bar Luminance Figure 51. Color Bar Chrominance Figure 52. Short Time Distortion Figure 53. K Factor Figure 54. NTSC Multiburst Figure 55. PAL Multiburst Figure 56. Recommended Interface Circuit ## **Application Notes** The TMC22x9x is a complex mixed-signal VLSI circuit. It handles TTL digital signals at clock rates of up to 30 MHz while producing analog outputs with a resolution of less than a millivolt. To maximize performance it is important to provide the product with a quiet operating environment. ### References The circuit shown provides a stable external 1.235V voltage reference to the TMC22x9x. To use the internal voltage reference source, simply leave the $V_{REF}$ pin unconnected except for the 0.1 $\mu F$ capacitor to ground. The accuracy the internal voltage reference is approximately $\pm 20\%$ . This variation can be overcome by varying the $R_{REF}$ resistor to get desired video output levels. It is recommended that a simple voltage divider from the power supply NOT be used, as any variations in power supply voltage would appear directly on the video outputs. The reference bandwidth is limited by the $0.1\mu F$ capacitor on the COMP pin, but low frequency signals (eg 60 Hz, 20 KHz power supply noise) will be passed through to the outputs. ### **Filtering** An inexpensive low-pass output filter is shown in Figure 57. This filter is located in the video signal path just after the COMPOSITE, LUMA, and CHROMA outputs of the TMC22x9x. The TMC22x9x has been designed to output adequate video levels to overcome the insertion loss of output filters. V<sub>REF</sub> and R<sub>REF</sub> may be varied to make up for filter loss. Since S-VIDEO comprises separate and simultaneous luminance and chrominance, it is important that the filters used on CHROMA and LUMA have identical group delay. Figure 57. Recommended Output Reconstruction Filter Figure 58. Response of Recommended Output Filter # Interface to the TMC22070 Genlocking Video Digitizer The TMC22x9x Digital Video Encoder has been designed to directly interface to the TMC22070 Genlocking Video Digitizer. The TMC22070 is the source for TMC22070 input signals CVBS<sub>7-0</sub>, GHSYNC\, GVSYNC\, and PXCK as shown in Figure 59. These signals directly connect to the TMC22190/191. The microprocessor interface for TMC22x9x and TMC22070 are identical. All W/R\, RESET\, data and address bus signals from the host microprocessor are shared by the TMC22x9x and TMC22070. Only CS\ and INT\ signals are separately driven from the microprocessor bus. ### **Grounding Strategy** The TMC22x9x has distinctly separate analog and digital circuits. To minimize digital crosstalk into the analog signals, the power supplies and grounds are provided over separate pins ( $V_{DD}$ and $D_{GND}$ are digital power supply pins; $V_{DDA}$ and $A_{GND}$ are analog supplies). In general, the best results are obtained by tying all grounds to a solid, low-impedance ground plane. Power supply pins should be individually decoupled at the pin. Power supply noise isolation may be provided between analog and digital supplies via a series inductor. Another approach calls for separating analog and digital ground. While some systems may benefit from this strategy, keep in mind that the analog and digital grounds must be kept within 0.5V of each other at all times. Figure 59. TMC22x9x-to-TMC22070 Interface Circuit ### **Printed Circuit Board Layout** Designing with high-performance mixed-signal circuits demands printed circuits with ground planes. Wire-wrap is not an option. Overall system performance is strongly influenced by the board layout. Capacitive coupling from digital to analog circuits may result in poor picture quality. Consider the following suggestions when doing the layout: - Keep analog traces (COMP, V<sub>REF</sub>, R<sub>REF</sub>, CHROMA, LUMA, COMPOSITE) as short and far from all digital signals as possible. The TMC22x9x should be located near the board edge, close to the analog output connectors. - The power plane for the TMC22x9x should be separate from that which supplies other digital circuitry. A single power plane should be used for all of the V<sub>DD</sub> pins. If the power supply for the TMC22x9x is the same for the system's digital circuitry, power to the TMC22x9x should be filtered with ferrite beads and 0.1μF capacitors to reduce noise. - The ground plane should be solid, not crosshatched. Connections to the ground plane should be very short. - Decoupling capacitors should be applied liberally to V<sub>DD</sub> pins. For best results, use 0.1μF capacitors in parallel with 0.01μF capacitors. Lead lengths should be minimized. Ceramic chip capacitors are the best choice. - If there is dedicated digital power plane, it should not overlap the TMC22x9x footprint, the voltage reference, or the analog outputs. Capacitive coupling of digital power supply noise from this layer to the TMC22x9x and its related analog circuitry can have an adverse effect on performance. - The PXCK should be handled carefully. Jitter and noise on this clock or its ground reference will translate to noise on the video outputs. Terminate the clock line carefully to eliminate overshoot and ringing. ### Microprocessor I/O Operations Various CLUT Read/Write operations are shown in Table 18. Each step in the table requires a CS\ pulse (falling edge followed by a rising edge) to execute. For Write operations, R/W\ and A<sub>1-0</sub> must conform to setup and hold timing with respect to the falling edge of CS\. D<sub>7-0</sub> must meet setup and hold timing with respect to the rising edge of CS\. These timing relationships are illustrated in Figure 11. When writing data into an internal register (i.e. CLUT Address Register) an extra CS\ falling edge is required to transfer the input data to that register. This requirement is usually accomplished by executing the next step in the sequence. If there is no planned next step in the sequence, executing a Control Register Read step will meet the requirement and terminate the sequence. For Read operations, R/W\ and A<sub>1-0</sub> must conform to setup and hold timing with respect to the falling edge of CS\. Read data on D<sub>7-0</sub> is initiated by the falling edge of CS\ and terminated by the rising edge of CS\ as shown in Figure 12. When reading Control Registers, valid data appears toom after the falling edge of CS\. When reading CLUT locations, an extra CLUT Read step is needed to set up the CLUT Read sequence. This is accomplished in the table by executing an extra CLUT Read step just before the CLUT Read sequence which returns successive d. e. and f data. CLUT Read sequences must be terminated an extra CS\ falling edge. This requirement is usually accomplished by executing the next I/O step. If there is no planned next step in the sequence, executing a Control Register Read step will meet the requirement and terminate the sequence. Table 18. CLUT Read/Write Sequences | Step | R/W\ | A <sub>1-0</sub> | D <sub>7-0</sub> | Function | |------|------|------------------|------------------|---------------------------------------------------------------| | | | | | Write Entire CLUT<br>Starting at Address 00 | | 1 | 0 | 01 | 00 | Write 00 into CLUT<br>Address Register. | | 2 | 0 | 11 | d1 | d1 written into D, CLUT address 00. | | 3 | 0 | 11 | e1 | e1 written into E, CLUT address 00. | | 4 | 0 | 11 | f1 | f1 written into F, CLUT address 00. | | | | •• | | repeat steps 3,4,5 until CLUT is full. | | 767 | 0 | 11 | d256 | d256 written into D, CLUT address FF. | | 768 | 0 | 11 | e256 | e256 written into E, CLUT address FF. | | 769 | 0 | 11 | f256 | f256 written into F, CLUT address FF. | | 770 | 1 | 00 | xx | Sequence termination. | | | | | | Write CLUT Location addr | | 1 | 0 | 01 | addr | Write addr into the CLUT | | 2 | 0 | 11 | d1 | Address Register.<br>d1 written into D, CLUT<br>address addr. | | 3 | 0 | 11 | e1 | e1 written into E, CLUT address addr. | | 4 | 0 | 11 | f1 | f1 written into F, CLUT address addr. | | 5 | 1 | 00 | xx | Sequence termination. | | | | | | Read CLUT Location addr | | 1 | 0 | 01 | addr | Write addr into the CLUT Address Register. | | 2 | 1 | 11 | xx | Set up for CLUT Read sequence. | | 3 | 1 | 11 | d1 | d1 read from D, CLUT<br>address addr. | | 4 | 1 | 11 | e1 | e1 read from E, CLUT address addr. | | 5 | 1 | 11 | f1 | f1 read from F, CLUT | | 6 | 1 | 00 | xx | Sequence termination. | | Step | R/W\ | A <sub>1-0</sub> | D <sub>7-0</sub> | Function | |------|------|------------------|------------------|-------------------------------------------------------------------| | | | | | Read CLUT Address<br>Register Then Write | | 1 | 1 | 01 | addr | Read CLUT Address<br>Register. | | 2 | 0 | 11 | d1 | d1 written into D, CLUT address addr. | | 3 | 0 | 11 | e1 | e1 written into E, CLUT address addr. | | 4 | 0 | 11 | f1 | f1 written into F, CLUT address addr. | | 5 | 1 | 01 | addr+1 | Read CLUT Address<br>Register. (terminates | | 6 | 0 | 11 | d2 | Write sequence) d2 written into D, CLUT address addr+1. | | 7 | 0 | 11 | e2 | e2 written into E, CLUT address addr+1. | | 8 | 0 | 11 | f2 | f2 written into F, CLUT | | 9 | 1 | 00 | хх | address addr+1. Sequence termination. | | | | | | Read/Modify/Write CLUT<br>Location addr | | 1 | 0 | 01 | addr | Write addr into the CLUT Address Register. | | 2 | 1 | 11<br>11 | xx<br>d1 | Set up for CLUT Read.<br>d1 read from D, CLUT | | 1 | , | | | address addr. | | 4 | 1 | 11 | e1 | e1 read from E, CLUT address addr. | | 5 | 1 | 11 | f1 | f1 read from F, CLUT address addr. | | | | •• | | System Modifies d1, e1, f1 to d1', e1', f1'. | | 6 | 0 | 01 | addr | Write addr into the CLUT<br>Address Register.<br>(terminates Read | | 7 | 0 | 11 | d1' | sequence) d1' written into D, CLUT address addr. | | 8 | 0 | 11 | e1' | e1' written into E, CLUT | | 9 | 0 | 11 | f1' | address addr. f1' written into F, CLUT | | 10 | 1 | 00 | xx | address addr.<br>Sequence termination. | | | | | | | Table 19. Pin Assignments for 84-lead PLCC Package (R0) | Pin | Name | Pln | Name | Pin | Name | Pin | Name | |-----|-------------------|-----|------------------|-----|------------------------|-----|---------------------| | 1 | CVBS <sub>2</sub> | 22 | TDO | 43 | V <sub>DDA</sub> | 64 | V <sub>DD</sub> | | 2 | CVBS <sub>1</sub> | 23 | TCK | 44 | CVBS <sub>7</sub> | 65 | D <sub>GND</sub> | | 3 | CVBS | 24 | TMS | 45 | CVBS <sub>6</sub> | 66 | PD <sub>11</sub> | | 4 | KEY | 25 | TDI | 46 | CVBS <sub>5</sub> | 67 | PD <sub>10</sub> | | 5 | RESET\ | 26 | D <sub>GND</sub> | 47 | CVBS <sub>4</sub> | 68 | PD <sub>9</sub> | | 6 | CS\ | 27 | $V_{DD}$ | 48 | OL <sub>3</sub> (TEST) | 69 | PD <sub>8</sub> | | 7 | R/W\ | 28 | BYPASS\(TEST) | 49 | OL <sub>2</sub> (TEST) | 70 | PD <sub>7</sub> | | 8 | A <sub>1</sub> | 29 | OL₄(TEST) | 50 | OL <sub>1</sub> (TEST) | 71 | PD <sub>6</sub> | | 9 | A <sub>0</sub> | 30 | V <sub>REF</sub> | 51 | OL <sub>0</sub> (TEST) | 72 | PD <sub>5</sub> | | 10 | D <sub>GND</sub> | 31 | R <sub>REF</sub> | 52 | PD <sub>23</sub> | 73 | $PD_4$ | | 11 | PDC | 32 | A <sub>GND</sub> | 53 | PD <sub>22</sub> | 74 | PD <sub>3</sub> | | 12 | VHSYNC\ | 33 | COMPOSITE | 54 | PD <sub>21</sub> | 75 | PD <sub>2</sub> | | 13 | VVSYNC\ | 34 | AGND | 55 | PD <sub>20</sub> | 76 | $PD_1$ | | 14 | D <sub>7</sub> | 35 | LÜMA | 56 | PD₁o | 77 | PD <sub>0</sub> | | 15 | D <sub>6</sub> | 36 | AGND | 57 | PD <sub>18</sub> | 78 | LDV | | 16 | D <sub>5</sub> | 37 | CHROMA | 58 | PD <sub>17</sub> | 79 | PXCK | | 17 | D <sub>4</sub> | 38 | AGND | 59 | PD <sub>16</sub> | 80 | D <sub>GND</sub> | | 18 | $D_3$ | 39 | COMP | 60 | PD <sub>15</sub> | 81 | l V <sub>DD</sub> l | | 19 | D <sub>2</sub> | 40 | $V_{DDA}$ | 61 | PD <sub>14</sub> | 82 | GVSYNC\ | | 20 | D <sub>1</sub> | 41 | $V_{DDA}$ | 62 | PD <sub>13</sub> | 83 | GHSYNC\ | | 21 | D <sub>0</sub> | 42 | V <sub>DDA</sub> | 63 | PD <sub>12</sub> | 84 | CVBS <sub>3</sub> | Note: Pin names in parentheses apply to TMC22090/091 # **Ordering Information** | Product<br>Number | Temperature<br>Range | Screening | Package | Package<br>Marking | |-------------------|------------------------------|------------|--------------|--------------------| | TMC22090R0C | T <sub>A</sub> = 0°C to 70°C | Commercial | 84-Lead PLCC | 22090R0C | | TMC22091R0C | T <sub>A</sub> = 0°C to 70°C | Commercial | 84-Lead PLCC | 22091R0C | | TMC22190R0C | T <sub>A</sub> = 0°C to 70°C | Commercial | 84-Lead PLCC | 22190R0C | | TMC22191R0C | T <sub>A</sub> = 0°C to 70°C | Commercial | 84-Lead PLCC | 22191R0C |