# 1.0 Functional Description

### 1.1 Functional Overview

Rockwell's VideoStream II products are a family of single-chip, pin-and register-compatible solutions for processing analog NTSC/PAL/SECAM video into digital 4:2:2 YCrCb video. They provide a comprehensive choice of capabilities to enable the feature set and cost to be tailored to different system hardware configurations. All solutions are housed in a 100-pin PQFP package. A detailed block diagram is shown in Figure 1-1.

1.1 Functional Overview

VideoStream II Decoders

Figure 1-1. Bt829B/827B Detailed Block Diagram



1.1 Functional Overview

#### 1.1.1 Bt829B Video Capture Processor for TV/VCR Analog Input

The Bt829B Video Capture Processor is a fully integrated single-chip decoding and scaling solution for analog NTSC/PAL/SECAM input signals from TV tuners, VCRs, cameras, and other sources of composite or Y/C video. It is the second generation front-end input solution for low-cost PC video/graphics systems that deliver complete integration and high-performance video synchronization, Y/C separation, and filtered scaling. The Bt829B has all the mixed signal and DSP circuitry required to convert an analog composite waveform into a scaled digital video stream, supporting a variety of video formats, resolutions, and frame rates.

#### 1.1.2 Bt827B Composite/S-Video Decoder

The Bt827B provides full composite and S-Video capability along with horizontal scaling. Vertical scaling can only be implemented by line-dropping.

The Synchronous Pixel Interface (SPI) is common to both pin-compatible devices, which enables implementation of a single system hardware design. Similarly, a common I<sup>2</sup>C register set allows a single piece of driver code to be written for software control of both options. Table 1-1 compares Bt829B and Bt827B features.

|  | Table | 1-1. | VideoStream | 11 | Features | Options |
|--|-------|------|-------------|----|----------|---------|
|--|-------|------|-------------|----|----------|---------|

| Feature Options                | Bt829B | Bt827B |
|--------------------------------|--------|--------|
| Composite Video Decoding       | Х      | Х      |
| S-Video Decoding               | Х      | Х      |
| SECAM Video                    | Х      | Х      |
| Hardware Closed Caption Decode | Х      | Х      |
| 3.3 V Digital I/O              | Х      | Х      |
| Filtered Vertical Scaling      | Х      |        |

1.1 Functional Overview VideoStream II Decoders

#### 1.1.3 Bt829B Architecture and Partitioning

The Bt829B has been developed to provide the most cost-effective, high-quality video input solution. It is used for low-cost multimedia subsystems that integrate both graphics display and video capabilities. The feature set of the Bt829B supports a video/graphics system partitioning which optimizes the total cost of a system configured both with and without video capture capabilities. This enables system vendors to easily offer products with various levels of video support using a single base-system design.

As graphics chip vendors move from graphics-only to video/graphics coprocessors, and eventually to single-chip video/graphics processor implementations, the ability to efficiently use silicon and package pins to support both graphics acceleration, video playback acceleration, and video capture becomes critical. This problem becomes more acute as the race towards higher performance graphics requires more and more package pins to be consumed for wide 64-bit memory interfaces and glueless local bus interfaces.

The Bt829B minimizes the cost of video capture function integration in two ways. First, recognizing that YCrCb to RGB color space conversion is a required feature of multimedia controllers for acceleration of digital video playback, the Bt829B avoids redundant functionality and allows the downstream controller to perform this task. Second, the Bt829B can minimize the number of interface pins required by a downstream multimedia controller in order to keep package costs to a minimum. The Bt829B can also output all timing and data signals at 3.3 V levels.

Controller systems designed to take advantage of these features allow video capture capability to be added to the base system in a modular fashion using only a single Integrated Circuit (IC).

The Bt827B is targeted at system configurations using video processors which typically integrate the scaling function.

#### 1.1.4 UltraLock

The Bt829B and Bt827B employ a proprietary technique known as UltraLock to lock to the incoming analog video signal. It will always generate the required number of pixels per line from an analog source in which the line length can vary by as much as a few microseconds. UltraLock's digital locking circuitry enables the VideoStream decoders to quickly and accurately lock on to video signals, regardless of their source. Since the technique is completely digital, UltraLock can recognize unstable signals caused by VCR headswitches or any other deviation and adapt the locking mechanism to accommodate the source. UltraLock uses nonlinear techniques which are difficult, if not impossible, to implement in genlock systems. And unlike linear techniques, it adapts the locking mechanism automatically.

1.1 Functional Overview

#### 1.1.5 Scaling and Cropping

The Bt829B can reduce the video image size in both horizontal and vertical directions independently using arbitrarily selected scaling ratios. The X and Y dimensions can be scaled down to one-sixteenth of the full resolution. Horizontal scaling is implemented with a 6-tap interpolation filter, while up to 5-tap interpolation is used for vertical scaling with a line store. The Bt827B supports vertical scaling by line-dropping.

The video image can be arbitrarily cropped by programming the ACTIVE flag to reduce the number of active scan lines and active horizontal pixels per line.

The Bt829B and Bt827B also support a temporal decimation feature that reduces video bandwidth by allowing frames or fields to be dropped from a video sequence at regular but arbitrarily selected intervals.

#### 1.1.6 Input Interface

Analog video signals are input to the Bt829B/827B via a four-input multiplexer that can select between four composite source inputs or between three composite and a single S-Video input source. When an S-Video source is input to the Bt829B, the luma component is fed through the input analog multiplexer, and the chroma component is fed directly into the C-input pin. An AGC circuit enables the Bt829B/827B to compensate for reduced amplitude in the analog signal input.

The clock signal interface consists of two pairs of pins for crystal connection and two clock output pins. One pair of crystal pins is for connection to a 28.64 MHz (8\*NTSC Fsc) crystal which is selected for NTSC operation. The other is for PAL operation with a 35.47 MHz (8\*PAL Fsc) crystal. Either of the two crystal frequencies can be selected to generate CLKx1 and CLKx2 output signals. CLKx2 operates at the full crystal frequency (8\*Fsc), whereas CLKx1 operates at half the crystal frequency (4\*Fsc). Either fundamental or third harmonic crystals may be used. Alternatively, CMOS oscillators may be used.

#### 1.1.7 Output Interface

The Bt829B and Bt827B support a Synchronous Pixel Interface (SPI) mode.

The SPI supports a YCrCb 4:2:2 data stream over an 8- or 16-bit-wide path. When the pixel output port is configured to operate 8-bits wide, 8 bits of chrominance data are output on the first clock cycle followed by 8 bits of luminance data on the next clock cycle for each pixel. Two clocks are required to output one pixel in this mode, thus a 2x clock is used to output the data.

The Bt829B/827B outputs all horizontal and vertical blanking pixels in addition to the active pixels synchronous with CLKX1 (16-bit mode) or CLKX2 (8-bit mode). It is also possible to insert control codes into the pixel stream using chrominance and luminance values that are outside the allowable chroma and luma ranges. These control codes can be used to flag video events such as ACTIVE, HRESET, and VRESET. Decoding these video events downstream enables the video controller to eliminate pins required for the corresponding video control signals. Both Bt829B and Bt827B can output (or receive) all digital timing, clock, and data signals at either 5 V or 3.3 V levels for connection to 5 V or 3.3 V graphics/video controllers.

1.1 Functional Overview

VideoStream II Decoders

#### 1.1.8 VBI Data Pass-Through

The Bt829B/827B provides VBI data passthrough capability. The VBI region ancillary data is captured by the video decoder and made available to the system for subsequent software processing. The Bt829B/827B may operate in a VBI Line Output mode, in which the VBI data is only made available during select lines. This mode of operation is intended to enable capture of VBI lines containing ancillary data as well as processing normal YCrCb video image data. In addition, the Bt829B/827B supports a VBI Frame Output mode, in which every line in the video signal is treated as if it was a vertical interval line and no image data is output. This mode of operation is designed for use in still-frame capture/processing applications.

#### 1.1.9 Closed Caption Decoding

The Bt829B and Bt827B provide a Closed Captioning (CC) and Extended Data Services (EDS) decoder. Data presented to the video decoder on the CC and EDS lines is decoded and made available to the system through the CC\_DATA and CCSTATUS registers.

#### 1.1.10 I<sup>2</sup>C Interface

The Bt829B/827B registers are accessed via a two-wire I<sup>2</sup>C interface. The Bt829B/827B operates as a slave device. Serial clock and data lines, SCL and SDA, transfer data from the bus master at a rate of 100 Kbits/s. Chip select and reset signals are also available to select one of two possible Bt829B/827B devices in the same system and to set the registers to their default values.

1.2 Pin Descriptions

## 1.2 Pin Descriptions

Figure 1-2 details the Bt829B and Bt827B pinout. Table 1-2 provides pin numbers, names, input and output functions, and descriptions.

Figure 1-2. Bt829B/827B Pinout Diagram



8

VideoStream II Decoders

Table 1-2. Pin Descriptions Grouped By Pin Function (1 of 4)

| Pin#              | 1/0 | Pin Name | Description                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |     |          | Input Stage Pins                                                                                                                                                                                                                                                                                                                                                                                          |
| 45, 50, 55,<br>57 | I   | MUX[3:0] | Analog composite video inputs to the on-chip input multiplexer. They are used to select between four composite sources or three composite and one S-Video source. Unused pins should be connected to GND.                                                                                                                                                                                                 |
| 53                | 0   | MUXOUT   | The analog video output of the 4-to-1 multiplexer. Connected to the YIN pin.                                                                                                                                                                                                                                                                                                                              |
| 52                | ı   | YIN      | The analog composite or luma input to the Y-ADC.                                                                                                                                                                                                                                                                                                                                                          |
| 67                | 1   | CIN      | The analog chroma input to the C-ADC.                                                                                                                                                                                                                                                                                                                                                                     |
| 59                | ı   | SYNCDET  | The sync stripper input generates timing information for the AGC circuit. Can be optionally connected through a 0.1 $\mu\text{F}$ capacitor to the same source as the Y-ADC, to maintain compatibility with Bt829 board layouts. A 1 $M\Omega$ bleeder resistor can be connected to ground, to maintain compatibility with Bt829 board layouts. For new Bt829B designs, this pin may be connected to VAA. |
| 41                | A   | AGCCAP   | The AGC time constant control capacitor node. Must be connected to a 0.1 $\mu\text{F}$ capacitor to ground.                                                                                                                                                                                                                                                                                               |
| 43                | 0   | REFOUT   | Output of the AGC which drives the YREF+ and CREF+ pins.                                                                                                                                                                                                                                                                                                                                                  |
| 49                | Α   | YREF+    | The top of the reference ladder of the Y-ADC. This should be connected to REFOUT.                                                                                                                                                                                                                                                                                                                         |
| 62                | А   | YREF-    | The bottom of the reference ladder of the Y-ADC. This should be connected to analog ground (AGND).                                                                                                                                                                                                                                                                                                        |
| 64                | Α   | CREF+    | The top of the reference ladder of the C-ADC. This should be connected to REFOUT.                                                                                                                                                                                                                                                                                                                         |
| 73                | А   | CREF-    | The bottom of the reference ladder of the C-ADC. This should be connected to analog ground (AGND).                                                                                                                                                                                                                                                                                                        |
| 74                | A   | CLEVEL   | An input to provide the DC level reference for the C-ADC. For compatibility with Bt829 board layouts, the 30 k $\Omega$ divider resistors may be maintained. Note: This pin should be left to float for new Bt829B designs.                                                                                                                                                                               |
| 51                | А   | N/C      | No connect.                                                                                                                                                                                                                                                                                                                                                                                               |
| 46                | Α   | N/C      | No connect.                                                                                                                                                                                                                                                                                                                                                                                               |
| 63, 68            | Α   | N/C      | No connect.                                                                                                                                                                                                                                                                                                                                                                                               |
| 70                | Α   | N/C      | No connect.                                                                                                                                                                                                                                                                                                                                                                                               |
| 69                | A   | N/C      | No connect.                                                                                                                                                                                                                                                                                                                                                                                               |
|                   |     |          | I <sup>2</sup> C Interface Pins                                                                                                                                                                                                                                                                                                                                                                           |
| 19                | ı   | SCL      | The I <sup>2</sup> C Serial Clock Line.                                                                                                                                                                                                                                                                                                                                                                   |
| 18                | I/O | SDA      | The I <sup>2</sup> C Serial Data Line.                                                                                                                                                                                                                                                                                                                                                                    |
| 14                | ı   | I2CCS    | The $I^2C$ Chip Select Input (TTL compatible). This pin selects one of two Bt829B devices in the same system. This pin is internally pulled to ground with an effective 18 K $\Omega$ resistance.                                                                                                                                                                                                         |
| 15                | I   | RST      | Reset Control Input (TTL compatible). A logical 0 for a minimum of four consecutive clock cycles resets the device to its default state. A logical 0 for less than eight XTAL cycles will leave the device in an undetermined state.                                                                                                                                                                      |

1.2 Pin Descriptions

Table 1-2. Pin Descriptions Grouped By Pin Function (2 of 4)

| Pin#  | 1/0 | Pin Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |          | Video Timing Unit Pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 82    | 0   | HRESET   | Horizontal Reset Output (TTL compatible). This signal indicates the beginning of a new line of video. This signal is 64 CLKx1 clock cycles wide. The falling edge of this output indicates the beginning of a new scan line of video. This pin may be defined in pixels as opposed to CLKx1 cycles. Refer to the HSFMT bit in the VTC register. Note: The polarity of this pin is programmable through the VPOLE register.                                                                                                                                                                                                                       |
| 79    | 0   | VRESET   | Vertical Reset Output (TTL compatible). This signal indicates the beginning of a new field of video. This signal is output coincident with the rising edge of CLKx1, and is normally 6 lines wide. The falling edge of VRESET indicates the beginning of a new field of video.  Note: The polarity of this pin is programmable through the VPOLE register.                                                                                                                                                                                                                                                                                       |
| 83    | 0   | ACTIVE   | Active Video Output (TTL compatible). This pin can be programmed to output the composite active or horizontal active signal via the VTC register. It is a logical high during the active/viewable periods of the video stream. The active region of the video stream is programmable.  Note: The polarity of this pin is programmable through the VPOLE register.                                                                                                                                                                                                                                                                                |
| 94    | 0   | QCLK     | Qualified Clock Output. This pin provides a rising edge only during valid, active pixel data. This output is generated from CLKx1 (or CLKx2 in 8-bit mode), DVALID and, if programmed, ACTIVE. The phase of QCLK is inverted from the CLKx1 (or CLKx2) to ensure adequate setup and hold time with respect to the data outputs. QCLK is not output during control codes when using SPI mode 2.                                                                                                                                                                                                                                                   |
| 98    | I   | <u>O</u> | Output Enable Control (TTL compatible). All video timing unit output pins and all clock interface output pins contain valid data following the rising edge of CLKx2, after $\overline{\text{OE}}$ has been asserted low. This function is asynchronous. The three-stated pins include: VD[15:0], $\overline{\text{HRESET}}$ , $\overline{\text{VRESET}}$ , $\overline{\text{ACTIVE}}$ , $\overline{\text{DVALID}}$ , $\overline{\text{CBFLAG}}$ , $\overline{\text{FIELD}}$ , $\overline{\text{QCLK}}$ , $\overline{\text{CLKx1}}$ , and $\overline{\text{CLKx2}}$ . See the OES bits in the OFORM register to disable subgroups of output pins. |
| 78    | 0   | FIELD    | Odd/Even Field Output (TTL compatible). A high state on the FIELD pin indicates that an odd field is being digitized.  Note: The polarity of this pin is programmable through the VPOLE register.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 89    | 0   | CBFLAG   | Cb Data Identifier (TTL compatible). A high state on this pin indicates that the current chroma byte contains Cb chroma information.  Note: The polarity of this pin is programmable through the VPOLE register.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2-9   | 0   | VD[15:8] | Digitized Video Data Outputs (TTL compatible). VD[0] is the least significant bit of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 22–29 | 1/0 | VD[7:0]  | the bus in 16-bit mode. VD[8] is the least significant bit of the bus in 8-bit mode. The information is output with respect to CLKx1 in 16-bit mode, and CLKx2 in 8-bit mode. In mode 2, this port is configured to output control codes as well as data. When data is output in 8-bit mode using VD[15:8], VD[7:0] can be used as general purpose I/O pins. See the P_IO register.                                                                                                                                                                                                                                                              |
| 84    | 0   | DVALID   | Data Valid Output (TTL compatible). This pin indicates when a valid pixel is being output onto the data bus. The Bt829B digitizes video at eight times the subcarrier rate, and outputs scaled video. Therefore, there are more clocks than valid data. DVALID indicates when valid pixel data is being output.  Note: The polarity of this pin is programmable through the VPOLE register.                                                                                                                                                                                                                                                      |
| 87    | 0   | CCVALID  | A logical low on this pin indicates that the CC FIFO is half full (8 characters). This pin may be disabled. This open drain output requires a pullup resistor for proper operation. However, if closed captioning is not implemented, this pin may be left unconnected.                                                                                                                                                                                                                                                                                                                                                                          |

1.2 Pin Descriptions

VideoStream II Decoders

Table 1-2. Pin Descriptions Grouped By Pin Function (3 of 4)

| Pin# | 1/0 | Pin Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 91   | I   | PWRDN    | A logical high on this pin puts the device into power-down mode. This is equivalent to programming CLK_SLEEP high in the ADC register.                                                                                                                                                                                                                                                                                                                                  |
| 86   | 0   | VACTIVE  | Vertical Blanking Output (TTL compatible). The falling edge of VACTIVE indicates the beginning of the active video lines in a field. This occurs VDELAY/2 lines after the rising edge of VRESET. The rising edge of VACTIVE indicates the end of active video lines and occurs ACTIVE_LINES/2 lines after the falling edge of VACTIVE. VACTIVE is output following the rising edge of CLKx1.  Note: The polarity of the pin is programmable through the VPOLE register. |
| 85   | I   | OEPOLE   | A logical low on this pin allows the Bt829B/827B to power up in the same manner as the Bt829/827. A logical high on this pin, followed by a device reset will TRISTATE the video outputs, sync outputs, and clock outputs.                                                                                                                                                                                                                                              |
|      |     |          | Clock Interface Pins                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12   | Α   | XT0I     | Clock Zero pins. A 28.64 MHz (8* Fsc) fundamental (or third harmonic) crystal can be                                                                                                                                                                                                                                                                                                                                                                                    |
| 13   | Α   | XT0O     | tied directly to these pins, or a single-ended oscillator can be connected to XT01. CMOS level inputs must be used. This clock source is selected for NTSC input sources. When the chip is configured to decode PAL but not NTSC (and therefore only one clock source is needed), the 35.47 MHz source is connected to this port (XT0).                                                                                                                                 |
| 16   | Α   | XT1I     | Clock One pins. A 35.47 MHz (8* Fsc) fundamental (or third harmonic) crystal can be                                                                                                                                                                                                                                                                                                                                                                                     |
| 17   | Α   | XT1O     | tied directly to these pins, or a single-ended oscillator can be connected to XT11. CMOS level inputs must be used. This clock source is selected for PAL input sources. If only NTSC or PAL is being decoded, and therefore only XT01 and XT0O are connected to a crystal, XT11 should be tied either high or low, and XT1O <i>must</i> be left floating.                                                                                                              |
| 97   | 0   | CLKx1    | 1x clock output (TTL compatible). The frequency of this clock is 4* Fsc (14.31818 MHz for NTSC or 17.73447 MHz for PAL).                                                                                                                                                                                                                                                                                                                                                |
| 99   | 0   | CLKx2    | 2x clock output (TTL compatible). The frequency of this clock is 8* Fsc (28.63636 MHz for NTSC, or 35.46895 MHz for PAL).                                                                                                                                                                                                                                                                                                                                               |
| 80   | I   | NUMXTAL  | Crystal Format Pin. This pin is set to indicate whether one or two crystals are present so that the Bt829B can select XT1 or XT0 as the default in auto format mode. A logical 0 on this pin indicates one crystal is present. A logical 1 indicates two crystals are present. This pin is internally pulled down to ground with an effective 18 K $\Omega$ resistance.                                                                                                 |
|      |     |          | JTAG Pins                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 34   | I   | TCK      | Test Clock (TTL compatible). Used to synchronize all JTAG test structures. When JTAG operations are not being performed, this pin must be driven to a logical low.                                                                                                                                                                                                                                                                                                      |
| 36   | I   | TMS      | Test Mode Select (TTL compatible). JTAG input pin whose transitions drive the JTAG state machine through its sequences. When JTAG operations are not being performed, this pin must be left floating or tied high.                                                                                                                                                                                                                                                      |
| 37   | I   | TDI      | Test Data Input (TTL compatible). JTAG pin used for loading instruction into the TAP controller or for loading test vector data for boundary-scan operation. When JTAG operations are not being performed, this pin must be left floating or tied high.                                                                                                                                                                                                                 |
| 32   | 0   | TDO      | Test Data Output (TTL compatible). JTAG pin used for verifying test results of all JTAG sampling operations. This output pin is active for certain JTAG operations and will be three-stated at all other times.                                                                                                                                                                                                                                                         |

1.2 Pin Descriptions

Table 1-2. Pin Descriptions Grouped By Pin Function (4 of 4)

| Pin#                                                 | 1/0                   | Pin Name               | Description                                                                                                                                                                                                                                                         |  |  |  |  |
|------------------------------------------------------|-----------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 35                                                   | I                     | TRST                   | Test Reset (TTL compatible). JTAG pin used to initialize the JTAG controller. This pin is tied low for normal device operation. When pulled high, the JTAG controller is ready for device testing.                                                                  |  |  |  |  |
|                                                      | Power And Ground Pins |                        |                                                                                                                                                                                                                                                                     |  |  |  |  |
| 10, 38, 76,<br>88, 96                                | Р                     | VDD +5 V               | Power supply for digital circuitry. All VDD pins must be connected together as close to the device as possible. A 0.1 μF ceramic capacitor should be connected between each group of VDD pins and the ground plane as close to the device as possible.              |  |  |  |  |
| 1, 20, 30, 92                                        | Р                     | VDDO + 3.3 V           | Power supply for 3.3 V digital circuitry. All VDDO pins must be connected together as close to the device as possible. A 0.1 µF ceramic capacitor should be connected between each group of VDDO pins and the ground plane, as close to the device as possible.     |  |  |  |  |
| 40, 44, 48,<br>60, 65, 72                            | Р                     | VAA +5 V,<br>VPOS +5 V | Power supply for analog circuitry. All VAA pins and VPOS must be connected together as close to the device as possible. A 0.1 $\mu$ F ceramic capacitor should be connected between each group of VAA pins and the ground plane as close to the device as possible. |  |  |  |  |
| 11, 21, 31,<br>33, 39, 77,<br>81, 90, 93,<br>95, 100 | G                     | GND                    | Ground for digital circuitry. All GND pins must be connected together as close to the device as possible.                                                                                                                                                           |  |  |  |  |
| 42, 47, 54,<br>56, 58, 61,<br>66, 71, 75             | G                     | AGND, VNEG             | Ground for analog circuitry. All AGND pins and VNEG must be connected together as close to the device as possible.                                                                                                                                                  |  |  |  |  |

#### I/O Column Legend:

- I = Digital Input
- O = Digital Output I/O = Digital Bidirectional
- A = Analog
- G = Ground
- P = Power

# 1.3 Differences Between Bt829A/827A and Bt829B/827B

While both Bt829A/827A and Bt829B/827B video decoders are pin and software compatible, please note the differences, as described in Table 1-3.

A 3.3 V mode has been added which allows the Bt829B to interface to 3.3 V graphic/video controllers without the use of 5 V to 3.3 V level translators.

Table 1-3. Pin Function Differences

| Pins          | Bt829A/<br>827A | Bt829B/<br>827B | Comments                                                                                                |
|---------------|-----------------|-----------------|---------------------------------------------------------------------------------------------------------|
| 1, 20, 30, 92 | VDD             | VDDO            | For 3.3 V I/O, connect the pins to the 3.3 V supply. For 5 V I/O, connect these pins to the 5 V supply. |

See Figure 3-4 for typical power and ground connections when in 3.3 V I/O mode. The pins listed in Table 1-4 can output 3.3 V signal levels when pins 1, 20, 30, and 92 (VDDO) are connected to a 3.3 V power supply.

Table 1-4. 3.3 V Pin Output

| Pin Number | Pin Name |
|------------|----------|
| 82         | HRESET   |
| 79         | VRESET   |
| 83         | ACTIVE   |
| 94         | QCLK     |
| 78         | FIELD    |
| 89         | CBFLAG   |
| 2–9        | VD[15:8] |
| 22–29      | VD[7:0]  |
| 84         | DVALID   |
| 87         | CCVALID  |
| 86         | VACTIVE  |
| 97         | CLKX1    |
| 99         | CLKX2    |
| 32         | TDO      |

1.3 Differences Between Bt829A/827A and Bt829B/827B

The pins shown in Table 1-5 can receive 3.3 V signal levels when pins 1, 20, 30, and 92 (VDDO) are connected to a 3.3 V power supply:

Table 1-5. 3.3 V Pin Input

| Pin Number | Pin Name |
|------------|----------|
| 19         | SCL      |
| 18         | SDA      |
| 14         | I2CCS    |
| 15         | RST      |
| 98         | ŌĒ       |
| 91         | PWRDN    |
| 85         | OEPOLE   |
| 80         | NUMXTAL  |
| 34         | тск      |
| 36         | TMS      |
| 37         | TDI      |
| 35         | TRST     |

When using the Bt829B/827B in the 3.3 V I/O mode with the third overtone crystal oscillators, the tank circuit required is different to the tank circuit when in 5 V I/O mode. See Figures 2-1, 2-2, 2-3, and 2-4.

1.4 UltraLock VideoStream II Decoders

#### 1.4 UltraLock

#### 1.4.1 The Challenge

The line length (the interval between the midpoints of the falling edges of succeeding horizontal sync pulses) of analog video sources is not constant. For a stable source such as a studio grade video source or test signal generators, this variation is very small:  $\pm 2$  ns. However, for an unstable source such as a VCR, laser disk player, or TV tuner, line length variation is as much as a few microseconds.

Digital display systems require a fixed number of pixels per line, despite these variations. The Bt829B employs a technique known as UltraLock to implement locking to the horizontal sync and the subcarrier of the incoming analog video signal and generating the required number of pixels per line.

#### 1.4.2 Operation Principles of UltraLock

UltraLock is based on sampling, using a fixed-frequency stable clock. Because the video line length will vary, the number of samples generated using a fixed-frequency sample clock will also vary from line-to-line. If the number of generated samples-per-line is always greater than the number of samples-per-line required by the particular video format, the number of acquired samples can be reduced to fit the required number of pixels per line.

The Bt829B requires an 8\*Fsc (28.64 MHz for NTSC and 35.47 MHz for PAL) crystal or oscillator input signal source. The 8\*Fsc clock signal, or CLKx2, is divided down to CLKx1 internally (14.32 MHz for NTSC and 17.73 MHz for PAL). Both CLKx2 and CLKx1 are made available to the system. UltraLock operates at CLKx1 although the input waveform is sampled at CLKx2 then low-pass filtered and decimated to CLKx1 sample rate.

At a 4\*Fsc (CLKx1) sample rate there are 910 pixels for NTSC and 1,135 pixels for PAL/SECAM within a nominal line time interval (63.5 µs for NTSC and 64 µs for PAL/SECAM). For square pixel NTSC and PAL/SECAM formats there should only be 780 and 944 pixels-per-video line, respectively. This is because the square pixel clock rates are slower than a 4\*Fsc clock rate: for example, 12.27 MHz for NTSC and 14.75 MHz for PAL.

UltraLock accommodates line length variations from nominal in the incoming video by always acquiring more samples (at an effective 4\*Fsc rate) than are required by the particular video format. It then outputs the correct number of pixels per line. UltraLock then interpolates the required number of pixels so that it maintains the stability of the original image, despite variation in the line length of the incoming analog waveform.

Figure 1-3 illustrates three successive lines of video being decoded for square pixel NTSC output. The first line is shorter than the nominal NTSC line time interval of 63.5  $\mu$ s. On this first line, a line time of 63.2  $\mu$ s sampled at 4\*Fsc (14.32 MHz) generates only 905 pixels. The second line matches the nominal line time of 63.5  $\mu$ s and provides the expected 910 pixels. Finally, the third line is too long at 63.8  $\mu$ s within which 913 pixels are generated. In all three cases, UltraLock outputs only 780 pixels.

VideoStream II Decoders 1.4 UltraLock





UltraLock can be used to extract any programmable number of pixels from the original video stream as long as the sum of the nominal pixel line length (910 for NTSC and 1,135 for PAL/SECAM) and the worst case line length variation from nominal in the active region is greater than or equal to the required number of output pixels per line, for example:

$$P_{Nom} + P_{Var} \ge P_{Desired}$$

where:  $P_{Nom}$  = Nominal number of pixels per line at 4\*Fsc sample rate (910 for NTSC, 1,135 for PAL/SECAM)  $P_{Var}$  = Variation of pixel count from nominal at 4\*Fsc (can be a positive or negative number)

 $P_{Desired}$  = Desired number of output pixels per line

**NOTE:** For stable inputs, UltraLock guarantees the time between the falling edges of HRESET only to within one pixel. UltraLock does, however, guarantee the number of active pixels in a line as long as the stated relationship holds.

# 1.5 Composite Video Input Formats

The Bt829B supports several composite video input formats. Table 1-6 specifies the different video formats and some of the countries in which each format is used.

Table 1-6. Video Input Formats Supported by the Bt829B

| Format                    | Lines        | Fields    | F <sub>SC</sub>        | Country                                |
|---------------------------|--------------|-----------|------------------------|----------------------------------------|
| NTSC-M                    | 525          | 60        | 3.58 MHz               | U.S., many others                      |
| NTSC-Japan <sup>(1)</sup> | 525          | 60        | 3.58 MHz               | Japan                                  |
| PAL-B                     | 625          | 50        | 4.43 MHz               | Many                                   |
| PAL-D                     | 625          | 50        | 4.43 MHz               | China                                  |
| PAL-G                     | 625          | 50        | 4.43 MHz               | Many                                   |
| PAL-H                     | 625          | 50        | 4.43 MHz               | Belgium                                |
| PAL-I                     | 625          | 50        | 4.43 MHz               | Great Britain, others                  |
| PAL-M                     | 525          | 60        | 4.43 MHz               | Brazil                                 |
| PAL-N                     | 625          | 50        | 4.43 MHz               | Paraguay, Uruguay                      |
| PAL-N combination         | 625          | 50        | 3.58 MHz               | Argentina                              |
| SECAM                     | 625          | 50        | 4.406 MHz<br>4.250 MHz | Eastern Europe, France,<br>Middle East |
| Notes: (1). NTSC-Jap      | oan has 0 IF | RE setup. |                        |                                        |

1.5 Composite Video Input Formats

The video decoder must be programmed appropriately for each of the composite video input formats. Table 1-7 lists the register values that need to be programmed for each input format.

Table 1-7. Register Values for Video Input Formats

| Register                                            | Bit                    | NTSC-M                                                 | NTSC-Japan                               | PAL-B, D,<br>G, H, I                                     | PAL-M                                    | PAL-N                                                 | PAL-N<br>Combination                    | SECAM                                                 |
|-----------------------------------------------------|------------------------|--------------------------------------------------------|------------------------------------------|----------------------------------------------------------|------------------------------------------|-------------------------------------------------------|-----------------------------------------|-------------------------------------------------------|
| IFORM<br>(0x01)                                     | XTSEL<br>4:3           | 01                                                     | 01                                       | 10                                                       | 01                                       | 10                                                    | 01                                      | 10                                                    |
|                                                     | FORMAT<br>2:0          | 001                                                    | 010                                      | 011                                                      | 100                                      | 101                                                   | 111                                     | 110                                                   |
| Cropping:<br>HDELAY,<br>VDELAY,<br>VACTIVE,<br>CROP | 7:0 in all 5 registers | Set to<br>desired crop-<br>ping values<br>in registers | Set to NTSC-<br>M square pixel<br>values | Set to desired<br>cropping val-<br>ues in regis-<br>ters | Set to NTSC-<br>M square pixel<br>values | Set to PAL-B,<br>D, G, H, I<br>square pixel<br>values | Set to PAL-B, D, G,<br>H, I CCIR values | Set to PAL-B,<br>D, G, H, I<br>square pixel<br>values |
| HSCALE<br>(0x08,<br>0x09)                           | 15:0                   | 0x02AA                                                 | 0x02AA                                   | 0x033C                                                   | 0x02AC                                   | 0x033C                                                | 0x00F8                                  | 0x033C                                                |
| ADELAY<br>(0x18)                                    | 7:0                    | 0x68                                                   | 0x68                                     | 0x7F                                                     | 0x68                                     | 0x7F                                                  | 0x7F                                    | 0x7F                                                  |
| BDELAY<br>(0x19)                                    | 7:0                    | 0x5D                                                   | 0x5D                                     | 0x72                                                     | 0x5D                                     | 0x72                                                  | 0x72                                    | 0xA0                                                  |

# 1.6 Y/C Separation and Chroma Demodulation

Y/C separation and chroma decoding is illustrated in Figure 1-4. Bandpass and notch filters are implemented to separate the composite video stream. Figure 1-5 displays the filter responses. The optional chroma comb filter is implemented in the vertical scaling block. See the Video Scaling, Cropping, and Temporal Decimation section in this chapter.

Figure 1-4. Y/C Separation and Chroma Demodulation for Composite Video



Figure 1-5. Y/C Separation Filter Responses



1.6 Y/C Separation and Chroma Demodulation

Figure 1-6 schematically describes the filtering and scaling operations.

In addition to the Y/C separation and chroma demodulation illustrated in Figure 1-4, the Bt829B also supports chrominance comb filtering as an optional filtering stage after chroma demodulation. The chroma demodulation generates baseband I and Q (NTSC) or U and V (PAL/SECAM) color difference signals.

For S-Video operation, the digitized luma data bypasses the Y/C separation block completely, and the digitized chrominance is passed directly to the chroma demodulator.

For monochrome operation, the Y/C separation block is also bypassed, and the saturation registers (SAT\_U and SAT\_V) are set to zero.

Figure 1-6. Filtering and Scaling Operations



Note: Z-1 refers to a pixel delay in the horizontal direction, and a line delay in the vertical direction. The coefficients are determined by UltraLock and the scaling algorithm.

## 1.7 Video Scaling, Cropping, and Temporal Decimation

The Bt829B provides three mechanisms to reduce the amount of video pixel data in its output stream: down-scaling, cropping, and temporal decimation. All three can be controlled independently.

#### 1.7.1 Horizontal and Vertical Scaling

The Bt829B provides independent and arbitrary horizontal and vertical downscaling. The maximum scaling ratio is 16:1 in both X and Y dimensions. The maximum vertical scaling ratio is reduced from 16:1 when using frames, and to 8:1 when using fields. The different methods utilized for scaling luminance and chrominance are described in the following sections.

#### 1.7.2 Luminance Scaling

The first stage in horizontal luminance scaling is an optional pre-filter which provides the capability to reduce antialiasing artifacts. It is generally desirable to limit the bandwidth of the luminance spectrum prior to performing horizontal scaling because the scaling of high-frequency components may create image artifacts in the resized image.

The optional low-pass filters shown in Figure 1-7 reduce the horizontal highfrequency spectrum in the luminance signal. Figure 1-8 and Figure 1-9 illustrates the combined results of the optional low-pass filters, and the luma notch and 2x oversampling filter.



PAL/SECAM Amplitude in dB [20\*log10[ampl]] ICON dB [20\*1 Frequency in MHz

1.7 Video Scaling, Cropping, and Temporal Decimation



Figure 1-8. Combined Luma Notch, 2x Oversampling and Optional Low-Pass Filter Response (NTSC)





The Bt829B implements horizontal scaling through poly-phase interpolation. The Bt829B uses 32 different phases to accurately interpolate the value of a pixel. This provides an effective pixel jitter of less than 6 ns.

In simple pixel- and line-dropping algorithms, non-integer scaling ratios introduce a step function in the video signal that effectively introduces high-frequency spectral components. Poly-phase interpolation accurately interpolates to the correct pixel and line position providing more accurate information. This results in more aesthetically pleasing video as well as higher compression ratios in bandwidth limited applications.

For vertical scaling, the Bt829B uses a line store to implement four different filtering options. The filter characteristics are shown in Figure 1-10. The Bt829B provides up to 5-tap filtering to ensure removal of aliasing artifacts. Figure 1-11 displays the combined responses of the luma notch and 2x oversampling filters.

1.7 Video Scaling, Cropping, and Temporal Decimation

VideoStream II Decoders

Figure 1-10. Frequency Responses for the Four Optional Vertical Luma Low-Pass Filters



Figure 1-11. Combined Luma Notch and 2x Oversampling Filter Response



1.7 Video Scaling, Cropping, and Temporal Decimation

### 1.7.3 Peaking

The Bt829B enables four different peaking levels by programming the PEAK bit and HFILT bits in the SCLOOP register. The filters are shown in Figures 1-12 and 1-13.

Figure 1-12. Peaking Filters



Figure 1-13. Luma Peaking Filters with 2x Oversampling Filter and Luma Notch



The number of taps in the vertical filter is set by the VTC register. The user may select two, three, four, or five taps. The number of taps must be chosen in conjunction with the horizontal scale factor to ensure that the needed data can fit in the internal FIFO (see the VFILT bits in the VTC register for limitations). As the scaling ratio is increased, the number of taps available for vertical scaling is increased. In addition to low-pass filtering, vertical interpolation is also employed to minimize artifacts when scaling to non-integer scaling ratios. The Bt827B employs line dropping for vertical scaling.

1.7 Video Scaling, Cropping, and Temporal Decimation

#### 1.7.4 Chrominance Scaling

A 2-tap, 32-phase interpolation filter is used for horizontal scaling of chrominance. Vertical scaling of chrominance is implemented through chrominance comb filtering using a line store, followed by simple decimation or line dropping.

#### 1.7.5 Scaling Registers

Horizontal Scaling Ratio Register (HSCALE) HSCALE is programmed with the horizontal scaling ratio. When outputting unscaled video (in NTSC), the Bt829B will produce 910 pixels per line. This corresponds to the pixel rate at  $f_{CLKx1}$  (4\*Fsc). This register is the control for scaling the video to the desired size. For example, square pixel NTSC requires 780 samples-per-line, while CCIR601 requires 858 samples-per-line. HSCALE\_HI and HSCALE\_LO are two 8-bit registers that, when concatenated, form the 16-bit HSCALE register.

The method below uses pixel ratios to determine the scaling ratio. The following formula should be used to determine the scaling ratio to be entered into the 16-bit register:

NTSC:  $HSCALE = [(910/P_{desired}) - 1] * 4096$ PAL/SECAM:  $HSCALE = [(1135/P_{desired}) - 1] * 4096$ 

where:  $P_{desired}$  = Desired number of pixels per line of video, including active, sync and blanking.

For example, to scale PAL/SECAM input to square pixel QCIF, the total number of horizontal pixels is 236:

An alternative method for determining the HSCALE value uses the ratio of the scaled active region to the unscaled active region as shown below:

NTSC: HSCALE = [ (754 / HACTIVE) – 1] \* 4096 PAL/SECAM: HSCALE = [ (922 / HACTIVE) – 1] \* 4096

where: *HACTIVE* = Desired number of pixels per line of video, not including sync or blanking.

1.7 Video Scaling, Cropping, and Temporal Decimation

VideoStream II Decoders

In this equation, the HACTIVE value cannot be cropped; it represents the total active region of the video line. This equation produces roughly the same result as using the full line length ratio shown in the first example. However, due to truncation, the HSCALE values determined using the active pixel ratio will be slightly different than those obtained using the total line length pixel ratio. The values in Table 1-8 were calculated using the full line length ratio.

Table 1-8. Scaling Ratios for Popular Formats Using Frequency Values

|                 |                                                              | Total                                                         |                                                  |                                      | VSCALE Reg                               | ister Values                         |
|-----------------|--------------------------------------------------------------|---------------------------------------------------------------|--------------------------------------------------|--------------------------------------|------------------------------------------|--------------------------------------|
| Scaling Ratio   | Format                                                       | Resolution<br>(including<br>sync and<br>blanking<br>interval) | Output<br>Resolution<br>(Active Pixels)          | HSCALE<br>Register<br>Values         | Use Both<br>Fields                       | Single<br>Field                      |
| Full Resolution | NTSC SQ Pixel<br>NTSC CCIR601                                | 780 x 525<br>858 x 525                                        | 640 x 480<br>720 x 480                           | 0x02AC<br>0x00F8                     | 0x0000<br>0x0000                         | N/A<br>N/A                           |
|                 | PAL CCIR601<br>PAL SQ Pixel                                  | 864 x 625<br>944 x 625                                        | 720 x 576<br>720 x 576<br>768 x 576              | 0x0504<br>0x033C                     | 0x0000<br>0x0000                         | N/A<br>N/A                           |
| CIF<br>2:1      | NTSC SQ Pixel<br>NTSC CCIR601<br>PAL CCIR601<br>PAL SQ Pixel | 390 x 262<br>429 x 262<br>432 x 312<br>472 x 312              | 320 x 240<br>360 x 240<br>360 x 288<br>384 x 288 | 0x1555<br>0x11F0<br>0x1A09<br>0x1679 | 0x1 E00<br>0x1 E00<br>0x1 E00<br>0x1 E00 | 0x0000<br>0x0000<br>0x0000<br>0x0000 |
| QCIF<br>4:1     | NTSC SQ Pixel<br>NTSC CCIR601<br>PAL CCIR601<br>PAL SQ Pixel | 195 x 131<br>214 x 131<br>216 x 156<br>236 x 156              | 160 x 120<br>180 x 120<br>180 x 144<br>192 x 144 | 0x3AAA<br>0x3409<br>0x4412<br>0x3CF2 | 0x1 A00<br>0x1 A00<br>0x1 A00<br>0x1 A00 | 0x1E00<br>0x1E00<br>0x1E00<br>0x1E00 |
| ICON<br>8:1     | NTSC SQ Pixel<br>NTSC CCIR601<br>PAL CCIR601<br>PAL SQ Pixel | 97 x 65<br>107 x 65<br>108 x 78<br>118 x 78                   | 80 x 60<br>90 x 60<br>90 x 72<br>96 x 72         | 0x861A<br>0x7813<br>0x9825<br>0x89E5 | 0x1200<br>0x1200<br>0x1200<br>0x1200     | 0x1A00<br>0x1A00<br>0x1A00<br>0x1A00 |

Notes: 1. PAL-M-HSCALE and VSCALE register values should be the same for NTSC.

3. SECAM-HSCALE and VSCALE register values should be the same as for PAL.

<sup>2.</sup> PAL-N combination—HSCALE register values should be the same as for CCIR resolution NTSC. VSCALE register values should be the same as for CCIR resolution PAL.

1.7 Video Scaling, Cropping, and Temporal Decimation

**Vertical Scaling Ratio Register (VSCALE)** VSCALE is programmed with the vertical scaling ratio. It defines the number of vertical lines output by the Bt829B. The following formula should be used to determine the value to be entered into this 13-bit register. The loaded value is a two's-complement, negative value.

```
VSCALE = (0x10000 - \{ (scaling_ratio) - 1) * 512 \}) & 0x1FFF
```

For example, to scale PAL/SECAM input to square pixel QCIF, the total number of vertical lines for PAL square pixel is 156 (see Table 1-8).

```
VSCALE = (0x10000 - \{ [(4/1) - 1] * 512 \}) & 0x1FFF
= 0x1A00
```

NOTE: Only the 13 least significant bits (LSBs) of the VSCALE value are used. The five LSBs of VSCALE\_HI and the 8-bit VSCALE\_LO register form the 13-bit VSCALE register. The three MSBs of VSCALE\_HI are used to control other functions. The user must take care not to alter the values of the three most significant bits when writing a vertical scaling value. The following C-code fragment illustrates changing the vertical scaling value:

```
#define BYTE unsigned char
#define WORD unsigned int
#define VSCALE HI 0x13
#define VSCALE LO 0x14
BYTE ReadFromBt829B( BYTE regAddress );
void WriteToBt829B( BYTE regAddress, BYTE regValue );
void SetBt829BVScaling( WORD VSCALE )
BYTE oldVscaleMSByte, newVscaleMSByte;
/* get existing VscaleMSByte value from */
/* Bt829B VSCALE_HI register */
oldVscaleMSByte = ReadFromBt829B( VSCALE_HI );
/* create a new VscaleMSByte, preserving top 3 bits */
newVscaleMSByte = (oldVscaleMSByte & 0xE0) | (VSCALE >> 8);
/* send the new VscaleMSByte to the VSCALE_HI reg */
WriteToBt829B( VSCALE HI, newVscaleMSByte );
/* send the new VscaleLSByte to the VSCALE_LO reg */
WriteToBt829B( VSCALE_LO, (BYTE) VSCALE );
}
```

1.7 Video Scaling, Cropping, and Temporal Decimation

VideoStream II Decoders

where: & = bitwise AND | = bitwise OR >> = bit shift, MSB to LSB

If your target machine has sufficient memory to statically store the scaling values locally, the READ operation can be eliminated.

On vertical scaling (when scaling below CIF resolution) it may be useful to use a single field as opposed to using both fields. Using a single field will ensure there are no inter-field motion artifacts on the scaled output. When performing single field scaling, the vertical scaling ratio will be twice as large as when scaling with both fields. For example, CIF scaling from one field does not require any vertical scaling, but when scaling from both fields, the scaling ratio is 50%. Also, the non-interlaced bit should be reset when scaling from a single field (INT = 0 in the VSCALE\_HI register). Table 1-8 lists scaling ratios for various video formats, and the register values required.

#### 1.7.6 Image Cropping

Cropping enables the user to output any subsection of the video image. The ACTIVE flag can be programmed to start and stop at any position on the video frame as shown in Figure 1-14. The start of the active area in the vertical direction is referenced to VRESET (beginning of a new field). In the horizontal direction it is referenced to HRESET (beginning of a new line). The dimensions of the active video region are defined by HDELAY, HACTIVE, VDELAY, and VACTIVE. All four registers are 10-bit values. The two MSBs of each register are contained in the CROP register, while the lower 8 bits are in the respective HDELAY\_LO, HACTIVE\_LO, VDELAY\_LO, and VACTIVE\_LO registers. The vertical and horizontal delay values determine the position of the cropped image within a frame while the horizontal and vertical active values set the pixel dimensions of the cropped image as illustrated in Figure 1-14.

29

VideoStream II Decoders

1.7 Video Scaling, Cropping, and Temporal Decimation

Figure 1-14. Effect of the Cropping and Active Registers



#### 1.7.7 Cropping Registers

Horizontal Delay Register (HDELAY) HDELAY is programmed with the delay between the falling edge of HRESET and the rising edge of ACTIVE. The count is programmed with respect to the scaled frequency clock.

NOTE: HDELAY should always be an even number.

Horizontal Active Register (HACTIVE) HACTIVE is programmed with the actual number of active pixels per line of video. This is equivalent to the number of scaled pixels that the Bt829B should output on a line. For example, if this register contained 90, and HSCALE was programmed to down-scale by 4:1, then 90 active pixels would be output. The 90 pixels would be a 4:1 scaled image of the 360 pixels (at CLKx1) starting at count HDELAY. HACTIVE is restricted in the following manner:

HACTIVE + HDELAY ≤ Total Number of Scaled Pixels.

For example, in the NTSC square pixel format, there is a total of 780 pixels, including blanking, sync and active regions. Therefore:

 $HACTIVE + HDELAY \leq 780$ .

When scaled by 2:1 for CIF, the total number of active pixels is 390. Therefore:

#### HACTIVE +HDELAY $\leq$ 390.

The HDELAY register is programmed with the number of scaled pixels between HRESET and the first active pixel. Because the front porch is defined as the distance between the last active pixel and the next horizontal sync, the video line can be considered in three components: HDELAY, HACTIVE, and the front porch. Figure 1-15 illustrates the video signal regions.

Figure 1-15. Regions of the Video Signal



1.7 Video Scaling, Cropping, and Temporal Decimation

When cropping is not implemented, the number of clocks at the 4x sample rate (the CLKx1 rate) in each of these regions is as follows:

|           | CLKx1<br>Front Porch | CLKx1<br>HDELAY | CLKx1<br>HACTIVE | CLKx1<br>Total |
|-----------|----------------------|-----------------|------------------|----------------|
| NTSC      | 21                   | 135             | 754              | 910            |
| PAL/SECAM | 27                   | 186             | 922              | 1135           |

The value for HDELAY is calculated using the following formula:

HDELAY = [(CLKx1\_HDELAY / CLKx1\_HACTIVE) \* HACTIVE] & 0x3FE

CLKx1\_HDELAY and CLKx1\_HACTIVE are constant values, so the equation becomes:

NTSC: HDELAY = [(135 / 754) \* HACTIVE] & 0x3FE PAL/SECAM: HDELAY = [(186 / 922) \* HACTIVE] & 0x3FE

In this equation, the HACTIVE value cannot be cropped.

**Vertical Delay Register (VDELAY)** VDELAY is programmed with the delay between the rising edge of VRESET and the start of active video lines. It determines how many lines to skip before initiating the ACTIVE signal. It is programmed with the number of lines to skip at the beginning of a frame.

**Vertical Active Register (VACTIVE)** VACTIVE is programmed with the number of lines used in the vertical scaling process. The actual number of vertical lines output from the Bt829B is equal to this register times the vertical scaling ratio. If VSCALE is set to 0x1A00 (4:1), then the actual number of lines output is VACTIVE/4. If VSCALE is set to 0x0000 (1:1), then VACTIVE contains the actual number of vertical lines output.

NOTE: It is important to note the difference between the implementation of the horizontal registers (HSCALE, HDELAY, and HACTIVE) and the vertical registers (VSCALE, VDELAY, and VACTIVE). Horizontally, HDELAY and HACTIVE are programmed with respect to the scaled pixels defined by HSCALE. Vertically, VDELAY and VACTIVE are programmed with respect to the number of lines before scaling (before VSCALE is applied).

#### 1.7.8 Temporal Decimation

Temporal decimation provides a solution for video synchronization during periods when full frame rate cannot be supported due to bandwidth and system restrictions.

For example, when capturing live video for storage, system limitations such as hard disk transfer rates or system bus bandwidth may limit the frame capture rate. If these restrictions limit the frame rate to 15 frames per second, the Bt829B's time scaling operation will enable the system to capture every other frame instead of allowing the hard disk timing restrictions to dictate which frame to capture. This maintains an even distribution of captured frames and alleviates the "jerky" effects caused by systems that simply burst in data when the bandwidth becomes available.

The Bt829B provides temporal decimation on either a field or frame basis. The Temporal Decimation TDEC register is loaded with a value from 1 to 60 (NTSC) or 1 to 50 (PAL/SECAM). This value is the number of fields or frames skipped by the chip during a sequence of 60 for NTSC or 50 for PAL/SECAM. Skipped fields and frames are considered inactive, which is indicated by the ACTIVE pin remaining low. Consequently if QCLK is programmed to depend on ACTIVE, QCLK would become inactive as well.

**Examples:** 

| TDEC = 0x02 | Decimation is performed by frames. Two frames are skipped per 60 frames of video, assuming NTSC decoding. |  |
|-------------|-----------------------------------------------------------------------------------------------------------|--|
|             | Frames 1–29 are output normally, then ACTIVE re-                                                          |  |
|             | mains low for one frame. Frames 30–59 are then output followed by another frame of inactive video.        |  |
| TDEC = 0x9E | Decimation is performed by fields. Thirty fields are                                                      |  |
|             | output per 60 fields of video, assuming NTSC                                                              |  |
|             | decoding.                                                                                                 |  |
|             | This value outputs every other field (every odd field)                                                    |  |
|             | of video starting with Field 1 in Frame 1.                                                                |  |
| TDEC = 0x01 | Decimation is performed by frames. One frame is                                                           |  |
|             | skipped per 50 frames of video, assuming                                                                  |  |
|             | PAL/SECAM decoding.                                                                                       |  |
| TDEC = 0x00 | Decimation is not performed. Full frame rate video is                                                     |  |

When changing the programming in the temporal decimation register, 0x00 should be loaded first, and then the decimation value. This will ensure that the decimation counter is reset to zero. If zero is not first loaded, the decimation may start on any field or frame in the sequence of 60 (or 50 for PAL/SECAM). On power-up, this preload is not necessary because the counter is reset internally.

output by the Bt829B.

When decimating fields, the FLDALIGN bit in the TDEC register can be programmed to choose whether the decimation starts with an odd field or an even field. If the FLDALIGN bit is set to logical 0, the first field that is dropped during the decimation process will be an odd field. Conversely, setting the FLDALIGN bit to logical 1 causes the even field to be dropped first in the decimation process.

1.8 Video Adjustments

## 1.8 Video Adjustments

The Bt829B provides programmable hue, contrast, saturation, and brightness.

#### 1.8.1 The Hue Adjust Register (HUE)

The Hue Adjust Register is used to offset the hue of the decoded signal. In NTSC, the hue of the video signal is defined as the phase of the subcarrier with reference to the burst. The value programmed in this register is added or subtracted from the phase of the subcarrier, which effectively changes the hue of the video. The hue can be shifted by  $\pm 90$  degrees. Because of the nature of PAL/SECAM encoding, hue adjustments cannot be made when decoding PAL/SECAM.

#### 1.8.2 The Contrast Adjust Register (CONTRAST)

The Contrast Adjust Register (also called the luma gain) provides the ability to change the contrast from approximately 0 percent to 200 percent of the original value. The decoded luma value is multiplied by the 9-bit coefficient loaded into this register.

#### 1.8.3 The Saturation Adjust Registers (SAT\_U, SAT\_V)

The Saturation Adjust Registers are additional color adjustment registers. It is a multiplicative gain of the U and V signals. The value programmed in these registers are the coefficients for the multiplication. The saturation range is from approximately 0 percent to 200 percent of the original value.

#### 1.8.4 The Brightness Register (BRIGHT)

The Brightness Register is simply an offset for the decoded luma value. The programmed value is added or subtracted from the original luma value which changes the brightness of the video output. The luma output is in the range of 0 to 255. Brightness adjustment can be made over a range of -128 to +127.

## 1.9 Bt829B VBI Data Output Interface

#### 1.9.1 Introduction

A frame of video is composed of 525 lines for NSTC and 625 for PAL/SECAM. Figure 1-16 illustrates an NTSC video frame in which there are a number of distinct regions. The video image or picture data is contained in the ODD and EVEN fields within lines 21–262 and lines 283–525, respectively. Each field of video also contains a region for vertical synchronization (lines 1–9 and 263–272) as well as a region which can contain non-video ancillary data (lines 10–20 and 273–282). We will refer to these regions which are between the vertical synchronization region and the video picture region as the Vertical Blanking Interval (VBI) portion of the video signal.

Figure 1-16. Regions of the Video Frame



#### 1.9.2 Overview

In the default configuration of the Bt829B, the VBI region of the video signal is treated the same way as the video image region of the signal. The Bt829B will decode this signal as if it was video. For example, it will digitize at 8xFsc, decimate/filter to a 4xFsc sample stream, color separate to derive luma and chroma component information, and interpolate for video synchronization and horizontal scaling. This process is shown in Figure 1-17.

Figure 1-17. Bt829B YCrCb 4:2:2 Data Path



1.9 Bt829B VBI Data Output Interface

The Bt829B can be configured in a mode known as VBI data pass through to enable capture of the VBI region ancillary data for later processing by software. In this mode the VBI region of the video signal is processed as follows:

- The analog composite video signal is digitized at 8\*Fsc (28.63636 MHz for NTSC and 35.46895 MHz for PAL/SECAM). This 8-bit value represents a number range from the bottom of sync tip to the peak of the composite video signal.
- The 8-bit data stream bypasses the decimation filter, Y/C separation filters, and the interpolation filter (see Figure 1-18).
- The Bt829B provides the option to pack the 8\*Fsc data stream into a 2-byte-wide stream at 4\*Fsc before outputting it to the VD[15:0] data pins, or it can simply be output as an 8-bit 8\*Fsc data stream on pins VD[15:8]. In the packed format, the first byte of each pair on a 4\*Fsc clock cycle is mapped to VD[15:8] and the second byte to VD[7:0] with VD[7] and VD[15] being the MSBs. The Bt829B uses the same 16-pin data port for VBI data and YCrCb 4:2:2 image data. The byte pair ordering is programmable.

Figure 1-18. Bt829B VBI Data Path



- The VBI datastream is not pipeline-delayed to match the YCrCb 4:2:2 image output data with respect to horizontal timing (i.e., valid VBI data will be output earlier than YCrCb 4:2:2 relative to the Bt829B HRESET signal).
- A larger number of pixels per line are generated in VBI output mode than in YCrCb 4:2:2 output mode. The downstream video processor must be capable of dealing with a varying number of pixels per line in order to capture VBI data, as well as YCrCb 4:2:2 data from the same frame.
- The following pins may be used to implement this solution: VD[15:0], VACTIVE, HACTIVE, DVALID, VRESET, HRESET, CLKx1, CLKx2, and QCLK. This should allow the downstream video processor to load the VBI data and the YCrCb 4:2:2 data correctly.
- Because the 8\*Fsc data stream does not pass through the interpolation filter, the sample stream is not locked/synchronized to the horizontal sync timing. The only implication of this is that the sample locations on each line are not correlated vertically.

1.9 Bt829B VBI Data Output Interface

VideoStream II Decoders

#### 1.9.3 Functional Description

There are three modes of operation for the Bt829B VBI data pass-through feature:

- 1 VBI Data Pass through Disabled. This is the default mode of operation for the Bt829B during which the device decodes composite video and generates a YCrCb 4:2:2 data stream.
- VBI Line Output Mode. The device outputs unfiltered 8\*Fsc data only during the vertical interval which is defined by the VACTIVE output signal provided by the Bt829B. Data is output between the trailing edge of the VRESET signal and the leading edge of VACTIVE. When VACTIVE is high, the Bt829B is outputting standard YCrCb 4:2:2 data. This mode of operation is intended to be used to enable capture of VBI lines containing ancillary data in addition to processing normal YCrCb 4:2:2 video image data
- 3 VBI Frame Output Mode. In this mode the Bt829B treats every line in the video signal as if it were a vertical interval line and outputs only the unfiltered 8\*Fsc data on every line (i.e., it does not output any image data). This mode of operation is designed for use in still-frame capture/processing applications.

#### 1.9.4 VBI Line Output Mode

The VBI line output mode is enabled via the VBIEN bit in the VTC Register (0x1B). When enabled, the VBI data is output during the VBI active period. The VBI horizontal active period is defined as the interval between consecutive Bt829B  $\overline{\text{HRESET}}$  signals. Specifically, it starts at a point one CLKx1 interval after the trailing edge of the first  $\overline{\text{HRESET}}$  and ends with the leading edge of the following  $\overline{\text{HRESET}}$ . This interval is coincident with the HACTIVE signal as indicated in Figure 1-19.

Figure 1-19. VBI Line Output Mode Timing



DVALID is always at a logical 1 during VBI. Also, QCLK is operating continuously at CLKx1 or CLKx2 rate during VBI. Valid VBI data is available one CLKx1 (or QCLK) interval after the trailing edge of HRESET. When the Bt829B is configured in VBI line output mode, it is generating invalid data outside of the VBI horizontal active period. In standard YCrCb output mode, the horizontal active period starts at a time point delayed from the leading edge of HRESET as defined by the value programmed in the HDELAY register.

VideoStream II Decoders

1.9 Bt829B VBI Data Output Interface

The VBI data sample stream which is output during the VBI horizontal active period represents an 8\*Fsc sampled version of the analog video signal starting in the vicinity of the subcarrier burst and ending after the leading edge of the horizontal synchronization pulse as illustrated in Figure 1-20.

Figure 1-20. VBI Sample Region



The number of VBI data samples generated on each line may vary depending on the stability of the analog composite video signal input to the Bt829B. The Bt829B will generate 845 16-bit VBI data words for NTSC and 1,070 16-bit VBI data words for PAL/SECAM on each VBI line at a CLKx1 rate, assuming a nominal or ideal video input signal (i.e., the analog video signal has a stable horizontal time base). This is also equivalent to 1,690 8-bit VBI data samples for NTSC and 2,140 8-bit VBI data samples for PAL/SECAM. These values can deviate from the nominal depending on the actual line length of the analog video signal.

The VBI vertical active period is defined as the period between the trailing edge of the Bt829B  $\overline{\text{VRESET}}$  signal and the leading edge of VACTIVE.

**NOTE:** The extent of the VBI vertical active region can be controlled by setting different values in the VDELAY register. This provides the flexibility to configure the VBI vertical active region as any group of consecutive lines starting with line 10 and extending to the line number set by the equivalent line count value in the VDELAY register (i.e., the VBI vertical active region can be extended into the video image region of the video signal).

The VBI horizontal active period starts with the trailing edge of an HRESET; therefore, if a rising edge of VRESET occurs after the horizontal active period has already started, the VBI active period starts on the following line. The HACTIVE pin is held at a logical 1 during the VBI horizontal active period. DVALID is held high during both the VBI horizontal active and horizontal inactive periods (i.e., it is held high during the whole VBI scan line.) These relationships are illustrated in Figure 1-21.

1.9 Bt829B VBI Data Output Interface

VideoStream II Decoders

Figure 1-21. Location of VBI Data



1.9 Bt829B VBI Data Output Interface

The Bt829B can provide VBI data in all the pixel port output configurations (i.e., 16-bit SPI, 8-bit SPI, and ByteStream modes). The range of the VBI data can be controlled with the RANGE bit in the OFORM Register (0x12). It is necessary to limit the range of VBI data for ByteStream output mode.

There must be a video signal present on the Bt829B analog input as defined by the status of the VPRES bit in the STATUS register in order for the Bt829B to generate VBI data. If the status of the VPRES bit reflects no analog input, then the Bt829B generates YCrCb data to create a flat blue field image.

The order in which the VBI data is presented on the output pins is programmable. Setting the VBIFMT bit in the VTC register to a logical 0 places the nth data sample on VD[15:8] and the nth+1 sample on VD[7:0]. Setting VBIFMT to a logical 1, logical 0 reverses the above. Similarly, in ByteStream and 8-bit output modes, setting VBIFMT = 0 generates a VBI sample stream with an ordering sequence of n+1, n, n+3, n+2, n+5, n+4, etc. Setting VBIFMT = 1 for ByteStream/8-bit output generates an n, n+1, n+2, n+3, etc. sequence as shown in Figure 1-22.



Figure 1-22. VBI Sample Ordering

A video processor/controller must be able to do the following to capture VBI data output by the Bt829B:

- Keep track of the line count in order to select a limited number of specific lines for processing of VBI data.
- Handle data type transitioning on the fly from the vertical interval to the active video image region. For example, during the vertical interval with VBI data pass through enabled, it must grab every byte pair while HACTIVE is high using the 4\*Fsc clock or QCLK. However, when the data stream transitions into YCrCb 4:2:2 data mode with VACTIVE going high, the video processor must interpret the DVALID signal (or use QCLK for the data load clock) from the Bt829B for pixel qualification and use only valid pixel cycles to load image data (default Bt829B operation).
- Handle a large and varying number of horizontal pixels per line in the VBI region as compared to the active image region.

1.9 Bt829B VBI Data Output Interface

VideoStream II Decoders

### 1.9.5 VBI Frame Output Mode

In VBI frame output mode, the Bt829B is generating VBI data all the time (i.e., there is no VBI active interval). In essence, the Bt829B is acting as an ADC continuously sampling the entire video signal at 8\*Fsc. The Bt829B generates HRESET, VRESET and FIELD timing signals in addition to the VBI data, but the DVALID, HACTIVE, and VACTIVE signals are all held high during VBI frame output operation. The behavior of the HRESET, VRESET, and FIELD timing signals is the same as normal YCrCb 4:2:2 output operation. The HRESET, VRESET, and FIELD timing signals can be used by the video processor to detect the beginning of a video frame/field, at which point it can start to capture a full frame/field of VBI data.

The number of VBI data samples generated on each line may vary depending on the stability of the analog composite video signal input to the Bt829B. The Bt829B will generate 910 16-bit VBI data words for NTSC and 1,135 16-bit VBI data words for PAL/SECAM for each line of analog video input at a CLKx1 rate, assuming a nominal or ideal video input signal (i.e., analog video signal has a stable horizontal time base). This is also equivalent to 1,820 8-bit VBI data samples for NTSC and, 270 8-bit VBI data samples for PAL/SECAM for each line of analog video input. These values can deviate from the nominal depending on the actual line length of the analog video signal.

VBI frame output mode is enabled via the VBIFRM bit in the OFORM register. The output byte ordering may be controlled by the VBIFMT bit as described for VBI line output mode. If both VBI line output and VBI frame output modes are enabled at the same time, the VBI frame output mode takes precedence. The VBI data range in VBI frame output mode can be controlled using the RANGE bit in the OFORM register, and a video signal must be present on the Bt829B analog input for this mode to operate as defined by the status of the VPRES bit in the STATUS register (0x00).

# 1.10 Closed Captioning and Extended Data Services Decoding

In a system capable of capturing Closed Captioning and Extended Data Services adhering to the EIA-608 standard, 2 bytes of information are presented to the video decoder on line 21 (odd field) for CC and an additional two bytes are presented on line 284 (even field) for EDS.

The data presented to the video decoder is an analog signal on the composite video input. The signal contains information identifying it as the CC/EDS data and is followed by a control code and 2 bytes of digital information transmitted by the analog signal. For the purposes of CC/EDS, only the luma component of the video signal is relevant. Therefore, the composite signal goes through the decimation and Y/C separation blocks of the Bt829B before any CC/EDS decoding takes place. See Figure 1-23 for a representation of this procedure.

Figure 1-23. CC/EDS Data Processing Path



The Bt829B can be programmed to decode CC/EDS data via the corresponding bits in the Extended Data Services/Closed Caption Status Register (CC\_STATUS;0X1C). The CC and EDS are independent and the video decoder may capture one or both in a given frame. The CC/EDS signal is displayed in Figure 1-24. In CC/EDS decode mode, once Bt829B has detected that line 21 of the field is being displayed, the decoder looks for the Clock Run-In signal. If the Clock Run-In signal is present and the correct start code (001) is recognized by Bt829B, then the CC/EDS data capture commences. Each of the 2 bytes of data transmitted to the video decoder per field contains a 7-bit ASCII code and a parity bit. The convention for CC/EDS data is odd parity.

Figure 1-24. CC/EDS Incoming Signal



The Bt829B provides a 16 x 10 location FIFO for storing CC/EDS data. Once the video decoder detects the start signal in the CC/EDS signal, it captures the low byte of CC/EDS data first and checks to see if the FIFO is full. If the FIFO is not full, then the data is stored in the FIFO, and is available to the user through the CC\_DATA register (0x1D). The high byte of CC/EDS data is captured next and placed in the FIFO. Upon being placed in the 10-bit FIFO, two additional bits are attached to the CC/EDS data byte by Bt829B's CC/EDS decoder. These two bits indicate whether the given byte stored in the FIFO corresponds to CC or EDS data and whether it is the high or low byte of CC/EDS. These two bits are available to the user through the CC\_STATUS register bits CC\_EDS and LO\_HI, respectively.

The parity bit is stored in the FIFO as shown in Figure 1-25. Additionally, the Bt829B stores the results of the parity check in the PARITY\_ERR bit in the CC\_STATUS register.



Figure 1-25. Closed Captioning/Extended Data Services FIFO

The 16-location FIFO can hold eight lines worth of CC/EDS data, at two bytes per line. Initially when the FIFO is empty, the DA bit in the CC\_STATUS register (0x1C) is set low and indicates that no data is available in the FIFO. Subsequently, when data has been stored in the FIFO, the DA bit is set to logical high. Once the FIFO is half full, the CC\_VALID interrupts pin signals to the system that the FIFO contents should be read in the near future. The CC\_VALID pin is enabled via a bit in the CC\_STATUS register (0x1C). The system controller can then poll the CC\_VALID bit in the STATUS register (0x00) to ensure that it was the Bt829B that initiated the CC\_VALID interrupt. This bit can also be used in applications where the CC\_VALID pin is disabled by the user.

VideoStream II Decoders

1.10 Closed Captioning and Extended Data Services Decoding

When the first byte of CC/EDS data is decoded and stored in the FIFO, the data is immediately placed in the CC\_DATA and CC\_STATUS registers and is available to be read. Once the data is read from the CC\_DATA register, the information in the next location of the FIFO is placed in the CC\_DATA and CC\_STATUS registers.

If the controller in the system ignores the Bt829B CC\_VALID interrupts pin for a sufficiently long period of time, then the CC/EDS FIFO will become full and the Bt829B will not be able to write additional data to the FIFO. Any incoming bytes of data will be lost and an overflow condition will occur; bit OR in the CC\_STATUS register will be set to a logical 1. The system may clear the overflow condition by reading the CC/EDS data and creating space in the FIFO for new information. As a result, the overflow bit is reset to a logical 0.

There will routinely be asynchronous reads and writes to the CC/EDS FIFO. The writes will be from the CC/EDS circuitry and the reads will occur as the system controller reads the CC/EDS data from Bt829B. These reads and writes will sometimes occur simultaneously, and the Bt829B is designed to give priority to the read operations. In the case where the CC\_DATA register data is specifically being read to clear an overflow condition, the simultaneous occurrence of a read and a write will not cause the overflow bit to be reset, even though the read has priority. An additional read must be made to the CC\_DATA register in order to clear the overflow condition. As always, the write data will be lost while the FIFO is in overflow condition.

The FIFO is reset when both CC and EDS bits are disabled in the CC\_STATUS register; any data in the FIFO is lost.

#### 1.10.1 Automatic Chrominance Gain Control

The Automatic Chrominance Gain Control (ACGC) compensates for reduced chrominance and color-burst amplitude. This can be caused by high-frequency loss in cabling. Here, the color-burst amplitude is calculated and compared to nominal. The color-difference signals are then increased or decreased in amplitude according to the color-burst amplitude difference from nominal. The maximum amount of chrominance gain is 0.5–2 times the original amplitude. This compensation coefficient is then multiplied by the value in the Saturation Adjust Register for a total chrominance gain range of 0–2 times the original signal. Automatic chrominance gain control may be disabled by setting the ACGC bit in the SCLOOP register to a logical 0.

#### 1.10.2 Low Color Detection and Removal

If a color burst of 25 percent (NTSC) or 35 percent (PAL/SECAM) or less of the nominal amplitude is detected for 127 consecutive scan lines, the color-difference signals U and V are set to zero. When the low color detection is active, the reduced chrominance signal is still separated from the composite signal to generate the luminance portion of the signal. The resulting Cr and Cb values are 128. Output of the chrominance signal is re-enabled when a color burst of 43 percent (NTSC) or 60 percent (PAL/SECAM) or greater of nominal amplitude is detected for 127 consecutive scan lines.

Low color detection and removal may be disabled by setting the CKILL bit in the SCLOOP register (0x10) to a logical 0.

1.10 Closed Captioning and Extended Data Services Decoding

VideoStream II Decoders

### 1.10.3 Coring

The Bt829B video decoder can perform a coring function, in which it forces all values below a programmed level to be zero. This is useful because the human eye is more sensitive to variations in black images. By taking near-black images and turning them into black, the image appears clearer to the eye.

Four coring values can be selected by the Output Format Register (OFORM; 0x12): 0, 8, 16, or 32 above black. If the total luminance level is below the selected limit, the luminance signal is truncated to the black value. If the luma range is limited (i.e., black is 16), then the coring circuitry automatically takes this into account and references the appropriate value for black. This is illustrated in Figure 1-26.

Figure 1-26. Coring Map



# 2.0 Electrical Interfaces

# 2.1 Input Interface

# 2.1.1 Analog Signal Selection

The Bt829B/827B contains an on-chip 4:1 MUX. For the Bt829B and Bt827B, this multiplexer can be used to switch between four composite sources or three composite sources and one S-Video source. In the first configuration, connect the inputs of the multiplexer (MUX[0], MUX[1], MUX[2], and MUX[3]) to the four composite sources. In the second configuration, connect three inputs to the composite sources and the other input to the luma component of the S-Video connector. In both configurations the output of the multiplexer (MUXOUT) should be connected to the input to the luma A/D (YIN) and the input to the sync detection circuitry (SYNCDET) through a optional 0.1  $\mu F$  capacitor (to maintain compatibility with the Bt829/827). When implementing S-Video, the input to the chroma A/D (CIN) should be connected to the chroma signal of the S-Video connector.

Use of the multiplexer is not a requirement for operation. If digitization of only one video source is required, the source may be connected directly to YIN.

# 2.1.2 Multiplexer Considerations

The multiplexer is not a break-before-make design. Therefore, during the multiplexer switching time it is possible for the input video signals to be momentarily connected together through the equivalent of  $200~\Omega$ 

45

The multiplexers cannot be switched on a real-time pixel-by-pixel basis.

2.1 Input Interface VideoStream II Decoders

#### 2.1.3 Autodetection of NTSC or PAL/SECAM Video

If the Bt829B is configured to decode both NTSC and PAL/SECAM, the Bt829B can be programmed to automatically detect which format is being input to the chip. Autodetection will select the proper clock source for the detected format. If NTSC/PAL-M is detected, XTAL0 is selected. If PAL/SECAM is detected, XTAL1 is selected. For PAL-N combination the user must manually select the XTAL0 crystal. Full control of the decoding configuration can be programmed by writing to the Input Format Register (0x01).

The Bt829B determines the video source input to the chip by counting the number of lines in a frame. Bit NUML indicates the result in the STATUS register. Based on this bit, the format of the video is determined, and XT0 or XT1 is selected for the clock source. Automatic format detection will select the clock source, but it will not program the required registers. The scaling and cropping registers (VSCALE, HSCALE, VDELAY, HDELAY, VACTIVE, and HACTIVE), as well as the burst delay and AGC delay registers (BDELAY and ADELAY) must be programmed accordingly.

#### 2.1.4 Flash A/D Converters

The Bt829B and Bt827B use two on-chip flash A/D converters to digitize the video signals. YREF+, CREF+, YREF-, and CREF- are the respective top and bottom of the internal resistor ladder.

The input video is always AC-coupled to the decoder. CREF- and YREF- are connected to analog ground. The voltage levels for YREF+ and CREF+ are controlled by the gain control circuitry. If the input video momentarily exceeds the corresponding REF+ voltage, it is indicated by LOF and COF in the STATUS register.

# 2.1.5 A/D Clamping

An internally generated clamp control signal is used to clamp the inputs of the A/D converter for DC restoration of the video signals. Clamping for both the YIN and CIN analog inputs occurs within the horizontal sync tip. The YIN input is always restored to ground while the CIN input is always restored to CLEVEL. CLEVEL can be set with an optional external resistor network so that it is biased to the midpoint between CREF– and CREF+. This ensures backward compatibility with the Bt819A/7A/5A, but is not required for the Bt829B/827B. External clamping is not required because internal clamping is automatically performed.

# 2.1.6 Power-Up Operation

Upon power-up, the status of the Bt829B's registers is indeterminate. The  $\overline{RST}$  signal must be asserted to set the register bits to their default values. The Bt829B device defaults to NTSC-M format upon reset. If pin 85 (OEPOLE) is tied to a logical high on power-up and the  $\overline{RST}$  signal is asserted, then the video pixel bus, sync signals, and output clocks will be three-stated.

Bt829B/827B 2.0 Electrical Interfaces

VideoStream II Decoders 2.1 Input Interface

## 2.1.7 Automatic Gain Controls (AGC)

The REFOUT, CREF+, and YREF+ pins should be connected together as shown in Figure 2-1. In this configuration, the Bt829B controls the voltage for the top of the reference ladder for each A/D. The automatic gain control adjusts the YREF+ and CREF+ voltage levels until the back porch of the Y-video input generates a digital code 0x38 from the A/D. If the video being digitized has a non-standard sync height to video height ratio, the digital code used for AGC may be changed by programming the ADC Interface Register (0x1A). Figure 2-2 illustrates Bt829B external circuitry with reduced passive components.

**♥ Rockwell** D829BDSA 47

#### 2.1 Input Interface

VideoStream II Decoders

Figure 2-1. Bt829B Typical External Circuitry with Third Overtone Crystal Oscillators (5 V VDD)



VideoStream II Decoders 2.1 Input Interface

Figure 2-2. Bt829B Typical External Circuitry with Third Overtone Crystal Oscillators (3.3V VDDO)



2.1 Input Interface

VideoStream II Decoders

### 2.1.8 Crystal Inputs and Clock Generation

The Bt829B has two pairs of pins: XT0I/XT0O and XT1I/XT1O. They are used to input a clock source. If both NTSC and PAL video are being digitized, both clock inputs must be implemented. The XT0 port is used to decode NTSC video and must be configured with a 28.63636 MHz source. The XT1 port is used to decode PAL video and must be configured with a 35.46895 MHz source.

If the Bt829B is configured to decode either NTSC or PAL, but not both, then only one clock source must be provided to the chip and it must be connected to the XT0I/XT0O port. If a crystal input is not used, the crystal amplifiers are internally shut down to save power.

Crystals are specified as follows:

- 28.636363 MHz or 35.468950 MHz
- · Third overtone
- Parallel resonant
- 30 pF load capacitance
- 50 ppm
- Series resistance 40  $\Omega$  or less

The following crystals are recommended for use with the Bt829B:

1 Standard Crystal (818) 443-2121

2BAK28M636363GLE30A

2BAK35M468950GLE30A

2 GED

(619) 591-4170

PKHC49-28.63636-.030-005-40R, 3rd overtone crystal PKHC49-35.46895-.030-005-40R, 3rd overtone crystal

3 M-Tron

(800) 762-8800

MP-1 28.63636, 3rd overtone crystal

MP-1 35.46895, 3rd overtone crystal

4 Monitor

(619) 433-4510

MM49X3C3A-28.63636, 3rd overtone crystal

MM49X3C3A-35.46895, 3rd overtone crystal

5 CTS

(815) 786-8411

R3B55A30-28.63636, 3rd overtone crystal

R3B55A30-35.46895, 3rd overtone crystal

6 Fox

(813) 693-0099

HC49U-28.63636, 3rd overtone crystal

HC49U-35.46895, 3rd overtone crystal

The two clock sources may be configured using single-ended oscillators, fundamental cut crystals, or third overtone mode crystals, with parallel resonant. If single-ended oscillators are used, they must be connected to XT0I and XT1I. Figure 2-3 shows the clock source options and circuit requirements.

Bt829B/827B 2.0 Electrical Interfaces

VideoStream II Decoders

2.1 Input Interface

The clock source tolerance should be 50 ppm or less, but 100 ppm is acceptable. Devices that output CMOS voltage levels are required. The load capacitance in the crystal configurations may vary, depending on the magnitude of board parasitic capacitance. The Bt829B is dynamic; to ensure proper operation, the clocks must always be running with a minimum frequency of 28.64 MHz.

The CLKx1 and CLKx2 outputs from the Bt829B are generated from XT0 and XT1 clock sources. CLKx2 operates at the crystal frequency (8xFsc), while CLKx1 operates at half the crystal frequency (4xFsc).

When the Bt829B is run in the 3.3 V digital I/O mode using third overtone crystals, the circuit shown in Figure 2-3 must be used. When the Bt829B is run in normal 5 V mode using third overtone crystals, the circuit shown in Figure 2-4 must be used.

2.1 Input Interface

VideoStream II Decoders

Figure 2-3. Clock Options (3.3 V VDD)



VideoStream II Decoders 2.1 Input Interface

Figure 2-4. Clock Options (5 V VDD)



2.1 Input Interface VideoStream II Decoders

## 2.1.9 2X Oversampling and Input Filtering

To avoid aliasing artifacts, digitized video needs to be band-limited. Because the Bt829B samples at CLKx2 (8xFsc—more than twice the normal rate), no filtering is required at the input to the A/Ds. The analog video needs to be band-limited to 14.32 MHz in NTSC and 17.73 MHz in PAL/SECAM mode. Normal video signals do not require additional external filtering. However, if noise or other signal content is expected above these frequencies, the optional antialiasing filter shown in Figure 2-1 may be included in the input signal path. After digitization, the samples are digitally low-pass filtered and then decimated to CLKx1. The response of the digital low-pass filter is shown in Figure 2-5. The digital low-pass filter provides the digital bandwidth reduction to limit the video to 6 MHz.

Figure 2-5. Luma and Chroma 2x Oversampling Filter



VideoStream II Decoders

2.2 Output Interface

# 2.2 Output Interface

## 2.2.1 Output Interfaces

The Bt829B supports a Synchronous Pixel Interface (SPI). SPI can support 8-bit or 16-bit YCrCb 4:2:2 data streams.

Bt829B outputs all pixel and control data synchronous with CLKx1 (16-bit mode), or CLKx2 (8-bit mode). Events such as  $\overline{\text{HRESET}}$  and  $\overline{\text{VRESET}}$  may also be encoded as control codes in the data stream to enable a reduced pin interface (ByteStream<sup>TM</sup>).

Mode selections are controlled by the state of the OFORM register (0x12). Figure 2-6 shows a diagram summarizing the different operating modes. On power-up, the Bt829B automatically initializes to SPI Mode 1, 16 bits wide.

Figure 2-6. Output Mode Summary



2.2 Output Interface

VideoStream II Decoders

#### 2.2.2 YCrCb Pixel Stream Format, SPI Mode, 8- and 16-Bit Formats

When the output is configured for an 8-bit pixel interface, the data is output on pins VD[15:8]. Eight bits of chrominance data precede 8 bits of luminance data for each pixel. New pixel data is output on the pixel port after each rising edge of CLKx2. When the output is configured for the 16-bit pixel interface, the luminance data is output on VD[15:8], and the chrominance data is output on VD[7:0]. In 16-bit mode, the data is output with respect to CLKx1. See Table 2-1 for a summary of output interface configurations. The YCrCb 4:2:2 pixel stream follows the CCIR recommendation, as illustrated in Figure 2-7.

Table 2-1. Pixel/Pin Map

|               | 16-Bit Pixel Interface |       |       |       |       |       |       |       |                                        |       |       |       |       |       |       |       |
|---------------|------------------------|-------|-------|-------|-------|-------|-------|-------|----------------------------------------|-------|-------|-------|-------|-------|-------|-------|
| Pin<br>Name   | VD15                   | VD14  | VD13  | VD12  | VD11  | VD10  | VD9   | VD8   | VD7                                    | VD6   | VD5   | VD4   | VD3   | VD2   | VD1   | VD0   |
| Data Bit      | <b>Y</b> 7             | Y6    | Y5    | Y4    | Y3    | Y2    | Y1    | Y0    | CrCb7                                  | CrCb6 | CrCb5 | CrCb4 | CrCb3 | CrCb2 | CrCb1 | CrCb0 |
|               | 8-Bit Pixel Interface  |       |       |       |       |       |       |       |                                        |       |       |       |       |       |       |       |
| Pin<br>Name   | VD15                   | VD14  | VD13  | VD12  | VD11  | VD10  | VD9   | VD8   | VD7                                    | VD6   | VD5   | VD4   | VD3   | VD2   | VD1   | VD0   |
| Y-Data<br>Bit | Y7                     | Y6    | Y5    | Y4    | Y3    | Y2    | Y1    | Y0    | 00000000000000000000000000000000000000 |       |       |       |       | 0     |       |       |
| C-Data<br>Bit | CrCb7                  | CrCb6 | CrCb5 | CrCb4 | CrCb3 | CrCb2 | CrCb1 | CrCb0 | NO.                                    |       |       |       |       |       |       |       |

Figure 2-7. YCrCb 4:2:2 Pixel Stream Format (SPI Mode, 8- and 16-Bits)



VideoStream II Decoders 2.2 Output Interface

## 2.2.3 Synchronous Pixel Interface (SPI Mode 1)

Upon reset, the Bt829B initializes to the SPI output, Mode 1 (SPI-1). In this mode, Bt829B outputs all horizontal and vertical blanking interval pixels, in addition to the active pixels synchronous with CLKx1 (16-bit mode), or CLKx2 (8-bit mode). Figure 2-8 illustrates SPI-1 for the Bt829B. The basic timing relationships remain the same for 16-bit or 8-bit modes. The 16-bit mode uses CLKx1 as the reference. The 8-bit mode uses CLKx2. Figure 2-9 shows the video timing for SPI Mode 1.

Figure 2-8. Bt829B/827B Synchronous Pixel Interface, Mode 1 (SPI-1)



Figure 2-9. Basic Timing Relationships for SPI Mode 1



**♥ Rockwell** D829BDSA 57

2.2 Output Interface VideoStream II Decoders

### 2.2.4 Synchronous Pixel Interface (SPI Mode 2, ByteStream)

In SPI Mode 2, the Bt829B encodes all video timing control signals onto the pixel data bus. ByteStream is the 8-bit version of this configuration. Because all timing data is included on the data bus, a complete interface to a video controller can be implemented in only nine pins: one for CLK x 2, and eight for data.

When using coded control, the RANGE bit and the CODE bit must be programmed high. When the RANGE bit is high, the chrominance pixels (both Cr and Cb) are saturated to the range 2 to 253, and the luminance range is limited to the range 16 to 253. In SPI Mode 2, the following values are inserted as control codes to indicate video events (see Table 2-2): the chroma values of 255 and 254, and the luminance values of 0 to 15. A chroma value of 255 indicates that the associated luma pixel is a control code; a pixel value of 255 indicates that the CbFlag is high (i.e., the current pixel is a Cb pixel). Similarly, a pixel value of 254 indicates that the luma value is a control code, and that the CbFlag is low (Cr pixel).

The first pixel of a line is guaranteed to be a Cb flag. However, due to code precedence relationships, the HRESET code may be delayed by one pixel, so HRESET can occur on a Cr or a Cb pixel. Also, at the beginning of a new field, the relationship between VRESET and HRESET may be lost, typically with video from a VCR. As a result, VRESET can occur during either a Cb or a Cr pixel. Figure 2-10 demonstrates coded control for SPI Mode 2 (ByteStream).

Table 2-2 shows pixel data output ranges. Independent of RANGE, decimal 128 indicates zero color information for Cr and Cb. Black is decimal 16 when RANGE = 0 and code 0 when RANGE = 1.

Figures 2-11 and 2-12 illustrate videotiming for SPI Modes 1 and 2.

| Luma<br>Value | Chroma<br>Value | Video Event Description                                                                                                    |
|---------------|-----------------|----------------------------------------------------------------------------------------------------------------------------|
| 0x00          | 0xFF<br>0xFE    | This is an invalid pixel; last valid pixel was a Cb pixel.<br>This is an invalid pixel; last valid pixel was a Cr pixel.   |
| 0x01          | 0xFF<br>0xFE    | Cb pixel; last pixel was the last active pixel of the line.<br>Cr pixel; last pixel was the last active pixel of the line. |
| 0x02          | 0xFF<br>0xFE    | Cb pixel; next pixel is the first active pixel of the line. Cr pixel; next pixel is the first active pixel of the line.    |

Table 2-2. Description of the Control Codes in the Pixel Stream

VideoStream II Decoders

2.2 Output Interface

Table 2-2. Description of the Control Codes in the Pixel Stream

| Luma<br>Value | Chroma<br>Value | Video Event Description                                                                    |
|---------------|-----------------|--------------------------------------------------------------------------------------------|
| 0x03          | 0xFF<br>0xFE    | Cb pixel; HRESET of a vertical active line.<br>Cr pixel; HRESET of a vertical active line. |
| 0x04          | 0xFF<br>0xFE    | Cb pixel; HRESET of a vertical blank line.<br>Cr pixel; HRESET of a vertical blank line.   |
| 0x05          | 0xFF<br>0xFE    | Cb pixel; VRESET followed by an even field.<br>Cr pixel; VRESET followed by an even field. |
| 0x06          | 0xFF<br>0xFE    | Cb pixel; VRESET followed by an odd field.<br>Cr pixel; VRESET followed by an odd field.   |

Figure 2-10. Data Output in SPI Mode 2 (ByteStream)



#### 2.2 Output Interface VideoStream II Decoders

Figure 2-11. Video Timing in SPI Modes 1 and 2



Notes: (1). HRESET precedes VRESET by two clock cycles at the beginning of fields 1, 3, 5, and 7 to facilitate external field generation.

- 2. ACTIVE pin may be programmed to be composite ACTIVE or horizontal ACTIVE.
- 3. ACTIVE, HRESET, VRESET and FIELD are shown with their default polarity. The polarity is programmable via the VPOLE register.
- 4. FIELD transitions with the end of horizontal active video, defined by HDELAY and HACTIVE.

VideoStream II Decoders 2.2 Output Interface

Figure 2-12. Horizontal Timing Signals in the SPI Modes



Table 2-3. Data Output Ranges

|    | RANGE = 0 | RANGE = 1 |
|----|-----------|-----------|
| Y  | 16 -> 235 | 0 -> 255  |
| Cr | 2 -> 253  | 2 -> 253  |
| Cb | 2 -> 253  | 2 -> 253  |

## 2.2.5 CCIR601 Compliance

When the RANGE bit is set to zero, the output levels are fully compliant with the CCIR601 recommendation. CCIR601 specifies that nominal video will have Y values ranging from 16 to 235, and that Cr and Cb values will range from 16 to 240. Excursions outside this range are allowed to handle non standard video. The only mandatory requirement is that 0 and 255 be reserved for timing information.

2.3 f<sup>2</sup>C Interface VideoStream II Decoders

# 2.3 I<sup>2</sup>C Interface

The Inter-Integrated Circuit bus is a two-wire serial interface. Serial Clock (SCL) and Data Lines (SDA) are used to transfer data between the bus master and the slave device. The Bt829B can transfer data at a maximum rate of 100 kbps. The Bt829B operates as a slave device.

## 2.3.1 Starting and Stopping

The relationship between SCL and SDA is decoded to provide both a start and stop condition on the bus. To initiate a transfer on the I<sup>2</sup>C bus, the master must transmit a start pulse to the slave device. This is accomplished by taking the SDA line low while the SCL line is held high. The master should only generate a start pulse at the beginning of the cycle, or after the transfer of a data byte to or from the slave. To terminate a transfer, the master must take the SDA line high while the SCL line is held high. The master may issue a stop pulse at any time during an I<sup>2</sup>C cycle. Since the I<sup>2</sup>C bus will interpret any transition on the SDA line during the high phase of the SCL line as a start or stop pulse, care must be taken to ensure that data is stable during the high phase of the clock. Figure 2-13 illustrates the relationship between SCL and SDA.



Figure 2-13. The Relationship between SCL and SDA

Bt829B/827B 2.0 Electrical Interfaces

VideoStream II Decoders 2.3 I<sup>2</sup>C Interface

## 2.3.2 Addressing the Bt829B

An  $I^2C$  slave address consists of two parts: a 7-bit base address and a single bit  $R/\overline{W}$  command. The  $R/\overline{W}$  bit is appended to the base address to form the transmitted  $I^2C$  address, as shown in Figure 2-14 and Table 2-4.

Figure 2-14. I<sup>2</sup>C Slave Address Configuration



Table 2-4. Bt829B Address Matrix

| 12CCS Pin | Bt829B Base | R/W Bit | Action |
|-----------|-------------|---------|--------|
| 0         | 1000100     | 0       | Write  |
|           | 1000100     | 1       | Read   |
| 1         | 1000101     | 0       | Write  |
|           | 1000101     | 1       | Read   |

### 2.3.3 Reading and Writing

After transmitting a start pulse to initiate a cycle, the master must address the Bt829B. To do this, the master must transmit one of the four valid Bt829B addresses, with the Most Significant Bit (MSB) transmitted first. After transmitting the address, the master must release the SDA line during the low phase of the SCL and wait for an acknowledgment. If the transmitted address matches the selected Bt829B address, the Bt829B will respond by driving the SDA line low, generating an acknowledge to the master. The master samples the SDA line at the rising edge of the SCL line, and proceeds with the cycle. If no device responds, including the Bt829B, the master transmits a stop pulse and ends the cycle.

If the slave address R/W bit was low (indicating a write) the master will transmit an 8-bit byte to the Bt829B, with the MSB transmitted first. The Bt829B acknowledges the transfer and loads the data into its internal address register. The master then issues a stop command, a start command, or transfers another 8-bit byte, MSB first. The internal address register points to the 8-bit byte, which is then loaded into the register. The Bt829B acknowledges the transfer and increments the address register in preparation for the next transfer. As before, the master may issue a stop command, a start command, or transfer another 8 bits which is loaded into the next register location.

If the slave address R/W bit was high (indicating a read), the Bt829B transfers the contents of the register. Its internal address register points to the contents, MSB first. The master acknowledges receipt of the data and pulls the SDA line low. As with the write cycle, the address register is auto-incremented in preparation for the next read.

2.3 f<sup>2</sup>C Interface VideoStream II Decoders

To stop a read transfer, the host must *not* acknowledge the last read cycle. The Bt829B then releases the data bus in preparation for a stop command. If an acknowledgment is received, the Bt829B proceeds to transfer the next register.

When the master generates a read from the Bt829B, the Bt829B starts its transfer from whatever location is currently loaded into the address register. Since the address register might not contain the address of the desired register, the master generally executes a write cycle, setting the address register to the desired location. After receiving an acknowledgment for the transfer of the data into the address register, the master initiates a read of the Bt829B by starting a new I<sup>2</sup>C cycle with an appropriate read address. The Bt829B then transfers the contents of the desired register.

For example, to read register 0x0A, Brightness Control, the master starts a write cycle with an I<sup>2</sup>C address of 0x88 or 0x8A. After receiving an acknowledgment from the Bt829B, the master transmits the desired address, 0x0A. After receiving an acknowledgment, the master then starts a read cycle with an I<sup>2</sup>C slave address of 0x89 or 0x8B. The Bt829B acknowledges and transfers the contents of register 0x0A. There is no need to issue a stop command after the write cycle. The Bt829B detects the repeated start command and starts a new I<sup>2</sup>C cycle. This process is illustrated in Table 2-5 and Figure 2-15.

For detailed information on the  $I^2C$  bus, refer to "The  $I^2C$ -Bus Reference Guide," reprinted by Rockwell.

Table 2-5. Example I<sup>2</sup>C Data Transactions

| Master                 | Data<br>Flow    | Bt829B | Comment                                                        |  |  |  |  |  |  |  |  |  |  |
|------------------------|-----------------|--------|----------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
|                        | Write to Bt829B |        |                                                                |  |  |  |  |  |  |  |  |  |  |
| I <sup>2</sup> C Start | >               |        | Master sends Bt829B chip address, i.e., 0x88 or 0x8A.          |  |  |  |  |  |  |  |  |  |  |
|                        |                 | ACK    | Bt829B generates ACK on successful receipt of chip address.    |  |  |  |  |  |  |  |  |  |  |
| Subaddress             | <br>>           |        | Master sends subaddress to Bt829B.                             |  |  |  |  |  |  |  |  |  |  |
|                        |                 | ACK    | Bt829B generates ACK on successful receipt of subaddress.      |  |  |  |  |  |  |  |  |  |  |
| Data(0)                | <br>>           |        | Master sends first data byte to Bt829B.                        |  |  |  |  |  |  |  |  |  |  |
|                        |                 | ACK(0) | Bt829B generates ACK on successful receipt of first data byte. |  |  |  |  |  |  |  |  |  |  |
| ·<br>·                 | ><br><br>><br>  |        |                                                                |  |  |  |  |  |  |  |  |  |  |
|                        | - <u>-</u>      |        |                                                                |  |  |  |  |  |  |  |  |  |  |
| Data(n)                | <br>>           |        | Master sends nth data byte to Bt829B.                          |  |  |  |  |  |  |  |  |  |  |
|                        |                 | ACK(n) | Bt829B generates ACK on successful receipt of nth data byte.   |  |  |  |  |  |  |  |  |  |  |
| I <sup>2</sup> C Stop  |                 |        | Master generates STOP to end transfer.                         |  |  |  |  |  |  |  |  |  |  |

VideoStream II Decoders 2.3 I<sup>2</sup>C Interface

Table 2-5. Example I<sup>2</sup>C Data Transactions

| Master                 | Data<br>Flow | Bt829B    | Comment                                                          |
|------------------------|--------------|-----------|------------------------------------------------------------------|
|                        |              |           | Read from Bt829B                                                 |
| I <sup>2</sup> C Start | >            |           | Master sends Bt829B chip address, i.e., 0x89 or 0x8B.            |
|                        |              | ACK       | Bt829B generates ACK on successful receipt of chip address.      |
|                        | <<br>-       | Data(0)   | Bt829B sends first data byte to Master.                          |
| ACK(0)                 |              |           | Master generates ACK on successful receipt of first data byte.   |
| ·<br>·                 |              |           |                                                                  |
|                        | <-<br>-      | Data(n-1) | Bt829B sends (n-1)th data byte to Master.                        |
| ACK(n-1)               |              |           | Master generates ACK on successful receipt of (n-1)th data byte. |
|                        | <-<br>-      | Data(n)   | Bt829B sends nth data byte to Master.                            |
| NO ACK                 |              |           | Master does not acknowledge nth data byte.                       |
| I <sup>2</sup> C Stop  |              |           | Master generates STOP to end transfer.                           |

where:  $I^2C$  Start =  $I^2C$  start condition and Bt829B chip address (including the

 $R/\overline{W}$  bit).

Subaddress = The 8-bit subaddress of the Bt829B register, MSB first.

Data(n) = The data to be transferred to/from the addressed register.

 $I^2C$  Stop =  $I^2C$  stop condition.

#### 2.3 l<sup>2</sup>C Interface VideoStream II Decoders

Figure 2-15. I<sup>2</sup>C Protocol Diagram



#### 2.3.4 Software Reset

The contents of the control registers may be reset to their default values by issuing a software reset. A software reset can be accomplished by writing any value to subaddress 0x1F. A read of this location returns an undefined value.

Bt829B/827B 2.0 Electrical Interfaces

VideoStream II Decoders 2.4 JTAG Interface

### 2.4 JTAG Interface

#### 2.4.1 Need for Functional Verification

As the complexity of imaging chips increases, the need to easily access individual chips for functional verification is vital. The Bt829B incorporates special circuitry which makes it accessible in full compliance with Joint Test Action Group (JTAG) standards. Conforming to IEEE P1149.1 "Standard Test Access Port and Boundary Scan Architecture," the Bt829B contains dedicated pins used only for testability purposes.

## 2.4.2 JTAG Approach to Testability

JTAG's approach to testability uses boundary scan cells that are placed at each digital pin and digital interface. (A digital interface is defined as the boundary between an analog block and a digital block within the Bt829B). All cells are interconnected into a boundary scan register that applies or captures test data to verify functionality of the integrated circuit. JTAG is particularly useful for board testers using functional testing methods.

JTAG consists of five dedicated pins comprising the Test Access Port (TAP). These pins are Test Mode Select (TMS), Test Clock (TCK), Test Data Input (TDI), Test Data Out (TDO), and Test Reset (TRST). The TRST pin resets the JTAG controller when pulled low at any time. Verification of the integrated circuit and its connection to other modules on the printed circuit board is achieved through these five TAP pins. With boundary scan cells at each digital interface and pin, the Bt829B is capable of applying and capturing the respective logic levels. Because all of the digital pins are interconnected as a long shift register, the TAP logic has access to the necessary pins. This ensures verification of pin functionality. The TAP controller can shift in any number of test vectors through the TDI input and can apply them to the internal circuitry. The output result is scanned on the TDO pin and is externally checked. While isolating the Bt829B from other components on the board, the user has easy access to all Bt829B digital pins and digital interfaces through the TAP. The user can then perform complete functionality tests without using expensive bed-of-nails testers.

2.4 JTAG Interface VideoStream II Decoders

## 2.4.3 Optional Device ID Register

The Bt829B has the optional device identification register defined by the JTAG specification. This register contains information concerning the revision, actual part number, and manufacturer's identification code that is specific to Rockwell. The TAP controller can access the register via an optional JTAG instruction, as shown in Table 2-6.

Table 2-6. Device Identification Register

| ١ | 'ers                                                                      | sio  | n |                               | Part Number  |  |  |  |  |  |  |  |  |   | Manufacturer ID |   |   |   |   |   |   |   |   |   |   |   |
|---|---------------------------------------------------------------------------|------|---|-------------------------------|--------------|--|--|--|--|--|--|--|--|---|-----------------|---|---|---|---|---|---|---|---|---|---|---|
| Χ | Χ                                                                         | Х    | Х | 0 0 0 0 0 0 1 1 0 0 1 1 1 0 1 |              |  |  |  |  |  |  |  |  | 1 | 0               | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 1 |
|   | (                                                                         | )    |   |                               | 0829, 0x033D |  |  |  |  |  |  |  |  |   | 0x0D6           |   |   |   |   |   |   |   |   |   |   |   |
|   | 4 E                                                                       | Bits |   |                               | 16 Bits      |  |  |  |  |  |  |  |  |   | 11 Bits         |   |   |   |   |   |   |   |   |   |   |   |
| N | Note: The part number remains the same for both parts: Bt829B and Bt827B. |      |   |                               |              |  |  |  |  |  |  |  |  |   |                 |   |   |   |   |   |   |   |   |   |   |   |

# 2.4.4 Verification with the Tap Controller

The TAP controller enables you to perform a variety of verification procedures. Using a set of four instructions, the Bt829B can verify board connectivity at all digital interfaces and pins. The instructions can be accessed using a state machine that is standard to all JTAG controllers. They are Sample/Preload, Extest, ID Code, and Bypass (see Figure 2-16). Refer to the IEEE P1149.1 specification for details concerning the instruction register and JTAG state machine.

Rockwell has created a BSDL with the AT&T BSD Editor. If you plan to implement JTAG testing, you may obtain a disk with an ASCII version of the complete BSDL file by contacting your local Rockwell sales office.

Figure 2-16. Instruction Register



Bt829B/827B 2.0 Electrical Interfaces

VideoStream II Decoders 2.4 JTAG Interface

#### 2.4.5 Example BSDL Listing

```
attribute BOUNDARY_REGISTER of Bt829B : entity is
            0 (BC_1, *, control, 1)," &
           1 (BC_1, *, internal, 1)," &
           2 (BC_1, *, control, 1)," &
            3 (BC_1, *, internal, X)," &
            4 (BC_1, *, internal, X)," &
            5 (BC_1, *, internal, X)," &
            6 (BC_1, *, internal, X)," &
           7 (BC_1, *, internal, X)," &
           8 (BC_1, *, internal, X)," &
            9 (BC_1, *, internal, X)," &
          10 (BC_1, *, internal, X)," &
          11 (BC_1, *, internal, X)," &
          12 (BC_1, *, internal, X)," &
        " 13 (BC_1, *, internal, 0)," &
           14 (BC_1, *, internal, 0)," &
          15 (BC_1, *, internal, 0)," &
          16 (BC_1, *, internal, 0)," &
          17 (BC_1, *, internal, 0)," &
          18 (BC_1, *, internal, 0)," &
          19 (BC_1, *, internal, 0)," &
          20 (BC_1, *, internal, 0)," &
          21 (BC_1, *, internal, 0)," &
          22 (BC_1, *, internal, 0)," &
          23 (BC_1, *, internal, 0)," &
          24 (BC_1, *, internal, 0)," &
          25 (BC_1, *, internal, 0)," &
          26 (BC_1, *, internal, 0)," &
          27 (BC_1, *, internal, 0)," &
          28 (BC_1, *, control, 0)," &
          29 (BC_1, FIELD, output3, X, 28, 0, Z)," &
          30 (BC_1, NVRESET, output3, X, 28, 0, Z)," &
           31 (BC_1, XTFMT, input, X)," &
          32 (BC_1, NHRESET, output3, X, 28, 0, Z)," &
          33 (BC_1, ACTIVE, output3, X, 28, 0, Z)," &
          34 (BC_1, DVALID, output3, X, 28, 0, Z)," &
           35 (BC_1, VACTIVE, output3, X, 28, 0, Z)," &
        " 36 (BC_1, TST, output2, 0, 36, 0, Weak1)," &
         37 (BC_1, *, internal, X)," &
```

2.4 JTAG Interface VideoStream II Decoders

```
38 (BC_1, CBFLAG, output3, X, 28, 0, Z)," &
  39 (BC_3, NVSEN, input, X)," &
  40 (BC_1, PWRDN, input, X)," &
  41 (BC_1, QCLK, output3, X, 28, 0, Z)," &
  42 (BC_1, CLKX1, output3, X, 28, 0, Z)," &
  43 (BC_1, NOE, input, 1)," &
  44 (BC_1, CLKX2, output3, X, 28, 0, Z)," &
  45 (BC_1, VDB(13), output3, X, 28, 0, Z)," &
  46 (BC_1, VDB(14), output3, X, 28, 0, Z)," &
  47 (BC_1, VDB(15), output3, X, 28, 0, Z)," &
  48 (BC_1, VDB(8), output3, X, 28, 0, Z)," &
  49 (BC_1, VDB(9), output3, X, 28, 0, Z)," &
" 50 (BC_1, VDB(10), output3, X, 28, 0, Z)," &
  51 (BC_1, VDB(11), output3, X, 28, 0, Z)," &
  52 (BC_1, VDB(12), output3, X, 28, 0, Z)," &
  53 (BC_1, *, internal, X)," &
  54 (BC_1, XT0I, input, X)," &
  55 (BC_1, I2CCS, input, X)," &
  56 (BC_1, NRST, input, X)," &
  57 (BC_1, *, internal, X)," &
  58 (BC_1, XT1I, input, X)," &
  59 (BC_1, SDA, output2, 0, 59, 1, Pull1)," &
  60 (BC_1, SDA, input, X)," &
  61 (BC_1, SCL, input, X)," &
  62 (BC_1, VDA(3), output3, X, 0, 1, Z)," &
  63 (BC_1, VDA(3), input, X)," &
" 64 (BC_1, VDA(4), output3, X, 2, 1, Z)," &
  65 (BC_1, VDA(4), input, X)," &
  66 (BC_1, VDA(5), output3, X, 2, 1, Z)," &
  67 (BC_1, VDA(5), input, X)," &
  68 (BC_1, VDA(6), output3, X, 2, 1, Z)," &
  69 (BC_1, VDA(6), input, X)," &
  70 (BC_1, VDA(7), output3, X, 2, 1, Z)," &
  71 (BC_1, VDA(7), input, X)," &
  72 (BC_1, VDA(0), output3, X, 0, 1, Z)," &
  73 (BC_1, VDA(0), input, X)," &
  74 (BC_1, VDA(1), output3, X, 0, 1, Z)," &
  75 (BC_1, VDA(1), input, X)," &
" 76 (BC_1, VDA(2), output3, X, 0, 1, Z)," &
" 77 (BC_1, VDA(2), input, X)," &
```

Bt829B/827B 2.0 Electrical Interfaces

VideoStream II Decoders

2.4 JTAG Interface

```
" 78 (BC_1, TWREN, input, X)," &
" 79 (BC_0, *, internal, 0)," &
" 80 (BC_0, *, internal, 0)";
```

end Bt829B;

2.4 JTAG Interface VideoStream II Decoders

# 3.0 PC Board Layout Considerations

The layout should be optimized for lowest noise on the Bt829B power and ground lines. Optimization is achieved by shielding the digital inputs and outputs and by providing good decoupling. The lead length between groups of power and ground pins should be minimized to reduce inductive ringing.

### 3.1 Ground Planes

The ground plane area should encompass all Bt829B ground pins, voltage reference circuitry, power supply bypass circuitry for the Bt829B, analog input traces, any input amplifiers, and all the digital signal traces leading to the Bt829B.

The Bt829B has digital grounds (GND) and analog grounds (AGND and VNEG). The layout for the ground plane should be set up so the two planes are at the same electrical potential, but they should be isolated from each other in the areas surrounding the chip. The return path for the current should be through the digital plane. See Figure 3-1 for an example of ground plane layout.



Figure 3-1. Example of Ground Plane Layout

3.1 Ground Planes VideoStream II Decoders

#### 3.1.1 Power Planes

The power plane area should encompass all Bt829B power pins, voltage reference circuitry, power supply bypass circuitry for the Bt829B, analog input traces, any input amplifiers, and all the digital signal traces leading to the Bt829B.

The Bt829B has digital power (VDD) and analog power (VAA and VPOS). The layout for the power plane should be set up so the two planes are at the same electrical potential, but they should be isolated from each other in the areas surrounding the chip. The return path for the current should be through the digital plane. This is the same layout as the ground plane (Figure 3-1). When using a regulator, circuitry must be included to ensure proper power sequencing. Figure 3-2 illustrates this circuitry layout.

Figure 3-2. Optional Regulator Circuitry



3.1 Ground Planes

#### 3.1.2 Supply Decoupling

The bypass capacitors should be installed with the shortest leads possible (consistent with reliable operation) to reduce the lead inductance. These capacitors should be placed as close as possible to the device.

Each group of VAA and VDD pins should have a  $0.1~\mu F$  ceramic bypass capacitor to ground, located as close as possible to the device.

Additionally,  $10 \,\mu\text{F}$  capacitors should be connected between the analog power and ground planes, as well as between the digital power and ground planes. These capacitors are at the same electrical potential, but provide additional decoupling by being physically close to the Bt829B power and ground planes. For additional information about power supply decoupling, see Figures 3-3 and 3-4.

Figure 3-3. Typical Power and Ground Connection Diagram and Parts List for 5 V I/O Mode



| Location              | Description              | Vendor Part Number    |  |  |  |  |
|-----------------------|--------------------------|-----------------------|--|--|--|--|
| C1, C2 <sup>(1)</sup> | 0.1 μF ceramic capacitor | Erie RPE112Z5U104M50V |  |  |  |  |
| C3, C4 <sup>(2)</sup> | 10 μF tantalum capacitor | Mallory CSR13G106KM   |  |  |  |  |

Notes: (1). A 0.1  $\mu$ F capacitor should be connected between each group of power pins and ground. They should be connected as close to the device as possible (ceramic chip capacitors are preferred).

- (2). The 10 μF capacitors should be connected between the analog supply and the analog ground, as well as the digital supply and the digital ground. These should be connected as close to the Bt829B as possible.
- 3. Vendor numbers are listed only as a guide. Substitution of devices with similar characteristics will not affect the performance of the Bt829B.

3.1 Ground Planes VideoStream II Decoders

Figure 3-4. Typical Power and Ground Connection Diagram and Parts List for 3.3 V I/O Mode



| Location                   | Description              | Vendor Part Number    |  |  |  |  |
|----------------------------|--------------------------|-----------------------|--|--|--|--|
| C1, C2 <sup>(1)</sup> , C5 | 0.1 μF ceramic capacitor | Erie RPE112Z5U104M50V |  |  |  |  |
| C3, C4 <sup>(2)</sup>      | 10 μF tantalum capacitor | Mallory CSR13G106KM   |  |  |  |  |

Notes: (1). A 0.1  $\mu$ F capacitor should be connected between each group of power pins and ground. They should be connected as close to the device as possible (ceramic chip capacitors are preferred).

- (2). The 10  $\mu$ F capacitors should be connected between the analog supply and the analog ground, as well as the digital supply and the digital ground. These should be connected as close to the Bt829B as possible.
- 3. Vendor numbers are listed only as a guide. Substitution of devices with similar characteristics will not affect the performance of the Bt829B.

3.1 Ground Planes

#### 3.1.3 Digital Signal Interconnect

The digital signals of the Bt829B should be isolated as much as possible from the analog signals and other analog circuitry. Also, the digital signals should not overlay the analog power plane.

Any termination resistors for the digital signals should be connected to the regular PCB power and ground planes.

#### 3.1.4 Analog Signal Interconnect

To minimize crosstalk, long lengths of closely spaced parallel video signals should be avoided. Ideally, a ground line should exist between the video signal traces driving the YIN and CIN inputs.

To minimize noise coupling, high-speed TTL signals should not be routed close to the analog signals.

#### 3.1.5 Latch-up Avoidance

Latch-up is a failure mechanism inherent to any CMOS device. It is triggered by static or impulse voltages on any signal input pin when the voltage on the power pins exceeds 0.5 V, or when it falls below the GND pins by more than 0.5 V. Latch-up can also occur if the voltage on any power pin exceeds the voltage on any other power pin by more than 0.5 V.

In some cases, devices with mixed signal interfaces, such as the Bt829B, can appear more sensitive to latch-up. Mixed signal devices tend to interact with peripheral devices, such as video monitors or cameras that are referenced to different ground potentials. Voltages applied to the device prior to the time that its power system is stable can create conditions that are amenable to the onset of latch-up.

To maintain a robust design with the Bt829B, you should take the following precautions:

- Apply power to the device before or at the same time that power is applied to the interface circuitry.
- Do not apply voltages below GND-0.5 V or higher than VAA+0.5 V to any pin on the device. Do not use negative supply op-amps or any other negative voltage interface circuitry. All logic inputs should be held low until power to the device has settled to the specified tolerance.
- Connect all VDD, VAA, and VPOS pins together through a low impedance plane.
- Connect all GND, AGND, and VNEG pins together through a low impedance plane.

3.1 Ground Planes VideoStream II Decoders

# 4.0 Control Register Definitions

This section describes the function of the various control registers in detail. Table 4-1 summarizes the register functions.

Table 4-1. Register Map (1 of 2)

| Register Name                               | Mnemonic    | Register Address | 640 x 480<br>Square Pixel NTSC<br>(Default) | 768 x 576<br>Square Pixel PAL/SECAM | 720 x 480<br>CCIR NTSC | 720 x 576<br>CCIR PAL/SECAM | 320 x 240 2:1 NTSC<br>(Square Pixel, CIF) | 320 x 288 2:1 PAL/SECAM<br>(Square Pixel, CIF) |
|---------------------------------------------|-------------|------------------|---------------------------------------------|-------------------------------------|------------------------|-----------------------------|-------------------------------------------|------------------------------------------------|
| Device Status                               | STATUS      | 0x00             | 0x00                                        | 0x00                                | 0x00                   | 0x00                        | 0x00                                      | 0x00                                           |
| Input Format                                | IFORM       | 0x01             | 0x58                                        | 0x78                                | 0x58                   | 0x78                        | 0x58                                      | 0x78                                           |
| Temporal Decimation                         | TDEC        | 0x02             | 0x00                                        | 0x00                                | 0x00                   | 0x00                        | 0x00                                      | 0x00                                           |
| M SB Cropping                               | CROP        | 0x03             | 0x12                                        | 0x23                                | 0x12                   | 0x23                        | 0x11                                      | 0x21                                           |
| Vertical Delay, Lower Byte                  | VDELAY_LO   | 0x04             | 0x16                                        | 0x16                                | 0x16                   | 0x16                        | 0x16                                      | 0x16                                           |
| Vertical Active, Lower Byte                 | VACTIVE_LO  | 0x05             | 0xE0                                        | 0x40                                | 0xE0                   | 0x40                        | 0xE0                                      | 0x40                                           |
| Horizontal Delay,<br>Lower Byte             | HDELAY_LO   | 0x06             | 0x78                                        | 0x9A                                | 0x80                   | 0x90                        | 0x40                                      | 0x48                                           |
| Horizontal Active,<br>Lower Byte            | HACTIVE_LO  | 0x07             | 0x80                                        | 0x00                                | 0xD0                   | 0xD0                        | 0x40                                      | 0x80                                           |
| Horizontal Scaling,<br>Upper Byte           | HSCALE_HI   | 0x08             | 0x02                                        | 0x03                                | 0x00                   | 0x05                        | 0x11                                      | 0x1A                                           |
| Horizontal Scaling,<br>Lower Byte           | HSCALE_LO   | 0x09             | 0xAC                                        | 0x3C                                | 0xF8                   | 0x04                        | 0xF0                                      | 0x09                                           |
| Brightness Control                          | BRIGHT      | 0x0A             | 0x00                                        | 0x00                                | 0x00                   | 0x00                        | 0x00                                      | 0x00                                           |
| Miscellaneous Control                       | CONTROL     | 0x0B             | 0x20                                        | 0x20 <sup>(1)</sup>                 | 0x20                   | 0x20 <sup>(1)</sup>         | 0x20                                      | 0x20                                           |
| Luma Gain,<br>Lower Byte (Contrast)         | CONTRAST_LO | 0x0C             | 0xD8                                        | 0xD8                                | 0xD8                   | 0xD8                        | 0xD8                                      | 0xD8                                           |
| Chroma (U) Gain,<br>Lower Byte (Saturation) | SAT_U_LO    | 0x0D             | 0xFE                                        | 0xFE                                | 0xFE                   | 0xFE                        | 0xFE                                      | 0xFE                                           |
| Chroma (V) Gain,<br>Upper Byte (Saturation) | SAT_V_LO    | 0x0E             | 0xB4                                        | 0xB4                                | 0xB4                   | 0xB4                        | 0xB4                                      | 0xB4                                           |

Table 4-1. Register Map (2 of 2)

| Register Name                                        | Mnemonic  | Register Address | 640 x 480<br>Square Pixel NTSC<br>(Default) | 768 x 576<br>Square Pixel PAL∕SECAM | 720 x 480<br>CCIR NTSC | 720 x 576<br>CCIR PAL/SECAM | 320 x 240 2:1 NTSC<br>(Square Pixel, CIF) | 320 x 288 2:1 PAL/SECAM<br>(Square Pixel, CIF) |
|------------------------------------------------------|-----------|------------------|---------------------------------------------|-------------------------------------|------------------------|-----------------------------|-------------------------------------------|------------------------------------------------|
| Hue Control                                          | HUE       | 0x0F             | 0x00                                        | 0x00                                | 0x00                   | 0x00                        | 0x00                                      | 0x00                                           |
| SC Loop Control                                      | SCLOOP    | 0x10             | 0x00                                        | 0x00 <sup>(1)</sup>                 | 0x00                   | 0x00 <sup>(1)</sup>         | 0x00                                      | 0x00                                           |
| White Crush Up Count                                 | WC_UP     | 0x11             | 0xCF                                        | 0xCF                                | 0xCF                   | 0xCF                        | 0xCF                                      | 0xCF                                           |
| Output Format                                        | OFORM     | 0x12             | 0x06                                        | 0x06                                | 0x06                   | 0x06                        | 0x06                                      | 0x06                                           |
| Vertical Scaling,<br>Upper Byte                      | VSCALE_HI | 0x13             | 0x60                                        | 0x60                                | 0x60                   | 0x60                        | 0x40 <sup>(1)</sup>                       | 0x40 <sup>(1)</sup>                            |
| Vertical Scaling,<br>Lower Byte                      | VSCALE_LO | 0x14             | 0x00                                        | 0x00                                | 0x00                   | 0x00                        | 0x00                                      | 0x00                                           |
| Test Control                                         | TEST      | 0x15             | 0x01                                        | 0x01                                | 0x01                   | 0x01                        | 0x01                                      | 0x01                                           |
| Video Timing Polarity<br>Register                    | VPOLE     | 0x16             | 0x00                                        | 0x00                                | 0x00                   | 0x00                        | 0x00                                      | 0x00                                           |
| ID Code                                              | IDCODE    | 0x17             | 0x70                                        | 0x70                                | 0x70                   | 0x70                        | 0x70                                      | 0x70                                           |
| AGC Delay                                            | ADELAY    | 0x18             | 0x68                                        | 0x7F                                | 0x68                   | 0x7F                        | 0x68                                      | 0x7F                                           |
| Burst Gate Delay                                     | BDELAY    | 0x19             | 0x5D                                        | 0x72 <sup>(1)</sup>                 | 0x5D                   | 0x72 <sup>(1)</sup>         | 0x5D                                      | 0x72                                           |
| ADC Interface                                        | ADC       | 0x1A             | 0x82                                        | 0x82                                | 0x82                   | 0x82                        | 0x82                                      | 0x82                                           |
| Video Timing Control                                 | VTC       | 0x1B             | 0x00                                        | 0x00                                | 0x00                   | 0x00                        | 0x00                                      | 0x00                                           |
| Extended Data Ser-<br>vices/Closed Caption<br>Status | CC_STATUS | 0x1C             | 0x00                                        | 0x00                                | 0x00                   | 0x00                        | 0x00                                      | 0x00                                           |
| Extended Data Ser-<br>vices/Closed Caption Data      | CC_DATA   | 0x1D             | 0x00                                        | 0x00                                | 0x00                   | 0x00                        | 0x00                                      | 0x00                                           |
| White Crush Down Count                               | WC_DN     | 0x1E             | 0x7F                                        | 0x7F                                | 0x7F                   | 0x7F                        | 0x7F                                      | 0x7F                                           |
| Software Reset                                       | SRESET    | 0x1F             | _                                           | _                                   | _                      | _                           | _                                         | _                                              |
| Programmable I/O                                     | P_IO      | 0x3F             | _                                           | _                                   | _                      | _                           | _                                         | _                                              |
|                                                      | SEC       | AM Vide          | o Register l                                | Difference                          | S                      |                             |                                           |                                                |
| Miscellaneous Control                                | CONTROL   | T -              | _                                           | 0x00                                | l –                    | 0x00                        | _                                         | _                                              |
| SC Loop Control                                      | SCLOOP    | <u> </u>         | _                                           | 0x10                                | _                      | 0x10                        | _                                         | _                                              |
| Burst Gate Delay                                     | BDELAY    | +                | _                                           | 0xA0                                | <u> </u>               | 0xA0                        |                                           |                                                |

Notes: (1). SECAM Video Register differences to PAL video.

80

<sup>(2).</sup> When using one field, no additional vertical scaling is necessary for CIF resolutions. The INT bit in register 0xB(VSCALE\_HI) should be set to a logical 0 when scaling from only one field.

0x00— Device Status Register (STATUS)

#### 0x00— Device Status Register (STATUS)

The MPU can read or write to this register at any time. Upon reset, it is initialized to 0x00. COF is the LSB. By writing to the register, the COF and LOF status bits hold their values until reset to their default values. The other six bits do not hold their values, but continually output the status. An asterisk indicates the default option.

| 7    | ·    | 5     | 4    |      |         | 1   |     |
|------|------|-------|------|------|---------|-----|-----|
| PRES | HLOC | FIELD | NUML | CSEL | CCVALID | LOF | COF |
| 0    | 0    | 0     | 0    | 0    | 0       | 0   | 0   |

**PRES** 

Video Present Status—Video is determined to be not present when an input sync is not detected in 31 consecutive line periods.

0\* = Video not present 1 = Video present

HLOC

Device in H-lock—If HSYNC is found within  $\pm 1$  clock cycle of the expected position of HSYNC for 32 consecutive lines, this bit is set to a logical 1. Once set, if HSYNC is not found within  $\pm 1$  clock cycle of the expected position of HSYNC for 32 consecutive lines, this bit is set to a logical 0. MPU writes to this bit are ignored. This bit indicates the stability of the incoming video. Although it is an indicator of horizontal locking, some video sources characteristically vary from line-to-line by more than one clock cycle. This causes the bit to never be set. Consumer VCRs are examples of sources that tend to never set this bit.

)\* = Device not in H-lock 1 = Device in H-lock

FIELD

Field Status—This bit reflects whether an odd or even field is being decoded. The FIELD bit is determined by the relationship between  $\overline{\text{HRESET}}$  and  $\overline{\text{VRESET}}$ .

0\* = Odd field 1 = Even field

NUML

Number of Lines—This bit identifies the number of lines found in the video stream. This bit is used to determine the type of video input to the Bt829A. Thirty two consecutive fields with the same number of lines is required before this status bit will change.

0\* = 525-line format (NTSC/PAL-M) 1 = 625-line format (PAL/SECAM)

**CSEL** 

Crystal Select—This bit identifies which crystal port is selected. When automatic format detection is enabled, this bit will be the same as NUML.

0\* = XTAL0 input selected 1 = XTAL1 input selected

**CCVALID** 

Valid Closed Caption Data—This bit indicates that valid closed caption or Extended Data Services (EDS) sample pairs have been stored in the closed caption data registers. This bit indicates that the closed caption data FIFO is half full. It is reset after being written to or when a chip reset occurs.

0x01—Input Format Register (IFORM)

VideoStream II Decoders

LOF

Luma ADC Overflow—On power-up, this bit is set to 0. If an ADC overflow occurs, the bit is set to a logical 1. It is reset after being written to, or when a chip reset occurs. When the ADC is in power-down mode (Y\_SLEEP = 1) the state of this bit is not valid and should be ignored. When the luma A/D is in sleep mode, LOF is set to 1.

COF

Chroma ADC Overflow—On power-up, this bit is set to 0. If an ADC overflow occurs, the bit is set to a logical 1. It is reset after being written to, or when a chip reset occurs. When the ADC is in power-down mode (C\_SLEEP = 1), the state of this bit is not valid and should be ignored. When the chroma A/D is in sleep mode, COF is set to 1.

#### 0x01—Input Format Register (IFORM)

The MPU may read or write to this control register at any time. Upon reset, it is initialized to 0x58. FORMAT(0) is the LSB. An asterisk indicates the default option.

| 7       | 6   | 5    | 4   | 3   |        | 1 | 0 |
|---------|-----|------|-----|-----|--------|---|---|
| HACTIVE | MUX | KSEL | XTS | SEL | FORMAT |   |   |
| 0       | 1   | 0    | 1   | 1   | 0      | 0 | 0 |

**HACTIVE** 

When using the Bt829A with a packed memory architecture, for example, with field memories, this bit should be programmed with a logical 1. When implementing a VRAM based architecture, this bit should be programmed with a logical 0.

0\* = Reset HACTIVE with HRESET 1 = Extend HACTIVE beyond HRESET

MUXSEL

This bit is used for software control of video input selection. The Bt829A can select between four composite video sources, or three composite and one S-Video source.

00 = Select MUX3 input to MUXOUT 01 = Select MUX2 input to MUXOUT 10\* = Select MUX0 input to MUXOUT 11 = Select MUX1 input to MUXOUT

**XTSEL** 

If automatic format detection is required, logical 11 must be loaded. Logical 01 and 10 are used if software format selection is desired.

00 = Reserved

01 = Select XT0 input (only XT0 present) 10 = Select XT1 input (both XTs present) 11\* = Auto XT select enabled (both XTs present)

**FORMAT** 

Automatic format detection may be enabled or disabled. The NUML bit is used to determine the input format when automatic format detection is enabled.

000\* = Auto format detect enabled 001 = NTSC (M) input format 010 = NTSC with no pedestal format 011 = PAL (B, D, G, H, I) input format

100 = PAL (M) input format 101 = PAL (N) input format 110 = SECAM input format

111 = PAL (N combination) input format

0x02—Temporal Decimation Register (TDEC)

#### 0x02—Temporal Decimation Register (TDEC)

The MPU can read or write to this control register at any time. Upon reset, it is initialized to 0x00. DEC\_RAT(0) is the LSB. This register enables temporal decimation by discarding a finite number of fields or frames from the incoming video. An asterisk indicates the default option.

| 7         | 6        | 5 | 4       | 3 | 2 | 1 | 0 |  |  |  |
|-----------|----------|---|---------|---|---|---|---|--|--|--|
| DEC_FIELD | FLDALIGN |   | DEC_RAT |   |   |   |   |  |  |  |
| 0         | 0        | 0 | 0       | 0 | 0 | 0 | 0 |  |  |  |

**DEC\_FIELD** This bit defines whether decimation occurs according to fields or frames.

0\* = Decimate frames 1 = Decimate fields

**FLDALIGN** This bit aligns the start of decimation with an even or odd field.

0\* = Start decimation on the odd field (an odd field is the first field dropped).

1 = Start decimation on the even field (an even field is the first field dropped).

DEC\_RAT is the number of fields or frames dropped out of 60 NTSC or 50 PAL/SECAM fields or frames. 0x00 value disables decimation (all video frames and fields are output).

**NOTE:** Use caution when changing the programming in the TDEC register. 0x00 must be loaded before the decimation value. This ensures that decimation does not start on the wrong field or frame. The register should not be loaded with DEC\_RAT greater than 60 (0x3C) for NTSC, or greater than 50 (0x34) for PAL/SECAM.

 $xx00\ 0000-xx11\ 1111 = Number of fields/frames dropped.$ 

## 0x03—MSB Cropping Register (CROP)

The MPU can read or write to this control register at any time. Upon reset, it is initialized to 0x12. HACTIVE\_MSB(0) is the LSB. See the VACTIVE, VDELAY, HACTIVE, and HDELAY registers for descriptions on the operation of this register.

| 7     | 6     | 5           | 4 | 3          | 2 | 1           | 0 |
|-------|-------|-------------|---|------------|---|-------------|---|
| VDELA | Y_MSB | VACTIVE_MSB |   | HDELAY_MSB |   | HACTIVE_MSB |   |
| 0     | 0     | 0           | 1 | 0          | 0 | 1           | 0 |

**VDELAY\_MSB** 00xx xxxx-11xx xxxx =The most significant two bits of vertical delay register.

**VACTIVE MSB** xx00 xxxx - xx11 xxxx =The most significant two bits of vertical active register.

HDELAY\_MSB xxxx 00xx-xxxx 11xx =The most significant two bits of horizontal delay register.

**HACTIVE\_MSB** xxxx xx00-xxxx xx11 =The most significant two bits of horizontal active register.

0x04— Vertical Delay Register, Lower Byte (VDELAY\_LO)

VideoStream II Decoders

#### 0x04— Vertical Delay Register, Lower Byte (VDELAY\_LO)

The MPU can read or write to this control register at any time. Upon reset, it is initialized to 0x16. The LSB (LSB) is VDELAY\_LO(0). This 8-bit register is the lower byte of the 10-bit VDELAY register. The CROP register contains the two MSBs of VDELAY. VDELAY defines the number of half lines between the trailing edge of VRESET and the start of active video.

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

**VDELAY\_LO** 0x01-0xFF =The LSByte of the vertical delay register.

#### 0x05— Vertical Active Register, Lower Byte (VACTIVE\_LO)

The MPU can read or write to this control register at any time. Upon reset, it is initialized to 0xE0. The LSB is VACTIVE\_LO(0). This 8-bit register is the lower byte of the 10-bit VACTIVE register. The CROP register contains the two MSBs of VACTIVE. VACTIVE defines the number of lines used in the vertical scaling process. The actual number of lines output by the Bt829A is SCALING\_RATIO \* VACTIVE.

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

**VACTIVE\_LO** 0x00-0xFF =The LSByte of the vertical active register.

## 0x06— Horizontal Delay Register, Lower Byte (HDELAY\_LO)

The MPU can read or write to this control register at any time. Upon reset, it is initialized to 0x78. HDELAY\_LO(0) is the LSB. This 8-bit register is the lower byte of the 10-bit HDELAY register. The two MSBs of HDELAY are contained in the CROP register. HDELAY defines the number of scaled pixels between the falling edge of HRESET and the start of active video.

|   | 6             | 5 | 4 | 3 |  | 1 | 0 |  |  |  |  |
|---|---------------|---|---|---|--|---|---|--|--|--|--|
|   | HDELAY_LO     |   |   |   |  |   |   |  |  |  |  |
| 0 | 0 1 1 1 1 0 0 |   |   |   |  |   |   |  |  |  |  |

HDELAY\_LO 0x01-0xFF =the LSByte of the horizontal delay register. HACTIVE pixels are output by the chip starting at the fall of HRESET.

Caution: HDELAY must be programmed with an even number.

x07— Horizontal Active Register, Lower Byte (HACTIVE\_LO)

#### 0x07— Horizontal Active Register, Lower Byte (HACTIVE\_LO)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0x80. HACTIVE\_LO(0) is the LSB. HACTIVE defines the number of horizontal active pixels-per-line output by the Bt829A.

| 7 | 6             | 5 | 4 | 3 |  | 1 | 0 |  |  |  |  |
|---|---------------|---|---|---|--|---|---|--|--|--|--|
|   | HACTIVE_LO    |   |   |   |  |   |   |  |  |  |  |
| 1 | 1 0 0 0 0 0 0 |   |   |   |  |   |   |  |  |  |  |

HACTIVE\_LO 0x00-0xFF =The LSByte of the horizontal active register. This 8-bit register is the lower byte of the 10-bit HACTIVE register. The CROP registers contains the two MSBs of HACTIVE.

## 0x08— Horizontal Scaling Register, Upper Byte (HSCALE\_HI)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0x02. This 8-bit register is the upper byte of the 16-bit HSCALE register.

| 7 | 6         |   | 4 |   |   | 1 | 0 |  |
|---|-----------|---|---|---|---|---|---|--|
|   | HSCALE_HI |   |   |   |   |   |   |  |
| 0 | 0         | 0 | 0 | 0 | 0 | 1 | 0 |  |

**HSCALE\_HI** 0x00-0xFF =The most significant byte of the horizontal scaling ratio.

### 0x09— Horizontal Scaling Register, Lower Byte (HSCALE\_LO)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0xAC. This 8-bit register is the lower byte of the 16-bit HSCALE register.

| 7               | 6         |  | 4 | 3 | 2 | 1 |  |  |
|-----------------|-----------|--|---|---|---|---|--|--|
|                 | HSCALE_LO |  |   |   |   |   |  |  |
| 1 0 1 0 1 1 0 0 |           |  |   |   |   |   |  |  |

**HSCALE LO** 0x00-0xFF =The LSByte of the horizontal scaling ratio.

0x0A—Brightness Control Register (BRIGHT)

VideoStream II Decoders

# 0x0A— Brightness Control Register (BRIGHT)

The brightness control involves the addition of a two's complement number to the luma channel. Brightness can be adjusted in 255 steps, from –128 to +127. The resolution of brightness change is one LSB 0.39% with respect to the full luma range. An asterisk indicates the default option.

| 7 | 6      | 5 | 4 | 3 | 2 |   | n |  |
|---|--------|---|---|---|---|---|---|--|
|   | BRIGHT |   |   |   |   |   |   |  |
| 0 | 0      | 0 | 0 | 0 | 0 | 0 | 0 |  |

#### **BRIGHT**

| Day Wales | Diagon Value | Brightness Changed By |                       |  |  |  |
|-----------|--------------|-----------------------|-----------------------|--|--|--|
| Hex Value | Binary Value | Number of LSBs        | Percent of Full Scale |  |  |  |
| 0x80      | 1000 0000    | -128                  | -100%                 |  |  |  |
| 0x81      | 1000 0001    | -127                  | -99.22%               |  |  |  |
|           | ·            |                       |                       |  |  |  |
| 0xFF      | 1111 1111    | -01                   | -0.78%                |  |  |  |
| 0x00*     | 0000 0000*   | 00                    | 0%                    |  |  |  |
| 0x01      | 0000 0001    | +01                   | +0.78%                |  |  |  |
|           |              |                       |                       |  |  |  |
| 0x7E      | 0111 1110    | +126                  | +99.2%                |  |  |  |
| 0x7F      | 0111 1111    | +127                  | +100%                 |  |  |  |

0x0B-Miscellaneous Control Register (CONTROL)

#### 0x0B— Miscellaneous Control Register (CONTROL)

The MPU can read or write to this control register at any time. Upon reset, it is initialized to 0x20. SAT\_V\_MSB is the LSB. An asterisk indicates the default option.

| 7      | 6    | 5    | 4       | 3        | 2       | 1         | 0         |
|--------|------|------|---------|----------|---------|-----------|-----------|
| LNOTCH | COMP | LDEC | CBSENSE | Reserved | CON_MSB | SAT_U_MSB | SAT_V_MSB |
| 0      | 0    | 1    | 0       | 0        | 0       | 0         | 0         |

LNOTCH

This bit is used to include the luma notch filter. For monochrome video, the notch should not be used. This will output full bandwidth luminance.

0\* = Enable the luma notch filter 1 = Disable the luma notch filter

COMP

When COMP is set to logical 1, the luma notch is disabled. When COMP is set to logical 0, the C ADC is disabled.

0\* = Composite Video 1 = Y/C Component Video

LDEC

The luma decimation filter is used to reduce the high-frequency component of the luma signal. This is useful when scaling to CIF resolutions or lower.

0 = Enable luma decimation using selectable H filter

1\* = Disable luma decimation

**CBSENSE** 

This bit controls whether the first pixel of a line is a Cb pixel or a Cr pixel. For example, if CBSENSE is low and HDELAY is an even number, the first active pixel output is a Cb pixel. If HDELAY is odd, CBSENSE may be programmed high to produce a Cb pixel as the first active pixel output.

0\* = Normal Cb, Cr order 1 = Invert Cb, Cr order

Reserved

This bit should only be written with a logical 0.

CON\_MSB

The most significant bit of the luma gain (contrast) value.

SAT\_U\_MSB

The most significant bit of the chroma (u) gain value.

 $SAT_V_MSB$ 

The most significant bit of the chroma (v) gain value.

0x0C—Luma Gain Register, Lower Byte (CONTRAST\_LO)

VideoStream II Decoders

## 0x0C—Luma Gain Register, Lower Byte (CONTRAST\_LO)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0xD8. CONTRAST\_LO(0) is the LSB. The CON\_L\_MSB bit and the CONTRAST\_LO register concatenate to form the 9-bit CONTRAST register. The value in this register is multiplied by the luminance value to provide contrast adjustment.

| 7 | 6             |  | 4 | 3 | - 2 |  | 0 |  |  |
|---|---------------|--|---|---|-----|--|---|--|--|
|   | CONTRAST_LO   |  |   |   |     |  |   |  |  |
| 1 | 1 1 0 1 1 0 0 |  |   |   |     |  |   |  |  |

**CONTRAST\_LO** The least significant byte (LSByte) of the luma gain (contrast) value.

| Decimal Value | Hex Value | % of Original Signal |
|---------------|-----------|----------------------|
| 511           | 0x1FF     | 236.57%              |
| 510           | 0x1FE     | 236.13%              |
| ÷             | ÷         | · ·                  |
| 217           | 0x0D9     | 100.46%              |
| 216           | 0x0D8     | 100.00%              |
| :             | ÷         | ÷                    |
| 128           | 0x080     | 59.26%               |
| :             | :         | :                    |
| 1             | 0x001     | 0.46%                |
| 0             | 0x000     | 0.00%                |

#### 0x0D— Chroma (U) Gain Register, Lower Byte (SAT\_U\_LO)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0xFE. SAT\_U\_LO(0) is the LSB. SAT\_U\_MSB in the CONTROL register and SAT\_U\_LO concatenate to give a 9-bit register (SAT\_U). This register is used to add a gain adjustment to the U component of the video signal. By adjusting the U and V color components of the video stream by the same amount, the saturation is adjusted. For normal saturation adjustment, the gain in both the color difference paths must be the same (i.e., the ratio between the value in the U gain register and the value in the V gain register should be kept constant at the default power-up ratio). When changing the saturation, if the SAT\_U\_MSB bit is altered, care must be taken to ensure that the other bits in the CONTROL register are not affected.

| 7 | 6           | 5 |  |  |  | 1 | 0 |  |
|---|-------------|---|--|--|--|---|---|--|
|   | SAT_U_LO    |   |  |  |  |   |   |  |
| 1 | 1 1 1 1 1 0 |   |  |  |  |   |   |  |

SAT\_U\_LO

| Decimal Value | Hex Value | % of Original Signal |
|---------------|-----------|----------------------|
| 511           | 0x1FF     | 201.18%              |
| 510           | 0x1FE     | 200.79%              |
| ·             | :         | :                    |
| 255           | 0x0FF     | 100.39%              |
| 254           | 0x0FE     | 100.00%              |
| ÷             | :         | :                    |
| 128           | 0x080     | 50.39%               |
| :             |           | :                    |
| 1             | 0x001     | 0.39%                |
| 0             | 0x000     | 0.00%                |

0x0E—Chroma (V) Gain Register, Lower Byte (SAT\_V\_LO)

VideoStream II Decoders

#### 0x0E— Chroma (V) Gain Register, Lower Byte (SAT\_V\_LO)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0xB4. SAT\_V\_LO(0) is the LSB. SAT\_V\_MSB in the CONTROL register and SAT\_V\_LO concatenate to give a 9-bit register (SAT\_V). This register is used to add a gain adjustment to the V-component of the video signal. By adjusting the U and V color components of the video stream by the same amount, the saturation is adjusted. For normal saturation adjustment, the gain in both the color difference paths must be the same (i.e., the ratio between the value in the U gain register and the value in the V gain register should be kept constant at the default power-up ratio). When changing the saturation, if the SAT\_V\_MSB bit is altered, care must be taken to ensure that the other bits in the CONTROL register are not affected.

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

SAT\_V\_LO

| Decimal Value | Hex Value | % of Original Signal |
|---------------|-----------|----------------------|
| 511           | 0x1FF     | 283.89%              |
| 510           | 0x1FE     | 283.33%              |
| ·             | :         | :                    |
| 181           | 0x0B5     | 100.56%              |
| 180           | 0x0B4     | 100.00%              |
| ·<br>·        | ·<br>·    | ÷                    |
| 128           | 0x080     | 71.11%               |
| ÷             | ÷         | :                    |
| 1             | 0x001     | 0.56%                |
| 0             | 0x000     | 0.00%                |

0x0F—Hue Control Register (HUE)

# 0x0F— Hue Control Register (HUE)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0x00. HUE(0) is the LSB. Hue adjustment involves the addition of a two's complement number to the demodulating subcarrier phase. Hue can be adjusted in 256 steps in the range  $-90^{\circ}$  to  $+89.3^{\circ}$ , in increments of  $0.7^{\circ}$ . An asterisk indicates the default option.

| 7 6 5 4 3 2 1 0<br>HUE |               |  |  |  |  |  |  |  |  |
|------------------------|---------------|--|--|--|--|--|--|--|--|
| 0                      | 0 0 0 0 0 0 0 |  |  |  |  |  |  |  |  |

HUE

| Hex Value | Binary Value | Subcarrier Reference<br>Changed By | Resulting Hue<br>Changed By |
|-----------|--------------|------------------------------------|-----------------------------|
| 0x80      | 1000 0000    | -90°                               | +90°                        |
| 0x81      | 1000 0001    | -89.3°                             | +89.3°                      |
|           |              | :<br>:                             |                             |
| 0xFF      | 1111 1111    | -0.7°                              | +0.7°                       |
| 0x00*     | 0000 0000    | 00°                                | 00°                         |
| 0x01      | 0000 0001    | +0.7°                              | -0.7°                       |
|           |              | ÷                                  |                             |
| 0x7E      | 0111 1110    | +88.6°                             | -88.6°                      |
| 0x7F      | 0111 1111    | +89.3°                             | -89.3°                      |

0x10—SC Loop Control (SCLOOP)

VideoStream II Decoders

#### 0x10—SC Loop Control (SCLOOP)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0x00. ACCEL is the LSB. An asterisk indicates the default option.

| 7    | 6    | 5     | 4  | 3   | 2        | 1 | 0 |
|------|------|-------|----|-----|----------|---|---|
| PEAK | CAGC | CKILL | HF | ILT | Reserved |   |   |
| 0    | 0    | 0     | 0  | 0   | 0        | 0 | 0 |

**PEAK** 

This bit determines whether the normal luma low pass filters are implemented via the HFILT bits, or whether the peaking filters are implemented. The LDEC bit in the control register must be programmed to zero to use these filters.

0\* = Normal luma low pass filtering 1 = Use luma peaking filters

CAGC

This bit controls the Chroma AGC function. When enabled, Chroma AGC will compensate for non-standard chroma levels. The compensation is achieved by multiplying the incoming chroma signal by a value in the range of 0.5 to 2.0.

0\* = Chroma AGC Disabled 1 = Chroma AGC Enabled

CKILL

This bit determines whether the low color detector and removal circuitry is enabled.

0\* = Low Color Detection and Removal Disabled 1 = Low Color Detection and Removal Enabled

**HFILT** 

These bits control the configuration of the optional 6-tap Horizontal Low-Pass Filter. The Auto Format Mode determines the appropriate low-pass filter based on the selected horizontal scaling ratio. To use these filters, the LDEC bit in the CONTROL register must be programmed to zero.

00\* = Auto Format—If Auto Format is selected when horizontally scaling between full resolution and half resolution, no filtering is selected. When scaling between one-half and one-third resolution, the CIF filter is used. When scaling between one-third and one-seventh resolution, the QCIF filter is used; at less than one-seventh resolution, the ICON filter is used.

01 = CIF

10 = QCIF (When decoding SECAM video, this filter must be

enabled.)

11 = ICON

If the PEAK bit is set to logical 1, the HFILT bits determine which peaking filter is selected.

00 = Maximum peaking response
 01 = Medium peaking response
 10 = Low peaking response
 11 = Minimum peaking response

Reserved

These bits must be set to zero.

0x11—White Crush Up Count Register (WC\_UP)

### 0x11— White Crush Up Count Register (WC\_UP)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0xCF. UPCNT(0) is the LSB.

| 7   | 6   | 5     | 4 |   | 2 | 1 |   |
|-----|-----|-------|---|---|---|---|---|
| M.A | AJS | UPCNT |   |   |   |   |   |
| 1   | 1   | 0     | 0 | 1 | 1 | 1 | 1 |

MAJS

These bits determine the majority comparison point for the White Crush Up function.

00 = 3/4 of maximum luma value 01 = 1/2 of maximum luma value 10 = 1/4 of maximum luma value

11\* = Automatic

**UPCNT** 

The value programmed in these bits accumulates once per field or frame when the majority of the pixels in the active region of the image are below a selected value. The accumulated value determines the extent to which the AGC value needs to be raised. This keeps the SYNC level proportionate with the white level. The UPCNT value is assumed positive:

3F = 63 3E = 62 : : : . . . . 00 = 0 0x12—Output Format Register (OFORM)

VideoStream II Decoders

#### 0x12— Output Format Register (OFORM)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0x06. OES(0) is the LSB. An asterisk indicates the default option.

| 7     |      |   |           | 3    | 2   | 1  | 0  |
|-------|------|---|-----------|------|-----|----|----|
| RANGE | CORE |   | VBI_FRAME | CODE | LEN | Ol | ES |
| 0     | 0    | 0 | 0         | 0    | 1   | 1  | 0  |

RANGE

Luma Output Range—This bit determines the range for the luminance output on the Bt829A. The range must be limited when using the control codes as video timing.

0\* = Normal operation (Luma range 16–253, chroma range 2–253) Y=16 is black (pedestal)

Cr, Cb=128 is zero color information

1 = Full-range Output (Luma range 0–255, chroma range 2–253)

Y=0 is black (pedestal)

Cr, Cb=128 is zero color information

CORE

Luma Coring—These bits control the coring value used by the Bt829A. When coring is active and the total luminance level is below the limit programmed into these bits, the luminance signal is truncated to zero.

 $00^* = 0x00$  no coring

01 = 8 10 = 16 11 = 32

**VBI FRAME** 

This bit enables the VBI Frame Output Mode. In the VBI Frame Output Mode, every line consists of unfiltered 8\*Fsc non-image data. This bit supersedes bit VBIEN in the VTC register. VBIFMT (also in VTC) works in both VBI frame and line output modes.

0\* = VBI Frame Output Mode disabled 1 = VBI Frame Output Mode enabled

CODE

Code Control Disable—This bit determines whether control codes are output with the video data. SPI Mode 2 requires this bit to be programmed with a logical 1. When control codes are inserted into the data stream, the external control signals are still available.

0\* = Disable control code insertion 1 = Enable control code insertion

LEN

8- or 16-Bit Format—This bit determines the output data format. In 8-bit mode, the data is output on VD[15:8].

0 = 8-bit YCrCb 4:2:2 output stream 1\* = 16-Bit YCrCb 4:2:2 output stream

| VD     | VD[15] | • • • | VD[8] VD[7]   | • • • | VD[0]    |
|--------|--------|-------|---------------|-------|----------|
| 16-bit | Y[7]   | • • • | Y[0] Cr/Cb[7] | • • • | Cr/Cb[0] |

8-bit Y/Cr/Cb[7] • • • Y/Cr/Cb[0]

0x13— Vertical Scaling Register, Upper Byte (VSCALE\_HI)

**OES** 

OES[1] and OES[0] control the output three-states when the  $\overline{\text{OE}}$  pin or the OUTEN bit (VPOLE bit 7) is asserted. The pins are divided into three groups: timing ( $\overline{\text{HRESET}}$ ,  $\overline{\text{VRESET}}$ , ACTIVE, VACTIVE, CBFLAG, DVALID, and FIELD), clocks (CLKx1, CLKx2 and QCLK), and data (VD[15:0]). CCVALID cannot output three-states.

00 = Three-state timing and data only

01 = Three-state data only

10 = Three-state timing, data and clocks 11 = Three-state clocks and data only

### 0x13— Vertical Scaling Register, Upper Byte (VSCALE\_HI)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0x60. An asterisk indicates the default option.

| 7     | 6    | 5   | 4         | 3 | 2 | 1 | 0 |
|-------|------|-----|-----------|---|---|---|---|
| YCOMB | СОМВ | INT | VSCALE_HI |   |   |   |   |
| 0     | 1    | 1   | 0         | 0 | 0 | 0 | 0 |

YCOM B

Luma Comb Enable—When enabled, the luma comb filter performs a weighted average on two, three, four, or five lines of luminance data. The coefficients used for the average are fixed and no interpolation is performed. The number of lines used for the luma comb filter is determined by the VFILT bits in the VTC register. When disabled by a logical 0, filtering and full vertical interpolation is performed based upon the value programmed into the VSCALE register. The LUMA comb filter cannot be enabled on the Bt827A.

0\* = Vertical low-pass filtering and vertical interpolation

1 = Vertical low-pass filtering only

COMB

Chroma Comb Enable—This bit determines whether the chroma comb is included in the data path. If enabled, a full line store is used to average adjacent lines of color information. This reduces cross-color artifacts.

0 = Chroma comb disabled 1\* = Chroma comb enabled

INT

Interlace—This bit is programmed to indicate whether the incoming video is interlaced or non-interlaced. For example, when using the full frame as input for vertical scaling, this bit should be programmed high. If using a single field for vertical scaling, this bit should be programmed low. Single field scaling is normally used when scaling below CIF resolution and when outputing to a non-interlaced monitor. Using a single field reduces motion artifacts.

0 = Non-interlace VS 1\* = Interlace VS

**VSCALE HI** 

Vertical Scaling Ratio—These five bits represent the most significant portion of the 13-bit vertical scaling ratio register. Care must be taken to avoid altering the contents of the LINE, COMB, and INT bits when adjusting the scaling ratio.

0x14— Vertical Scaling Register, Lower Byte (VSCALE\_LO)

VideoStream II Decoders

#### 0x14— Vertical Scaling Register, Lower Byte (VSCALE\_LO)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0x00.

| 7 |           |   |   | 3 |   | 1 |   |  |  |
|---|-----------|---|---|---|---|---|---|--|--|
|   | VSCALE_LO |   |   |   |   |   |   |  |  |
| 0 | 0         | 0 | 0 | 0 | 0 | 0 | 0 |  |  |

#### VSCALE\_LO

Vertical Scaling Ratio—These eight bits represent the LSbyte of the 13-bit vertical scaling ratio register. They are concatenated with 5 bits in VSCALE\_HI. The following equation is used to determine the value for this register:

VSCALE = 
$$(0x10000 - \{ [(scaling\_ratio) - 1] * 512 \}) & 0x1FFF$$

For example, to scale PAL/SECAM input to square pixel QCIF, the total number of vertical lines is 156:

VSCALE = 
$$(0x10000 - \{ [(4/1) - 1] * 512 \}) & 0x1FFF$$
  
=  $0x1A00$ 

#### 0x15— Test Control Register (TEST)

This control register is reserved for putting the part into test mode. Write operation to this register may cause undetermined behavior and should not be attempted. A read cycle from this register returns 0x01, and only a write of 0x01 is permitted.

97

VideoStream II Decoders

0x16— Video Timing Polarity Register (VPOLE)

## 0x16— Video Timing Polarity Register (VPOLE)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0x00. An asterisk indicates the default option.

| 7      | 6      | 5       | 4      | 3     | 2      | 1      | 0      |
|--------|--------|---------|--------|-------|--------|--------|--------|
| OUT_EN | DVALID | VACTIVE | CBFLAG | FIELD | ACTIVE | HRESET | VRESET |
| 0      | 0      | 0       | 0      | 0     | 0      | 0      | 0      |

**OUTEN** 

Three-states the pins defined by OES in the OFORM register. The affected pins are: VD[15:0], HRESET, VRESET, ACTIVE, VACTIVE, DVALID, CBFLAG, FIELD, QCLK, CLKx1, and CLKx2.

When Pin 85 is a logical 0

0\* = Enable outputs 1 = Three-state outputs

When Pin 85 is a logical 1

0\* = Three-state outputs 1 = Enable outputs

**DVALID** 

0\* = DVALID Pin: Active high 1 = DVALID Pin: Active low

VACTIVE

0\* = VACTIVE Pin: Active high 1 = VACTIVE Pin: Active low

**CBFLAG** 

0\* = CBFLAG Pin: Active high 1 = CBFLAG Pin: Active low

FIELD

0\* = FIELD Pin: High indicates odd field 1 = FIELD Pin: High indicates even field

**ACTIVE** 

0\* = ACTIVE Pin: Active high 1 = ACTIVE Pin: Active low

**HRESET** 

0\* = <u>HRESET</u> Pin: Active low 1 = <u>HRESET</u> Pin: Active high

**VRESET** 

 $0^* = \overline{VRESET}$  Pin: Active low  $1 = \overline{VRESET}$  Pin: Active high 0x17—ID Code Register (IDCODE)

VideoStream II Decoders

### 0x17—ID Code Register (IDCODE)

This control register may be read by the MPU at any time. PART\_REV(0) is the LSB.

| 7 |     | 5    | 4 | 3        | 2 |   | 0 |
|---|-----|------|---|----------|---|---|---|
|   | PAR | T_ID |   | PART_REV |   |   |   |
| 1 | 1   | 1    | 0 | 0        | 0 | 0 | 0 |

PART\_ID

1110 = Bt829A Part ID Code 1100 = Bt827A Part ID Code

PART\_REV

0x0 - 0xF = Current Revision ID Code

### 0x18— AGC Delay Register (ADELAY)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0x68.

| 7      | 6 |   |   |   | 2 | 1 | U |  |
|--------|---|---|---|---|---|---|---|--|
| ADELAY |   |   |   |   |   |   |   |  |
| 0      | 1 | 1 | 0 | 1 | 0 | 0 | 0 |  |

**ADELAY** 

This register indicates the AGC gate delay for back-porch sampling. The following equation should be used to determine the value for this register:

ADELAY = 
$$(6.8 \,\mu\text{S} * f_{\text{CLK}x1}) + 7$$

For example, for an NTSC input signal:

ADELAY = 
$$(6.8 \mu S * 14.32 \text{ MHz}) + 7$$
  
=  $104 (0x68)$ 

0x19—Burst Delay Register (BDELAY)

# 0x19— Burst Delay Register (BDELAY)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0x5D. BDELAY(0) is the LSB.

|        | 6 | 5 |   |   | 2 | 1 | 0 |  |  |
|--------|---|---|---|---|---|---|---|--|--|
| BDELAY |   |   |   |   |   |   |   |  |  |
| 0      | 1 | 0 | 1 | 1 | 1 | 0 | 1 |  |  |

**BDELAY** 

This register indicates the burst gate delay for sub-carrier sampling. The following equation should be used to determine the value for this register:

BDELAY = 
$$(6.5 \,\mu\text{S} * f_{\text{CLKx1}})$$

For example, for an NTSC input signal:

BDELAY = 
$$(6.5 \mu S * 14.32 \text{ MHz})$$
  
=  $93 (0x5D)$ 

0x1 A- ADC Interface Register (ADC)

VideoStream II Decoders

#### 0x1A— ADC Interface Register (ADC)

This control register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0x82. Reserved is the LSB. An asterisk indicates the default option.

| 7    | 6     | 5      | 4      | 3         | 2       | 1       | 0     |
|------|-------|--------|--------|-----------|---------|---------|-------|
| Rese | erved | SYNC_T | AGC_EN | CLK_SLEEP | Y_SLEEP | C_SLEEP | CRUSH |
| 1    | 0     | 0      | 0      | 0         | 0       | 1       | 0     |

Reserved These bits should only be written with bit 7 set at a logical 1 and bit 6 set at a logical 0.

SYNC\_T This bit defines the voltage level for which the SYNC signal can be detected.

0\* = Analog SYNCDET threshold high (~125 mV) 1 = Analog SYNCDET threshold low (~75 mV)

This bit controls the AGC function. When disabled, REFOUT is not driven, and an external reference voltage must be provided. When enabled, REFOUT is driven to control the A/D reference voltage.

0\* = AGC Enabled 1 = AGC Disabled

When this bit is set at a logical 1, the system clock is powered down, but the output clocks (CLKx1 and CLKx2) are still running, and the I<sup>2</sup>C registers are still accessible. Recovery time is approximately one second.

0\* = Normal clock operation

1 = Shut down the system clock (power down)

Y\_SLEEP This bit enables the luma ADC to operate in sleep mode.

0\* = Normal Y ADC operation 1 = Sleep Y ADC operation

**C\_SLEEP** This bit enables the chroma ADC to operate in sleep mode.

0 = Normal C ADC operation 1\* = Sleep C ADC operation

This bit enables white CRUSH mode, and must be written with a logical 0.

 $0^*$  = Normal SYNC level to white level

1 = Enable white CRUSH mode to compensate for nonstandard

SYNC to white video relationship

0x1B— Video Timing Control (VTC)

#### 0x1B— Video Timing Control (VTC)

This register may be written to or read by the MPU at any time. Upon reset, it is initialized to 0x00. VFILT(0) is the LSB. An asterisk indicates the default option.

| 7     | 6      | 5       | 4     | 3      | 2        | 1  | 0   |
|-------|--------|---------|-------|--------|----------|----|-----|
| HSFMT | ACTFMT | CLKGATE | VBIEN | VBIFMT | VALIDFMT | VF | ILT |
| 0     | 0      | 0       | 0     | 0      | 0        | 0  | 0   |

**HSFMT** 

This bit selects between a single-pixel-wide HRESET and the standard 64-clock-wide HRESET.

 $0^* = \overline{\text{HRESET}}$  is 64 CLKx1 cycles wide

 $1 = \overline{\text{HRESET}}$  is 1 pixel wide

ACTFMT

This bit selects whether composite ACTIVE (HACTIVE and VACTIVE) or whether HACTIVE only is output on the ACTIVE pin.

0\* = ACTIVE is composite active 1 = ACTIVE is horizontal active

**CLKGATE** 

This bit selects the signals that are gated with CLK to create QCLK. If logical 0 is selected, the ACTIVE pin (composite ACTIVE or HACTIVE) is used in gating CLK.

0\* = CLKx1 and CLKx2 are gated with DVALID and ACTIVE to create QCLK

1 = CLKx1 and CLKx2 are gated with DVALID to create QCLK

**VBIEN** 

This bit enables VBI data to be captured.

 $0^*$  = Do not capture VBI

1 = Capture VBI

VBIFMT

This bit determines the byte ordering for VBI data.

0\* = Pixel N on the VD[15:8] data bus, pixel N+1 on the VD[7:0] data bus

Pixel N+1 on the VD[15:8] data bus, Pixel N on the VD[7:0] data bus (Pixel N refers to the first, third, fifth, and so on, while pixel N+1 refers to the second, fourth, and sixth in a horizontal line of video)

**VALIDFMT** 

 $0^*$  = Normal DVALID timing

1 = DVALID is the logical AND of VALID and ACTIVE, where ACTIVE is controlled by the ACTFMT bit. Also, the QCLK signal will free turn and is an inverted version of CLKx1 or CLKx2, depending upon whether 8- or 16-bit pixel output format is selected. 0x1B—Video Timing Control (VTC)

VideoStream II Decoders

**VFILT** 

These bits control the number of taps in the Vertical Scaling Filter. The number of taps must be chosen in conjunction with the horizontal scale factor to ensure that the needed data does not overflow the internal FIFO.

If the YCOMB bit in the VSCALE\_HI register is set at a logical 1, the following settings and equations apply:

00\* = 2-tap  $\frac{1}{2}(1+Z^{-1})$  Available at all resolutions.

01 = 3-tap  $\frac{1}{4}(1+2Z^{-1}+Z^{-2})$  Only available when scaling to less than 385 horizontal active pixels for PAL, or 361 for NTSC (CIF or smaller).

10 = 4-tap  $\frac{1}{8}(1 + 3Z^{-1} + 3Z^{-2} + Z^{-3})$  Only available when scaling to less than 193 horizontal active pixels for PAL, or 181 for NTSC (OCIF or smaller).

11 = 5-tap  $\frac{1}{16}(1+4Z^{-1}+6Z^{-2}+4Z^{-3}+Z^{-4})$  Only available when scaling to less than 193 horizontal active pixels for PAL, or 181 for NTSC (QCIF or smaller).

If the YCOMB bit in the VSCALE\_HI register is set at a logical 0, the following settings and equations apply:

 $00^*$  = 2-tap interpolation only. Available at all resolutions.

01 = 2-tap  $\frac{1}{2}(1 + Z^{-1})$  and 2-tap interpolation. Only available when scaling to less than 385 horizontal active pixels for PAL, or 361 for NTSC (CIF or smaller).

10 = 3-tap  $\frac{1}{4}(1+2Z^{-1}+Z^{-2})$  and 2-tap interpolation. Only available when scaling to less than 193 horizontal active pixels for PAL, or 181 for NTSC (QCIF or smaller).

11 = 4-tap  $\frac{1}{8}(1 + 3Z^{-1} + 3Z^{-2} + Z^{-3})$  and 2-tap interpolation. Only available when scaling to less than 193 horizontal active pixels for PAL, or 181 for NTSC (QCIF or smaller).

**NOTE:** The Bt827A can only be used with a VFILT value of 00, because it does not have a vertical scaling filter.

1C—Extended Data Service/Closed Caption Status Register

#### 0x1C— Extended Data Service/Closed Caption Status Register (CC\_STATUS)

This register may be written or read by the MPU at any time. Upon reset, the value of register bits 7, 1, and 0 are indeterminate because their status depends on the incoming CC/EDS data. Having register bits 6, 5, and 4 at their reset value causes the CC/EDS circuitry to be powered down.  $\overline{\text{LO}}_{-}\text{HI}$  is the LSB. An asterisk indicates the default option.

| 7          | 6          | 5   | 4  | 3  | 2  | 1      | 0             |
|------------|------------|-----|----|----|----|--------|---------------|
| PARITY_ERR | CCVALID_EN | EDS | CC | OR | DA | CC_EDS | <u>LO</u> _HI |
| Х          | 1          | 0   | 0  | 0  | 0  | Х      | Х             |

PARITY\_ERR This bit corresponds to the current word in CC\_DATA.

0 = No error

1 = Odd parity error

**NOTE:** Closed caption data is transmitted using odd parity.

CCVALID\_EN This bit serves as a mask for the CCVALID interrupts pin.

0 = Disabled CCVALID interrupts pin
 1 = Enabled CCVALID interrupts pin

This bit determines whether EDS data is written into the CC\_DATA FIFO.

0\* = EDS data is not written into the CC\_DATA FIFO 1 = EDS data is written into the CC\_DATA FIFO

This bit determines whether CC data is written into the CC\_DATA FIFO.

0\* = CC data is not written into the CC\_DATA FIFO 1 = CC data is written into the CC\_DATA FIFO

This bit indicates the CC\_DATA FIFO is full and that EDS or CC data has been lost. This bit is read only. On reset or read of CC\_DATA, this bit is set to zero.

0 = An overflow has not occurred since this bit was last reset

1 = An overflow has occurred

CC/EDS data available. This bit indicates whether valid data exists in the CC\_DATA FIFO. This bit is read only. On reset, this bit is set to zero.

0 = FIFO is empty

1 = One or more bytes available

This bit indicates whether a CC byte or an EDS byte is in the CC\_DATA register. After the CC\_DATA register is read, this bit is automatically updated. This bit is read only. On reset, this bit is not valid.

0 = Closed caption byte in CC\_DATA

1 = Extended data service byte in CC\_DATA

CC/EDS data are output in 16-bit words. This bit indicates whether the low or high byte is located in the CC\_DATA register. This bit is read only. On reset, this bit is not valid.

0 = Low byte is in the CC\_DATA register 1 = High byte is in the CC\_DATA register

Rockwell

OR

DA

ГО НІ

0x1D—Extended Data Service/Closed Caption Data

VideoStream II Decoders

#### 0x1D— Extended Data Service/Closed Caption Data Register (CC\_DATA)

The CC-DATA register is read only and can be read by the MPU at any time. Any writes to this register are ignored. Upon reset, the value of the bits in this register are indeterminate because their status depends on the incoming CC/EDS data. CC\_DATA(0) is the LSB.

| 7 |   | 5 |      |      |   |   |   |
|---|---|---|------|------|---|---|---|
|   |   |   | CC_I | DATA |   |   |   |
| Х | Х | х | х    | Х    | Х | Х | Х |

CC\_DATA

The low or high data byte transmitted in a closed caption or extended data service line.

#### 0x1E—White Crush Down Count Register (WC DN)

This control register may be written to or read by the MPU at any time. Upon reset, the value of the register bits is initialized to 0x7F. DNCNT(0) is the LSB. This register is programmed with a two's complement number.

| 7      | 6       | 5 | 4 | 3   | 2   |   | 0 |
|--------|---------|---|---|-----|-----|---|---|
| VERTEN | WCFRAME |   |   | DNe | CNT |   |   |
| 0      | 1       | 1 | 1 | 1   | 1   | 1 | 1 |

**VERTEN** 

 $0^*$  = Normal operation

1 = Adds vertical detection algorithm to reject noise causing false vertical syncs.

WCFRAME

This bit programs the rate at which the DNCNT and UPCNT values are accumulated.

0 = Once-per-field 1 = Once-per-frame

DNCNT

The value programmed in these bits accumulates at a rate of once-per-field or frame. The accumulated value determines the extent to which the AGC value needs to be lowered to keep the SYNC level proportionate to the white level.

The DNCNT value is assumed negative:

3F = -1 3E = -2: : : 00 = -64

## 0x1F—Software Reset Register (SRESET)

This command register can be written at any time. Read cycles to this register return an undefined value. A data write cycle to this register resets the device to the default state (indicated in the command register definitions by an asterisk). Writing any data value into this address resets the device.

0x3F—Programmable I/O Register (P\_IO)

#### 0x3F— Programmable I/O Register (P\_IO)

This control register may be written to or read by the MPU at any time. Upon reset, the value of the register bits is initialized to 0x00. OUT\_0 is the LSB. While in 8-bit output mode (SPI-8), the VD[7:0] pins are completely asynchronous. IN[3:0] represent the digital levels input on VD[7:4], while the values programmed into OUT[3:0] represent the output on VD[3:0]

| 7    |      | •    | 4    |       | 2     | 1     | 0     |
|------|------|------|------|-------|-------|-------|-------|
| IN_3 | IN_2 | IN_1 | IN_0 | OUT_3 | OUT_2 | OUT_1 | OUT_0 |
| 0    | 0    | 0    | 0    | 0     | 0     | 0     | 0     |

IN[3:0]

These input bits can be used to monitor external signals from VD[7:4]. The programmable I/O register is only accessible in the 8-Bit 4:2:2 YCrCb Output Mode (LEN = 0). When not in 8-Bit Output Mode, the values returned by the IN[3:0] bits are not valid.

OUT[3:0]

These output bits can be programmed to output miscellaneous additional signals from the video decoder on VD[3:0]. The Programmable I/O register is only accessible in the 8-bit 4:2:2 YCrCb Output Mode. When not in the 8-Bit output mode, the OUT[3:0] bits are set to logical 1.

0x3F—Programmable I/O Register (P\_IO)

VideoStream II Decoders

# 5.0 Parametric Information

# 5.1 DC Electrical Parameters

Table 5-1. Recommended Operating Conditions

| Parameter                                                 | Symbol           | Min  | Тур  | Max  | Units |
|-----------------------------------------------------------|------------------|------|------|------|-------|
| Power Supply — Analog                                     | V <sub>AA</sub>  | 4.75 | 5.00 | 5.25 | ٧     |
| Power Supply — 5.0 V Digital                              | V <sub>DD</sub>  | 4.75 | 5.00 | 5.25 | ٧     |
| Power Supply — 3.3 V Digital                              | V <sub>DDO</sub> | 3.00 | 3.3  | 3.6  | ٧     |
| Maximum Δ IV <sub>DD</sub> – V <sub>AA</sub> I            |                  |      |      | 0.5  | ٧     |
| MUX0, MUX1 and MUX2 Input Range<br>(AC coupling required) |                  | 0.5  | 1.00 | 2.00 | V     |
| VIN Amplitude Range (AC coupling required)                |                  | 0.5  | 1.00 | 2.00 | ٧     |
| Ambient Operating Temperature                             | T <sub>A</sub>   | 0    |      | +70  | °C    |

#### 5.1 DC Electrical Parameters

| Table 5-2. Absolute | Maximum Rating | js |
|---------------------|----------------|----|
|---------------------|----------------|----|

| Parameter                                      | Symbol            | Min        | Тур | Max                   | Units |
|------------------------------------------------|-------------------|------------|-----|-----------------------|-------|
| V <sub>AA</sub> (measured to AGND)             |                   |            |     | 7.00                  | ٧     |
| V <sub>DD</sub> (measured to DGND)             |                   |            |     | 7.00                  | ٧     |
| Voltage on any signal pin (See the note below) |                   | DGND - 0.5 |     | V <sub>DD</sub> + 0.5 | V     |
| Analog Input Voltage                           |                   | AGND - 0.5 |     | V <sub>AA</sub> + 0.5 | V     |
| Storage Temperature                            | T <sub>S</sub>    | -65        |     | +150                  | °C    |
| Junction Temperature                           | TJ                |            |     | +125                  | °C    |
| Vapor Phase Soldering<br>(15 Seconds)          | T <sub>VSOL</sub> |            |     | +220                  | °C    |

Note: Stresses above those listed may cause permanent damage to the device. This is a stress rating only, and functional operation at these or any other conditions above those listed in the operational section of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

This device employs high-impedance CMOS devices on all signal pins. It must be handled as an ESD-sensitive device. Voltage on any signal pin that exceeds the power supply voltage by more than +0.5 V, or drops below ground by more than 0.5 V, can induce destructive latch-up.

Table 5-3. DC Characteristics (3.3 V digital I/O operation)

| Parameter                                              | Symbol          | Min       | Тур | Max                    | Units |
|--------------------------------------------------------|-----------------|-----------|-----|------------------------|-------|
| Digital Inputs                                         |                 |           |     |                        |       |
| Input High Voltage (TTL)                               | V <sub>IH</sub> | 2.0       |     | V <sub>DDO</sub> + 0.5 | V     |
| Input Low Voltage (TTL)                                | V <sub>IL</sub> |           |     | 0.8                    | V     |
| Input High Voltage (XT0I, XT1I,)                       | V <sub>IH</sub> | 2.3       |     | V <sub>DDO</sub> + 0.5 | V     |
| Input Low Voltage (XT0I, XT1I,)                        | V <sub>IL</sub> | GND - 0.5 |     | 1.0                    | V     |
| Input High Current (V <sub>IN</sub> =V <sub>DD</sub> ) | I <sub>IH</sub> |           |     | 10                     | μΑ    |
| Input Low Current (V <sub>IN</sub> =GND)               | I <sub>IL</sub> |           |     | -10                    | μΑ    |
| Input Capacitance (f=1 MHz, V <sub>IN</sub> =2.4 V)    | C <sub>IN</sub> |           |     |                        | pF    |
| Input High Voltage (NUMXTAL, I2CCS)                    | V <sub>IH</sub> | 2.5       |     |                        | V     |
| Digital Outputs                                        |                 |           |     |                        |       |
| Output High Voltage (I <sub>OH</sub> = -400 μA)        | V <sub>OH</sub> | 2.4       |     | V <sub>DDO</sub>       | V     |
| Output Low Voltage (I <sub>OL</sub> = 3.2 mA)          | V <sub>OL</sub> |           |     | 0.4                    | V     |
| Three-State Current                                    | loz             |           |     | 10                     | μΑ    |
| Output Capacitance                                     | Co              |           | 5   |                        | pF    |
| Analog Pin Input Capacitance                           | C <sub>A</sub>  |           | 5   |                        | pF    |

5.1 DC Electrical Parameters

Table 5-4. DC Characteristics (5 V only operation)

| Parameter                                              | Symbol          | Min       | Тур | Max                   | Units |
|--------------------------------------------------------|-----------------|-----------|-----|-----------------------|-------|
| Digital Inputs                                         |                 |           |     |                       |       |
| Input High Voltage (TTL)                               | V <sub>IH</sub> | 2.0       |     | V <sub>DD</sub> + 0.5 | V     |
| Input Low Voltage (TTL)                                | V <sub>IL</sub> |           |     | 0.8                   | V     |
| Input High Voltage (XT0I, XT1I,)                       | V <sub>IH</sub> | 3.5       |     | V <sub>DD</sub> + 0.5 | V     |
| Input Low Voltage (XT0I, XT1I,)                        | V <sub>IL</sub> | GND - 0.5 |     | 1.5                   | V     |
| Input High Current (V <sub>IN</sub> =V <sub>DD</sub> ) | I <sub>IH</sub> |           |     | 10                    | μΑ    |
| Input Low Current (V <sub>IN</sub> =GND)               | I <sub>IL</sub> |           |     | -10                   | μΑ    |
| Input Capacitance (f=1 MHz, V <sub>IN</sub> =2.4 V)    | C <sub>IN</sub> |           | 5   |                       | pF    |
| Digital Outputs                                        |                 |           |     |                       |       |
| Output High Voltage ( $I_{OH} = -400 \mu A$ )          | V <sub>OH</sub> | 2.4       |     | $V_{DD}$              | V     |
| Output Low Voltage (I <sub>OL</sub> = 3.2 mA)          | V <sub>OL</sub> |           |     | 0.4                   | V     |
| Three-State Current                                    | loz             |           |     | 10                    | μΑ    |
| Output Capacitance                                     | co              |           | 5   |                       | pF    |
| Analog Pin Input Capacitance                           | C <sub>A</sub>  |           | 5   |                       | pF    |

# 5.2 AC Electrical Parameters

Table 5-5. Clock Timing Parameters (1 of 2)

| Parameter                           | Symbol          | Min  | Тур       | Max | Units |
|-------------------------------------|-----------------|------|-----------|-----|-------|
| NTSC:                               |                 |      |           |     |       |
| CLKx1 Rate                          | <sub>F</sub> S1 |      | 14.318180 |     | MHz   |
| CLKx2 Rate (50 PPM source required) | F <sub>S2</sub> |      | 28.636360 |     | MHz   |
| PAL/SECAM:                          |                 |      |           |     |       |
| CLKx1 Rate                          | <sub>F</sub> S1 |      | 17.734475 |     | MHz   |
| CLKx2 Rate (50 PPM source required) | F <sub>S2</sub> |      | 35.468950 |     | MHz   |
| XTO and XT1 Inputs                  |                 |      |           |     |       |
| Cycle Time                          | 1               | 28.2 |           |     | ns    |
| High Time                           | 2               | 12   |           |     | ns    |
| Low Time                            | 3               | 12   |           |     | ns    |

5.2 AC Electrical Parameters

Table 5-5. Clock Timing Parameters (2 of 2)

| Parameter                                  | Symbol | Min | Тур | Max                    | Units |
|--------------------------------------------|--------|-----|-----|------------------------|-------|
| CLKx1 Duty Cycle                           |        | 45  |     | 55                     | %     |
| CLKx2 Duty Cycle                           |        | 40  |     | 60                     | %     |
| CLKx2 to CLKx1 Delay                       | 4      | 0   |     | 2                      | ns    |
| CLKx1 to Data Delay                        | 5      | 3   |     | 11 (25) <sup>(2)</sup> | ns    |
| CLKx2 to Data Delay                        | 6      | 3   |     | 11 (25) (2)            | ns    |
| CLKx1 (Falling Edge) to QCLK (Rising Edge) | 41     | 0   |     | 8                      | ns    |
| CLKx2 (Falling Edge) to QCLK (Rising Edge) | 42     | 0   |     | 8                      | ns    |
| 8-Bit Mode <sup>(1)</sup>                  |        |     |     |                        |       |
| Data to QCLK (Rising Edge) Delay           | 7b     | 5   |     |                        | ns    |
| QCLK (Rising Edge) to Data Delay           | 8b     | 15  |     |                        | ns    |
| 16-Bit Mode <sup>(†)</sup>                 |        |     |     |                        |       |
| Data to QCLK (Rising Edge) Delay           | 7a     | 14  |     |                        | ns    |
| QCLK (Rising Edge) to Data Delay           | 8a     | 25  |     |                        | ns    |

Notes: (1). Because QCLK is generated with a gated version of CLKx1 or CLKx2, the timing in symbols 7 and 8 are subject to changes in the duty cycle of CLKx1 and CLKx2. If crystals are used as clock sources for the Bt829A, the duty cycle is symmetric. This assumption is used to generate the timing numbers shown in 7 and 8. For non-symmetric clock sources, use the following equations:

| Data to QCLK (setup) 16-bit mode             | xtal period + CLKx1 to qclk (max) - CLKx1 to data (max) or symbol 1 + symbol 41 (max) - symbol 5 (max) |
|----------------------------------------------|--------------------------------------------------------------------------------------------------------|
|                                              | NTSC: 34.9 nS + 8 nS - 11 nS = 31.9 nS<br>PAL: 28.2 nS + 8 nS -11 nS = 25.2 nS                         |
| QCLK to Data (hold) 16-bit mode              | xtal period - CLKx1 to qclk (min) + CLKx1 to data (min) or                                             |
|                                              | symbol 1 - symbol 41 (min) + symbol 5 (min)                                                            |
|                                              | NTSC: 34.9 nS - 0 nS + 3 nS = 37.9 nS<br>PAL: 28.3 nS - 0 nS + 3 nS = 31.3 nS                          |
| Data to QCLK (setup) 8-bit mode              | (xtal period)/2 + CLKx2 to qclk (max) - CLKx2 to data (max) or                                         |
|                                              | (symbol 1)/2 + symbol 42 (max) - symbol 6 (max)                                                        |
|                                              | NTSC: 17.5 nS + 8nS - 11 nS = 14.5 nS<br>PAL: 14.1 nS + 8 nS - 11 nS = 11.1 nS                         |
| QCLK to data (hold) 8-bit mode               | (xtal period)/2 - CLKx2 to qclk (min) + CLKx2 to data (min) or                                         |
|                                              | (symbol 1)/2 - symbol 42 (min) + symbol 6 (min)                                                        |
|                                              | NTSC: 17.5 nS - 0 nS + 3 nS = 20.5 nS<br>PAL: 14.1 nS - 0 nS + 3 nS = 17.1 nS                          |
| (2). Parenthesis indicate max CLKx1/CLKx2 to | Data Delay when using V <sub>DDO</sub> = 3.3 V.                                                        |

#### 5.2 AC Electrical Parameters

VideoStream II Decoders

Figure 5-1. Clock Timing Diagram



Table 5-6. Power Supply Current Parameters (3 and 5 V operation)

| Parameter                                                                                                                                                                                                                      | Symbol | Min | Тур       | Max        | Units                    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----|-----------|------------|--------------------------|
| Supply Current $V_{AA}=V_{DD}=5.0V,\ F_{CLKx2}=28.64\ MHz,\ T=25^{\circ}C$ $V_{AA}=V_{DD}=5.25V,\ F_{CLKx2}=35.47\ MHz,\ T=70^{\circ}C$ $V_{AA}=V_{DD}=5.25V,\ F_{CLKx2}=35.47\ MHz,\ T=0^{\circ}C$ Supply Current, Power Down | I      |     | 170<br>65 | 250<br>280 | m A<br>m A<br>m A<br>m A |

Table 5-7. Output Enable Timing Parameters

| Parameter                                                                                  | Symbol        | Min | Тур | Max        | Units          |
|--------------------------------------------------------------------------------------------|---------------|-----|-----|------------|----------------|
| OE Asserted to Data Bus Driven OE Asserted to Data Valid OE Negated to Data Bus Not Driven | 9<br>10<br>11 | 0   |     | 100<br>100 | nS<br>nS<br>nS |
| RST Low Time                                                                               |               | 8   |     |            | XTAL cycles    |

5.2 AC Electrical Parameters

Figure 5-2. Output Enable Timing Diagram



Table 5-8. JTAG Timing Parameters

| Parameter                       | Symbol | Min | Тур | Max | Units |
|---------------------------------|--------|-----|-----|-----|-------|
| TMS, TDI Setup Time             | 12     |     | 10  |     | ns    |
| TMS, TDI Hold Time              | 13     |     | 10  |     | ns    |
| TCK Asserted to TDO Valid       | 14     |     | 60  |     | ns    |
| TCK Asserted to TDO Driven      | 15     |     | 5   |     | ns    |
| TCK Negated to TDO Three-stated | 16     |     | 80  |     | ns    |
| TCK Low Time                    | 17     | 25  |     |     | ns    |
| TCK High TIme                   | 18     | 25  |     |     | ns    |

Figure 5-3. JTAG Timing Diagram



Table 5-9. Decoder Performance Parameters

| Parameter             | Symbol | Min  | Тур | Max | Units            |
|-----------------------|--------|------|-----|-----|------------------|
| Horizontal Lock Range |        |      |     | ±7  | % of Line Length |
| Fsc, Lock-in Range    |        | ±800 |     |     | Hz               |
| Gain Range            |        | -6   |     | 6   | dB               |

Note: Test conditions (unless otherwise specified): "Recommended Operating Conditions." TTL input values are 0–3 V, with input rise/fall times ≤ 3 ns, measured between the 10% and 90% points. Timing reference points at 50% for digital inputs and outputs. Pixel and control data loads ≤ 30 pF and ≥10 pF. CLKx1 and CLKx2 loads ≤ 50 pF. Control data includes CBFLAG, DVALID, ACTIVE, VACTIVE, HRESET, VRESET and FIELD.

# 5.3 Package Mechanical Drawings

Figure 5-4. 100-Pin PQFP Package Mechanical Drawing



5.4 Revision History

# 5.4 Revision History

Table 5-10. Bt829B Datasheet Revision History

| Revision |          | Description         |
|----------|----------|---------------------|
| А        | 03/27/98 | Engineering Release |