## MC92314 ## DVB-T Single Chip Demodulator Application Note Authors Christoph Patzelt (Motorola), Adrian Turner (NDS) (Single Chip DVB-T Demodulator) Rev. 1.3 Date: November 30, 1998 3:37 pm Motorola reserves the right to make changes without further notice to any products herein. Motorola makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Motorola assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters which may be provided in Motorola data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Motorola does not convey any license under its patent rights nor the rights of others. Motorola products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Motorola was negligent regarding the design or manufacture of the part. Motorola and (A) are registered trademarks of Motorola, Inc. Motorola, Inc. is an Equal Opportunity/Affirmative Action Employer. Rev. 1.3 Revision Status: Version 1.2 Finalised. #### **Summary of Changes or Updates:** • Significant reduction in external intervention. #### **Rev. 1.1:** Changes to VCXO LPF included. #### **Rev. 1.2:** - Added CSE register to OFDM block register map. - Added AGC Fix and VCXO Fix descriptions. #### Rev. 1.3: - Included performance values and power consumption values. - Included suggestions to speed up acquisition (AFC Sweep Start, fixing FEC coderate). - Added Timing Diagram - Added BGA package information - Added VCXO tolerance requirement **Trademarks:** Single Chip DVB-T Demodulator | | | - 4 | • | | | 4 | |---|----|-----|---|---|---|---| | S | Δ, | ~1 | 1 | n | n | 7 | | • | 5 | U | | u | | | | $\sim$ | 10 | | • | ,_, | - 1 | IFW | |--------|----------|------|---|-----|-----|------| | ~ 1 | <i>,</i> | <br> | | | | _ \^ | | | | | | | | | | 1.1 Conoral Description | 1 1 | |------------------------------------------------------------------------|-----| | 1.1 General Description | | | 1.2 Considerations on Terrestrial Transmission | | | 1.2.1 Echoes on the Transmission Path | | | 1.2.2 Noise | | | 1.3 Advantages of the OFDM Transmission Scheme | | | 1.4 Overview of the DVB-T System | 1-4 | | Overview of the DVB-T System 1.4.1 Modulation Scheme | 1-4 | | 1.4.2 OFDM Block | 1-6 | | 1.4.3 FFT Block | 1-6 | | 1.4.2 OFDM Block | 1-6 | | 1.4.4.1 Viterbi Decoder | 1-6 | | 1.4.4.2 Convolutional Deinterleaver | 1-7 | | 1.4.4.3 Reed-Solomon Decoder | 1-7 | | 1.4.4.4 Energy Dispersal Removal (Descrambling) | 1-7 | | 1.5 References | 1-8 | | | | | Section 2 | | | | | | PINOUT & SIGNAL DESCRIPTION OF THE MC92314 | | | 2.1 Pirout for the 160PQFP Package | 2-2 | | 2.2 Pinout for the 169BGA Package | | | 2.3 Pin Description of the Single Chip DVB-T Demodulator MC92314 | | | 2.0 Thr bescription of the origin of the by by by bernoutlated western | Z ¬ | | | | | Section 3 | | | DEVICE DESCRIPTION | | | 3.1 Complete DVB-T Digital Frontend | 3-1 | | 3.2 Component Descriptions | | | 3.2.1 2K-FFT Processor Block | | | 3.2.2 2K-OFDM Demodulator Block | | | 3.2.2.1 I/Q-Demodulator | | | J.Z.Z. I I/Q-DGINOGUIATOI | 5-3 | | 3.2.2.2 | Derotator | 3-3 | |----------------|-------------------------------------------------------------|------| | 3.2.2.3 | Time Synchronisation | 3-3 | | 3.2.2.4 | Channel Estimation | 3-4 | | 3.2.2.5 | Channel Estimation RAM | 3-4 | | 3.2.2.6 | Channel Correction | 3-4 | | 3.2.2.7 | Channel State Estimation | 3-4 | | 3.2.2.8 | Inner Deinterleaver | 3-5 | | 3.2.2.9 | Symbol Demapper and Bit Deinterleaver | 3-5 | | 3.2.2.10 | Data Formatter | 3-5 | | | Block | | | 3.2.3.1 | Node Synchroniser | 3-6 | | 3 2 3 2 | Viterbi Error Correction | 2-12 | | 3.2.3.3 | Frame Synchronisation | 3-18 | | 3.2.3.4 | Frame Synchronisation. Deinterleaver Reed-Solomon Decoder | 3-23 | | 3.2.3.5 | Reed-Solomon Decoder | 3-24 | | 3.2.3.6 | Descrambler | 3-28 | | DVB-T DEMODULA | ATOR INTERFACES | | | 4.1 General F | Purpose Outputs | 4-1 | | 4.2 I2C Interf | ace | 4-1 | | 4.2.1 I2C F | unctionality | 4-2 | | 4.2.1.1 | Start Condition | 4-2 | | 4.2(1.2 | Stop Condition | 4-3 | | 4.2.1.3 | Transmitting "1" and "0" | 4-3 | | 4.2.1.4 | Data Transfer Sequence | 4-3 | | 4.2.1.5 | Accessing Registers via I2C | 4-4 | | 4.2.1.6 | I2C Interface of the MC92314 | 4-5 | | 4.2.2 I2C R | egister Maps of the MC92314 | 4-7 | | 4.2.2.1 | Register Map for the OFDM Part | 4-8 | | 4.2.2.2 | Register Map for the FEC Part | 4-17 | | | erface | | | 4.3.1 Gener | ral Tuner Characteristics | 4-25 | | 4.3.2 Clock | Signals | 4-26 | | 4.3.3 Input | from the Tuner Analog-to-Digital Converter | 4-27 | | 4.3.4 Tuner Control signals from the MC92314 | 4-27 | |------------------------------------------------------------------------------------------------------------------------------------|------| | 4.3.4.1 VCXO Control Loop | | | 4.3.4.2 AGC Control Loop | 4-28 | | 4.4 MPEG-2 Output Interface of the MC92314 | 4-28 | | 4.5 References | 4-29 | | | | | Section 5 | | | USAGE AND PERFORMANCE OF MOTOROLA'S SINGLE-CHIP DVB-T DEV | ICE | | 5.1 Remarks on the Circuit Diagram | 5-1 | | 5.2 Initialising the Chipset | 5-1 | | <ul><li>5.1 Remarks on the Circuit Diagram.</li><li>5.2 Initialising the Chipset.</li><li>5.2.1 Setup of the OFDM Block.</li></ul> | 5-2 | | 5.2.1.1 Registers of the OFDM Block | 5-2 | | 5.2.1.1 Registers of the OFDM Block | 5-2 | | 5.3.1 Status Information of the OFDM Block | | | 5.3.1.1 Hardware pins | 5-2 | | 5.3.1.2 Lock Status Registers | | | 5.3.1.3 Usage of the AGO Feedback Register | 5-3 | | 5.3.2 Status Information of the FEC Block | 5-3 | | 5.3.2.1 Hardware Rins | 5-3 | | 5.3.2.2 Software Registers | 5-3 | | 5.3.2.3 FEC Block QVAL Values corresponding to BER values | 5-3 | | 5.4 Performance Considerations | 5-4 | | 5.4.1 Possible Changes in the OFDM Block | 5-4 | | 5.4.1.1 Speeding up the Acquisition Time | 5-4 | | \$4.1.2 Co-Channel Protection vs. Noise | 5-6 | | 5.4.2 Possible Changes in the FEC Block | 5-6 | | 5.4.2.1 Fixing the Coderate for the Viterbi Decoder | 5-6 | | 5.4.2.2 Adjusting the MPEG Frame Synchroniser | 5-6 | | 5.5 MC92314 Performance | 5-7 | | 5.5.1 Performance in a typical Consumer Application | 5-7 | | 5.5.1.1 Typical Lock Performance | 5-7 | | 5.5.1.2 Noise and Interference Performance | 5-9 | | 5.6 References | 5-10 | | Section 6 | | |--------------------------------------------------|-----| | | | | ELECTRICAL CHARACTERISTICS | | | 6.1 MC92314 Electrical Considerations | | | 6.2 MC92314 DC Electrical Specifications | | | 6.3 MC92314 Timing Characteristics | 6-4 | | Section 7 | | | MECHANICAL CHARACTERISTICS | | | 7.1 Outlines of the 160PQFP Package | 7-1 | | 7.2 Outlines of the 169BGA Package | 7-3 | | Chust | | | and Internal | | | iminary | | | diffe | | | | | | <b>√ √</b> • • • • • • • • • • • • • • • • • • • | | ## SECTION 1 SYSTEM OVERVIEW In this Application Note Motorola's single chip demodulator and FEC for DVB-T receivers along with the usual application is described. This section covers the overall descriptions as well as an introduction into the DVB-T standard, supporting the understanding of the special features of the OFDM system. #### 1.1 General Description Before describing the important specialities of the DVB-T system itself the key features of Motorola's single chip are outlined. - 0.35mm CMOS process at 3.3 V. - 160 pin QFP package - 169 BGA package There are two main sections in the chip, providing the functions necessary to obtain a complete MPEG-2 transport stream out of one real IF-sampled DVB-T signal. The steps necessary are **OFDM demodulation** and **FEC decoding**, corresponding to the three separate devices described in Reference [1-4]: Important capabilities of the FFT/OFDM block: - Usable for 8 MHz, 7 MHz and 6 MHz channel bandwidth by adjusting the clock rate. - C/N performance according to Reference [1-1] Annex A with a degradation margin of 3 dB. - Supported DVB-T modulation schemes: QPSK, 16-QAM and 64-QAM. - Automatic lock onto all specified guard interval lengths ( $^{1}/_{32}$ , $^{1}/_{16}$ , $^{1}/_{8}$ , $^{1}/_{4}$ ). - Data input: 8 Bit TTL compatible 2's complement or offset binary. - Channel estimation and correction using the pilot carriers. - I<sup>2</sup>C compatible interface (M-Bus). - Transmission Parameter Signalling (TPS) data is decoded and made available to the system controller via M-Bus. - Processing of one block of 2048 complex samples (i.e. one 2K-OFDM symbol) in 224 ms. - FFT input wordlength 8 bit, output accuracy 12 bit. - Overflow on certain OFDM subcarriers due to co-channel interferes is prevented internally. Key items of the **FEC** part include: - Maximum 37 Mbit/s output rate. - 3 Bit soft-decision input matched to the output of the OFDM block. - Code rate $\frac{1}{2}$ and depunctured rates of $\frac{2}{3}$ , $\frac{3}{4}$ , $\frac{5}{6}$ , and $\frac{7}{8}$ . - · Automatic or manual rate selection. - Viterbi decoder survivor depth 96 - Signal quality output data. - DVB compliant 12 x 17 Forney Convolutional Deinterleaver - Reed-Solomon (204, 188, 8) decoder as specified by DVB - DVB Descrambler for Energy Dispersal & inverted Sync Byte removal - Bit Error Rate (BER) and uncorrectable Frame Error (BAD) monitoring - setting of "transport\_error\_indicator" bit in the MPEG2 output stream (MSB of first byte immediately following the Sync Byte) #### 1.2 Considerations on Terrestrial Transmission One of the most important aspects in designing a transmission system is to chose the modulation scheme that fits best to the characteristics of the transmission channel employed. Comparing the terrestrial channel in the UHF band with the channels of the satellite or cable system yields several important differences that exclude the modulation schemes used there from an efficient usage in the terrestrial channel. #### 1.2.1 Echoes on the Transmission Path In Figure 1-1 a typical environment for terrestrial reception is given. The antenna of the stationary receiver receives the signal belonging to the direct path from the transmitter as well as delayed echoes e.g. from buildings (this is called a Ricean channel). In contrast to this a portable receiver may receive only echoes without a signal direct from the transmitter (Rayleigh channel characteristics). Figure 1-1. Possible echo constellation In the well known analog TV transmission systems such echoes appear as ghost pictures on the screen, but as long as they don't get too strong the original information remains visible, at the penalty of reduced picture quality. #### 1.2.2 **Noise** Another impairment on every transmission channel is the addition of noise. Due to many reasons (e.g. thermal noise, impulse noise from ignition sources) the signal quality degrades with increasing distance from the transmitter. On the analog TV picture the different noise sources decrease the quality of the picture, but as long as the synchronisation circuitry remains in lock even heavily distorted pictures deliver visible information to the viewers. ### 1.3 Advantages of the OFDM Transmission Scheme In contrast to this the behaviour of analog systems outlined in the paragraphs above the behaviour of digital transmission systems is different. The picture contents are mapped into digital signals, transmission impairments lead to transmission errors, resulting in bit errors of the received datastream. Due to the high compression ration of the source encoded MPEG-2 transport stream used in the DVB systems even single bit errors may have a severe impact on the picture quality. Without careful system layout, taking into account the characteristics of the transmission channel, the performance of a digital transmission system may be very poor. The problems mentioned above can be circumvented successfully leading to the present system for digital terrestrial transmission. One of the main points is the Orthogonal Frequency Division Multiplex (OFDM) scheme. The following list gives a short overview about the key features of the DVB-T standard: - Divide the whole available bandwidth into a large number of subchannels with different frequencies (Frequency Division Multiplex). - each subchannel is independent form all others (Orthogonality). - To combat the echoes in the terrestrial channel a guard interval is used to absorb them. - A certain amount of redundancy is added to the bits at the transmitter side, allowing powerful error correction techniques in the receiver. In principle the whole available bandwidth is divided into a large number N (e.g. 2048) of separate narrowband subchannels (the OFDM subcarriers). Data transmission on each subcarrier frequency is independent from and in parallel with the other subcarriers, leading to a very low datarate on each subcarrier compared to the overall transmission capacity. The splitting into the subchannels including the modulation onto the subcarriers can be done very efficiently by performing an Inverse Fast Fourier Transform (FFT) to the data to be transmitted. In turn the receiver must do a FFT to obtain the original information. Following the usual terms of digital signal processing the region before the IFFT in the transmitter and after the FFT in the receiver is called 'frequency domain' and in contrast to it the signal after the IFFT (in the transmitter) until before the FFT (in the receiver) is associated with the time domain'. All these steps together allow the realisation of a robust transmission scheme specially adapted to the terrestrial channel. Advances in silicon technology enable the implementation of the advanced signal processing algorithms necessary at costs suitable to the consumer electronics industry. Additional information on the OFDM system can be obtained from Reference [1-2] and Reference [1-3]. ## 1.4 Overview of the DVB-T System After thorough investigation of the requirements the standard for digital terrestrial television was finalised in 1996 (see Reference [1-1]). In line with the standards for the satellite system (DVB-S) and the cable system (DVB-C) it specifies all the transmission parameters for the broadcasting of services via terrestrial (e.g. UHF) channels. #### 1.4.1 Modulation Scheme The standard covers the Orthogonal Frequency Division Multiplex (OFDM) scheme, using OFDM symbol lengths of either 2048 (2K) or 8192 (8K) complex-valued samples. The integrated circuit covered in this document can deal only with the 2K-system, so the 8K system is not covered here. Figure 1-2 gives a block diagram of the complete DVB-T transmission system, the blocks marked with thick lines are unique to the terrestrial system, whereas the other blocks are identical to the satellite standard DVB-S. In this diagram also the basic parameters of the transmission parameters are given, for a more detailed description see Reference [1-1] MOTOROLA #### 1.4.2 OFDM Block The OFMD block performs the functions given in the blocks 'Synchronisation', 'Demapping' and 'Inner Deinterleaving' in Figure 1-2. This includes all the necessary synchronisation tasks, OFDM-related deinterleaving, demapping of the constellation diagram, generation of soft-decision information and output formatting. This block is designed to work directly with the FFT block. Important capabilities are: - Usable for 8 MHz, 7 MHz and 6 MHz channel bandwidth by adjusting the clock rate. - C/N performance according to Reference [1-1] Annex A with a degradation margin of 3 dB. - Supported DVB-T modulation schemes: QPSK, 16-QAM and 64-QAM. - Automatic lock on all specified guard interval lengths (<sup>1</sup>/<sub>32</sub>C<sup>1</sup>/<sub>16</sub>, <sup>1</sup>/<sub>8</sub>, <sup>1</sup>/<sub>4</sub>). - Data input: 8 Bit TTL compatible 2's complement or offset binary. - Channel estimation and correction using the pilot carriers. - I<sup>2</sup>C compatible interface (M-Bus) to the system controller. - Transmission Parameter Signalling (TPS) data is decoded and made available to the system controller via M-Bus. #### 1.4.3 FFT Block The FFT block performs the OFDM demodulation in the true sense of the word. It gets the time domain information from the OFDM block, performs a Fast Fourier Transform on it and delivers the frequency domain information, i.e. the constellation diagram (suffering from the channel impairments) back again to the OFDM block. Main features of the FFT block are: - Processing of one block of 2048 complex samples (i.e. one 2K-OFDM symbol) in 224 μs. - FFT input wordlength 8 bit, output accuracy selectable between 10 and 12 bit. - Overflow on certain OFDM subcarriers due to co-channel interferes is handled internally. #### 1.4.4 Forward Error Correction Block The FEC part of the DVB-T transmission is located in the blocks 'FEC-Decoding', 'Deinterleaving', 'Sync-Inversion' and Descrambling. All these tasks are handled by the FEC block. The FEC scheme itself consist of the inner Viterbi decoder and the outer RS decoder. #### 1.4.4.1 Viterbi Decoder The Viterbi decoder block is DVB compliant with all the coderates available according to the specification. Its main features are: - Maximum 37 Mbit/s output rate. - Constraint length 7, generator polynomial (171<sub>8</sub>, 133<sub>8</sub>) - 3 Bit soft-decision input in suited to the output of the OFDM block. - Code rate $\frac{1}{2}$ and depunctured rates of $\frac{2}{3}$ , $\frac{3}{4}$ , $\frac{5}{6}$ , and $\frac{7}{8}$ . - · Automatic or manual rate selection. - Programmable internal synchronizer. - Provision for external synchronization. - Survivor depth 96 - No internal APLL needed, clock is provided by the OFDM block. - · Signal quality output data. #### 1.4.4.2 Convolutional Deinterleaver To achieve the optimal performance of any concatenated coding scheme there must be an interleaver in the transmitter between the inner and outer encoder. This interleaver distributes the bytes in a pseudo random order before feeding them into the inner encoder. In turn the deinterleaver in the receiver rearranges the original order, spreading error bursts provoked by overloading the inner decoder due to bad channel conditions. In case of the DVB system the interleaving scheme uses a Convolutional 12x17 Forney Interleaver: Every 204 bytes of data are interleaved (reordered) at the transmitter and deinterleaved in the receiver using a Convolutional Deinterleaver with I=12 branches and M=17 byte storage cells as defined by the DVB Specifications. #### 1.4.4.3 Reed-Solomon Decoder The FEC block contains a complete Reed-Solomon decoder as specified by DVB for digital receiver applications (204, 188) of GF(256), that means input blocks with 188 byte in length, added redundancy of 16 checkbytes leading to 204 bytes output block length. The block will accept data from the Viterbi decoder and deliver an MPEG-2 transport stream to the Set-Top Box core demultiplexer. #### 1.4.4.4 Energy Dispersal Removal (Descrambling) The MPEG-2 data (excluding Sync Bytes) are randomised for Energy Dispersal in the transmitter. This block reverses the process and re-inverts the inverted Sync Byte prior to delivering the data to the MPEG-2 Transport Demultiplexer. It is the last step in the frontend processing chain. The main features of the deinterleaver, RS decoder and descrambling block are given below: - 37 MBit/s typical input and output data rates - optimized Frame Synchronizer performance for DVB parameters - DVB compliant 12x17 Forney Deinterleaver - Reed-Solomon (204,188,8) decoder as specified by DVB - DVB Descrambler for Energy Dispersal & inverted Sync Byte removal - setting of "transport\_error\_indicator" bit in the MPEG2 output stream (MSB of first byte immediately following the Sync Byte) - Bit Error Rate (BER) and uncorrectable Frame Error (BAD) monitoring - 180° input data stream phase error correction #### 1.5 References - [1-1] ETSI (European Telecommunication Standards Institute): Digital broadcasting systems for television, sound and data services; Framing structure, channel coding and modulation for digital terrestrial television. Draft prETS 300 744, September 1996. - [1-2] M. Alard, R. Lassalle: Principles of modulation and channel coding for digital broadcasting for mobile receivers. EBU Collected Papers on concepts for sound broadcasting into the 21st century, August 19988, pp. 47-69. - [1-3] J. Gledhill, S. Anikhindi, P. Avon: The transmission of digital television in the UHF band using Orthogonal Frequency Division Multiplex. Proceedings of the 6th International IEE Conference on Digital Processing of Signals in Communications, IEEE Conf. Publ. No. 340, pp. 175-180, September 1991. - [1-4] C. Patzelt, M. Drozd, S. Anikhindi: MC92307 MC92308 MC92309 DVB-T, Chipset Application Note Version 1.1; Motorola; July 1998. # SECTION 2 PINOUT & SIGNAL DESCRIPTION OF THE MC92314 Motorola's DVB-T demodulator is available in a 160QFP package as well as in a 169BGA. The pinout of this packages as well as the input and output lines are given in Figure 2-1, Figure 2-2 and Table 2-1. The mechanical dimensions of the package are given in Section 7. The supply voltage of the IC is 3.3 V, its power consumption is app. 1.7 W in a typical DVB-T application as it is described Section 5. Preliminary mormation #### 2.1 Pinout for the 160PQFP Package Figure 2-1. Pinout for the 160PQFP ## 2.2 Pinout for the 169BGA Package View from top, x-ray through package. 7 2 3 4 5 8 9 **10** 11 12 13 ADCDATA3ADCDATA4 ADCDATA5ADCDATA6ADCDATA7 CLKEN18 AGCCTLP AGCCTLN CLKCTLP (VSS) (VSS) (VSS) (VSS) В ADCDATA2 (VSS) (VSS) (VSS) (VSS) (VSS) (VSS) OPEN8 (VSS) (VSS) (VSS) (VSS) (VSS) X $\mathbf{C}$ (VSS) (VSS) X (VSS) VDD (VSS) VDD X OPEN9 VDD (VSS) (VSS) D ADCDATA1 (VSS) (VSS) **VDD VDD** VDD CLKCTLN MSCL (VSS) **GND VDD VDD GND** $\mathbf{E}$ ADCDATA0 (VSS) X (VSS) VDD **GND GND GND GND GND** VDD MSDA F (VSS) INSYNC VDD VDD **GND GND GND GND GND** VDD VDD (VSS) CLK **TPSLOCK** G **VLOCK** (OPEN) **GND GND GND** GND **GND GND** GND (VSS) (VSS) (VSS) Η (OPEN) VDD **GND GND** GND VDD VDD MBUSID0 (VSS) AFCLOCK RESB X **GND GND GND** GND **GND GND** VDD (VSS) MBUSID1 (VSS) J CLKLOCK VDD VDD K TRERROR (OPEN) (OPEN) **VDD** VDD **VDD** GND (OPEN) MBUSID2 (OPEN) GP2 $\mathbf{L}$ (OPEN) (OPEN) VDD (OPEN) X **VDD VDD** X (OPEN) X (OPEN) MBUSID3 GP1 GP3 (OPEN) (OPEN) (OPEN) (OPEN) (OPEN) (OPEN) (OPEN) TRDOUT0 TRSTART (OPEN) (OPEN) M GP0 TRDOUT6 TRDOUT5 TRDOUT4 TRDOUT3 TRDOUT2 TRDOUT1 N (OPEN) **TRVALID TRCLK** TRDOUT7 (OPEN) (OPEN) Figure 2-2. Pinout for the 169BGA #### 2.3 Pin Description of the Single Chip DVB-T Demodulator MC92314 The description of the MC92314 pinout is given in the table below: Table 2-1. MC92314 Pin List | SIGNAL | PIN-NR. | FUNCTIONALITY | TYPE | ACTIVE | |----------------|---------------------------------------------|---------------------------------------------------------------|-------------------|--------| | CLK | 61 | Common clock input (36.57 MHz) | TTL - IN | high | | RESB | 135 | Reset (asynchronous) | TTL - IN | low | | CLKEN18 | 33 | ADC data strobe | TTL - IN | high | | ADCDATA[7:0] | 21, 16, 11,<br>6, 1, 160,<br>155, 150 | ADC input | TTL - IN | high | | ADCDATA[-1:-2] | 147, 145 | 10-Bit extension for future 8K device | reserved<br>(VSS) | N/A | | CLKCTLP | 41 | ADC clock control (+) | TTL - OUT | high | | CLKCTLN | 46 | ADC clock control (-) | TTL - OUT | low | | AGCCTLP | 36 | Analogue AGC control (+) | TTL - OUT | high | | AGCCTLN | 40 | Analogue AGC control (-) | TTL - OUT | low | | MSDA | 56 | I <sup>2</sup> C compatible control bus, data pin | TTL - OD | N/A | | MSCL | 51 | I <sup>2</sup> C compatible control bus, clock pin | TTL - IN | high | | MBUSID[3:0]] | 80, 76, 71,<br>66 | I <sup>2</sup> C compatible control bus, variable ID selector | TTL - IN | high | | GP[3:0] | 104, 102,<br>99, 97 | General Purpose Output pins | TTL - OUT | high | | TRERROR | 130 | MPEG-2 Frame Error Indicator | TTL - OUT | high | | TRVALID | 121 | MPEG-2 Byte Valid Indicator | TTL - OUT | high | | TRSTART | 125 | MPEG-2 Sync Byte Indicator | TTL - OUT | high | | TRCLK | 120 | MPEG-2 Byte Clock | TTL - OUT | high | | TRDOUT[7:0] | 115, 110,<br>105, 100,<br>95, 90, 85,<br>81 | MPEG-2 Transport Stream Byte Output | TTL - OUT | high | | INSYNC | 143 | FEC Frame Synchronization Status | TTL - OUT | high | | VLOCK | 142 | Viterbi Decoder Synchronization Status | TTL - OUT | high | | TPSLOCKB | 141 | TPS Data Valid indicator (inverted) | TTL - OUT | low | | AFCLCK | 139 | AFC status indicator | TTL - OUT | high | | CLKLCK | 138 | Time Synchronization state indicator | TTL - OUT | high | #### **NOTE** The pins marked with (VSS) in the BGA pinout must be tied to $V_{SS}$ . As they are reserved pins they need not to be connected directly to $V_{SS}$ , instead of a pulldown resistor of about 10 K is sufficient. Similar the pins '(OPEN)' must be left unconnected. # SECTION 3 DEVICE DESCRIPTION In this section the chipset as a whole as well as the operation of the several components are described. #### 3.1 Complete DVB-T Digital Frontend Motorola's terrestrial chipset builds a complete digital frontend for the DVB-T system, it performs according to the following functional diagram: Figure 3-1. Block Diagram of a complete DVB-T Frontend Whereas Motorola's chipset covers all the digital functions required by the standard, the analog parts (RF amplification, RF filtering, downconversion, AGC, clock generation and AD-conversion) are located in the DVB-T tuner. The RF signal obtained by the antenna has to be fed into the tuner core, given that the C/N of the signal is high enough for the demodulation the receiver frontend will lock onto it and produce the transmitted transport stream ready to deliver it to the MPEG-2 demultiplexer. ### 3.2 Component Descriptions After giving the overall functions of the complete digital frontend in the last paragraph we go into more detail of the individual components: #### 3.2.1 2K-FFT Processor Block Integrated into the MC92314 is a pipelined Fast Fourier Transformation (FFT) processor with a blocklength of 2048 complex samples. It is especially designed for use in digital terrestrial Set- Top boxes according to the DVB-T standard for 2K transmission. One block of 2048 complex samples can be processed in 224 µs Figure 3-2. Block Diagram of the FFT Processor #### 3.2.2 2K-OFDM Demodulator Block The MC92314 contains also a Demodulator for the Orthogonal Frequency Division Multiplex transmission scheme according to the 2K-mode of the ETSI specification for digital terrestrial transmission (see reference [1-1]). Together with the 2K FFT block described in the previous paragraph it includes all the functions required to demodulate the information transmitted in one single UHF channel. In Figure 3-3 the block diagram of the OFDM block is given, followed by the description of the functional blocks. Figure 3-3. OFDM Demodulator Part of the MC92314 #### 3.2.2.1 I/Q-Demodulator In this first stage the complex samples are reconstructed from the (real valued) input stream by means of a discrete Hilbert transformer. The input stream is fed into the Hilbert transformer and delayed appropriately to calculate the real and imaginary parts of the signal. #### 3.2.2.2 Derotator Carrier frequency offsets resulting from local oscillator offsets in the tuner are removed digitally by means of a NCO and a phase accumulator, that are controlled by the <u>Au</u>tomatic <u>F</u>requency <u>C</u>ontrol (AFC). During the acquisition phase (when locking onto a DVB-T transmission) the AFC circuit sweeps permanently through the available range until the correct frequency offset has been detected. During the tracking phase the control signal for the phase increment is derived from the pilot carriers in the frequency domain. #### 3.2.2.3 Time Synchronisation The Time Synchronisation (separated in the coarse synchronisation valid during the acquisition phase and the fine synchronisation for tracking purposes) sets the FFT window position for the real OFDM demodulation and controls the clocking of the whole chip. In the tracking mode the time synchronisation generates the VCXO control signal using the filter structure given in Figure 3-4 below. The contribution of the proportional branch and of the integrator branch can be adjusted separately using the Clock Loop Filter Coefficients (see also paragraph 4.2.2.1.5). The gain of the proportional part is set using Bits [7:4] and the gain of the integrator part is adjusted with Bits [3:0]. Figure 3-4. Time Synchronisation of the OFDM Block #### 3.2.2.4 Channel Estimation To compensate for the impairments of the terrestrial channel it is essential to estimate the channel transfer function. This estimation is done using the scattered and continual pilot carriers. As the scattered pilots change in subsequent OFDM symbols a <u>time interpolation</u> over 4 OFDM symbols is necessary to build a complete set of pilot information. This set contains one valid pilot sample at every 3rd carrier position. To obtain a channel estimation value so the set ends up with an estimation value for each carrier position, <u>frequency interpolation</u> must be performed. #### 3.2.2.5 Channel Estimation RAM The channel estimation RAM must store the data carriers until the channel estimation is available for a given OFDM symbol. #### 3.2.2.6 Channel Correction In the channel correction block the estimate of the channel transfer function is used to compensate the influence of the terrestrial transmission. In principle each data carrier's value is multiplied with the inverse of the estimate to approximate the desired flat overall frequency response to as close as possible. #### 3.2.2.7 Channel State Estimation To improve the efficiency of the decoding of the inner convolutional code, information about the reliability of each bit received via the transmission channel, is generated during the demodulation process. So data that were transmitted in subchannels disturbed heavily due to echoes or interference (resulting in a low SNR in these specific subchannels) are marked less reliable than those transmitted in nearly undisturbed subchannels. In the channel state estimation this reliability information is generated for each carrier individually and passed together with the subcarriers data to the following stage. #### 3.2.2.8 Inner Deinterleaver Due to the echoes on the transmission path it is obvious that adjacent subcarriers are disturbed in a similar way: the used bandwidth of 7.61 MHz corresponds to 1705 active carriers, so the difference in the channel transfer function from one carrier to the adjacent carrier is limited. In case of a simple parallel to serial conversion adjacent bits of data would suffer from similar distortions. In this case the Viterbi decoder cannot work with its optimal performance. Instead the best performance is given if the disturbance applied to adjacent data bits is uncorrelated. To achieve this the data of all the relevant subcarriers are interleaved in the transmitter according to par. 4.3.4 in reference [1-1]. This interleaving has to be reversed prior to the demodulation. #### 3.2.2.9 Symbol Demapper and Bit Deinterleaver The modulated (complex valued) frequency domain samples are demapped into 2, 4 or 6 streams depending on the modulation scheme chosen. Each demodulated data bit is extended to a 3-bit soft decision value using the reliability information from the Channel State Estimation to support the following FEC. In par. 4.3.4 in reference [1-1], bit interleaving is also specified in order to disperse bursts of bit errors in the receiver after demapping the complex data symbols. This bit interleaving is reversed in the Bit Deinterleaver module. #### 3.2.2.10 Data Formatter This is the final stage in the OFDM specific part of the DVB-T frontend. It generates from the up to 6 bitstreams according to par. 4.3.4 in reference [1-1] the correct datastreams corresponding to the G1 and G2 data to be fed into the Viterbi decoder. Although the FEC scheme and the format of the data delivered by the OFDM block is identical to the satellite system there is a fundamental difference in clocking. In the DVB-S system the data are delivered continuously to the Viterbi decoder, where as, this cannot be the case in DVB-T. The internal clocking is uncorrelated to the transmitted data rate. Instead of going the costly way of synthesizing an extra clock signal for the Viterbi decoder, the demodulated data are output in burst mode at an average frequency corresponding to the transmitted data rate. For details see the paragraph 4.6 OFDM -> FEC Interface in reference [1-1]. #### 3.2.3 FEC Block The FEC block completes Motorola's DVB-T single chip demodulator by providing all the FEC functions necessary for the reception of DVB-T transmissions. It is fully compliant to the ETSI specification for digital terrestrial broadcasting (see reference [1-1]). Figure 3-5. Block Diagram of the FEC Block #### 3.2.3.1 Node Synchroniser #### 3.2.3.1.1 Syndrome Based Node Synchronisation Prior to producing valid data the Viterbi decoder block must synchronise to the input data stream, including removing any phase ambiguity in the received symbols and determine the punctured code rate transmitted. The Viterbi block employs a method known as Syndrome Based Node Synchronisation to achieve both I & Q symbol and punctured rate Synchronisation. This method has certain advantages over other more common Synchronisation methods such as observation of path metric growth rates and re-encoding of the received data stream: - Path metric growth observations are relatively sensitive to input magnitude variations and require multiple estimation cycles to detect Synchronisation. - Re-encoding of the data stream (using a convolutional encoder) requires multiple estimation cycles and can increase the latency of the decoder. | Device | Descri | ptior | |--------|--------|-------| | | | | Syndrome based node synchronisation is independent of the average input magnitude and can also easily detect changes of the synchronisation state. The theory is based on the observation that the product of the incoming data and a syndrome (predetermined by simulation for each data rate) is zero if synchronised correctly. In any other case, the probability of 0's vs. 1's in the product increases. In the extreme case, i.e. the node synchronisation is completely wrong, the product is random and there is equiprobability of 0's and 1's. This behaviour is exploited for syndrome based node synchronisation. #### 3.2.3.1.2 Synchronisation States The possible states that the synchroniser has to deal with are a combination of the following factors: - The phasing of the received symbols. The synchronise must decide which of two possible states the I and Q input streams are in. They can either be processed as-is or can be rotated 90° to account for constellation rotation in the receiver. - Determination of the framing of the I and Q bit streams so as to extract the correct symbol. There are four possible ways to frame the two bit streams and the synchroniser must determine the correct one. #### 3.2.3.1.3 Synchroniser Parameters The synchroniser is based on an estimator which determines whether the received symbol sequence is in the correct synchronisation state. This estimate is based on single sided sequential probability ratio tests (SPRTs). The tests are based on the accumulation of the log-likelihood ratio (LLR) that a certain hypothesis (in-sync or out-of-sync) for the input sequence holds. A vote for a hypothesis is obtained if the accumulated LLR reaches a certain threshold. The accumulator value L is computed as shown in the flowchart in Figure . #### **NOTE** If a vote for out-of-sync occurs, the synchronisation state (which is output at 12c register SYNCH\_STATE) is increased to test the next hypothesis. Figure 3-6. Synchronisation Flow #### 3.2.3.1.4 Choice of DEC and THRES The constants INC, DEC and THRES influence the acquisition behaviour of the synchroniser as well as it's robustness. The constants INC and DEC should be chosen such that the accumulator is driven towards zero in the case that the syndrome sequence is identifying the in-sync state (i.e. rate of zeroes is $p_0$ ): If the syndrome sequence is identifying an out-of-sync state (i.e. $p_0 = 0.5$ ) the accumulator should be driven with approximately equal average increments towards the threshold. Obviously, the synchroniser will erroneously vote for out-of-sync condition if the channel SNR falls below a certain limit since $p_0$ will approach 0.5 for very low SNR. - The decoder uses a fixed Increment of INC = 32. - DEC is set via 12c register DEC[4:0] and can have a maximum value of 32, default selection of DEC values according to the rate being decoded is enabled by setting the DDEC bit in the CONFIG register to 0. The default values of DEC for each of the supported rates is shown in Table 3-1. - THRES is set via 1<sup>2</sup>C register THRESHOLD and can have a maximum value of 32, default selection of THRES = 8 is enabled by setting the DTHRES bit in the CONFIG register to be 0. The actual value of THRES is interpreted as <register\_value> x 29. The defaults have been chosen such that the synchroniser will operate correctly (but with a performance degradation) roughly 2 dB below the output error rate, which is required for quasi error free operation (BER of the decoded stream approximately $= 2 \times 10^{-4}$ ). **Table 3-1. Default Settings For DEC Parameter** | Rate | Dec | Lower SNR<br>Boundary<br>(dB) | Quasi<br>Error<br>Free SNR<br>(dB) | Design<br>Point SNR<br>(dB) | Design<br>Point<br>Channel<br>BER | |------|-----|-------------------------------|------------------------------------|-----------------------------|-----------------------------------| | 1/2 | 29 | 1.2 | 3.0 | 2.15 | 0.100 | | 2/3 | 26 | 2.0 | 3.5 | 2.49 | 0.062 | | 3/4 | 25 | 2.4 | 4.0 | 3.00 | 0.042 | | 5/6 | 24 | 2.9 | 4.5 | 3.51 | 0.026 | | 7/8 | 23 | 3.5 | 5.2 | 4.10 | 0.017 | #### 3.2.3.1.5 Synchroniser Performance The performance of the synchroniser can be characterized by three figures: • Short Average Run Length (SARL): This is the mean time required to detect that the currently investigated synchronisation state is not the correct synchronisation state. The SARL is calculated as: $$SARL = \frac{2XTHRES}{INC - DEC}$$ #### **NOTE**S SARL performance is not affected by the channel SNR since the syndrome sequence is composed of equiprobable 1's and 0's for an out of synch condition and low channel SNR would also result in equiprobable 1's and 0's. • Reacquisition Average Run Length (RARL): This is the mean time between a erroneous detection of a change of the synchronisation state and successful acquisition of the new synchronisation state (reacquisition). The RARL is calculated as: $$RARL = \frac{SARL}{(syncstates - 1)}$$ Where "syncstates" is given by: Table 3-2. Number of Syncstates in Code Rates | Rate | Synchstates | |------|-------------| | 1/2 | 2 | | 2/3 | 6 | | 3/4 | 4 | | 5/6 | 6 | | 7/8 | 8 | #### NOTE For automatic rate selection the synchroniser investigates the possible synchronisation states one after the other and RARL is calculated as follows: $$RARL = \left(\sum_{rate = \frac{1}{2}}^{\frac{7}{8}} Synchstates\right) \times SARL$$ Long Average Run Length (LARL): This is the mean time until the algorithm incorrectly indicates a change of the synchronisation state that did not actually occur. This grows exponentially with the threshold value THRES. #### **NOTE** While the SARL and RARL can be determined analytically the evaluation of the LARL is nontrivial and is best determined via simulation. Figure 6-2. shows the simulated LARL for all code rates, the channel error rate is set so the SNR is 1dB below the error rate required for QEF operation at the output of Viterbi decoder. Figure 3-7. LARL Versus THRES At Various Design Points For rate $^{1}/_{2}$ (worst case for the synchroniser) the results for QEF (BER = 0.0789) and 2.8 dB below (BER = 0.125) are shown extrapolated. From it can be seen that the LARL increases with decreasing SNR. For QEF operation a threshold below 5000 is sufficient to obtain less than one synchroniser error per day for a rate $\frac{1}{2}$ . #### 3.2.3.1.6 Lock Detection and Time-out Lock of the decoder is indicated if the state of the synchroniser has not changed for a significantly long time, this period is measured in number of syndrome bits. The time-out period can be set via the $I^2C$ register TIMEOUT, a default value of 8 is used if bit DLT in the CONFIG register is set to 0. The actual period is TIMEOUT \* $2^{11}$ syndrome bits. - If the accumulator value L does not reach the threshold value THRES within the period specified by TIMEOUT then it is reset and the decoder continues to indicate a locked state. - If L exceeds THRES before the end of the TIMEOUT period then an out of lock condition is declared and the synchroniser moves to the next state and restarts the synchronisation process. To avoid false lock indications, and to quickly detect out of lock situations the optimal value for TIMEOUT is SARL \* 4. #### 3.2.3.2 Viterbi Error Correction #### 3.2.3.2.1 BER vs. SNR Performance Figure 3-8 shows the performance curves for each code rate as a function of Bit Error Rate (BER) versus channel Signal to Noise Ratio (SNR). The graph also shows the Quasi Error Free (QEF) operating limit at 2 \* 10<sup>-4</sup>. The graph was generated assuming QPSK transmission over an AWGN channel with a normalized gain of 1 at the output of the receiver A/D. In paragraph 5.3.2.3 an example is given how to obtain a BER estimate from the QVAL values that are available from the FEC register. #### 3.2.3.2.2 Decoding Latency A survivor depth of 96 is used to ensure reliable error correction for highrate punctured codes such as the 7/8 code. The latency of the decoder (in symbols) is approximately 2.5 x the survivor depth (the uncertainty in the latency is due to the input FIFO which gives a range of + or - 16 symbols). #### **NOTE** This latency applies for all coding rates not just the 7/8 rate. The absolute worst case latency is thus: $(2.5 \times 96) + 16 = 256$ symbols. #### 3.2.3.2.3 Generator Polynomials The Viterbi decoder is designed to decode bit streams encoded using the DVB standard generator polynomials (171<sub>8</sub>, 133<sub>8</sub>) as shown in Figure 3-9. Figure 3-9. Generator Polynomials #### 3.2.3.2.4 Punctured Codes The Viterbi decoder is able to decode a basic rate 1/2 convolutional code and the "standard" punctured codes for a k=7 constraint length. The punctured maps are shown in the table below. Specific bits of the original rate 1/2 code sequence are periodically deleted prior to transmission according to the entries in the table, where a 0 means that the bit is deleted and a 1 means that the bit is transmitted. Table 3-3. Deletion Map For Punctured Rate 1/2 Codes #### 3.2.3.2.5 Rate Encoding Data Word The code rate actually being decoded by the decoder is indicated via external pins SR2..SR0 and via the I<sup>2</sup>C interface. Table 3-4 shows the encoding of the rate information into a three bit word. This information is used for output information when using automatic synchronisation or for control information when the block is being externally controlled via the I<sup>2</sup>C interface. **Table 3-4. Rate Encoding** | Coding Rate | Data Word | |-------------|-----------| | 1/2 | 000 | | 2/3 | 001 | | 3/4 | 010 | | 5/6 | 011 | | 7/8 | 100 | | Automatic | 111 | Notes: Automatic rate selection is only used as an input value when internal synchronisation is used. The decoder will never output 111 as a coding rate. All other states of the 3 bit data word are unused. This table is referred to throughout this document when discussing the various rates supported by the decoder. #### 3.2.3.2.6 Input Data Format The I and Q data input to the decoder can be interpreted as either sign-magnitude or offset binary format. The choice of input format is specified by setting the IFS bit in the CONFIG register bank of the I2C interface. The default after RESET\_N is to use offset binary. Table 3-5. I And Q Input Format | | VC0[2:0]/VC1[2:0] | | 2's complement | |----------------|----------------------------|-----------------------------|-------------------| | Interpretation | IFS = 0<br>(offset binary) | IFS = 1<br>(sign-magnitude) | (internal format) | | strong 0 | 000 | 011 | 100 | | | 001 | 010 | 101 | | weak 0 | 010 | 001 | 110 | | | 011 | 000 | 111 | | weak 1 | 100 | 100 | 000 | | | 101 | 101 | 001 | | | 110 | 110 | 010 | | strong 1 | 111 | 111 | 011 | #### 3.2.3.2.7 Channel SNR Measurement The synchroniser generated syndrome sequence ( $p_0$ ) is used to determine the channel SNR value. The average value of the number of 1's accumulated from $p_0$ is calculated over a known period and is accessible via the $I^2C$ interface. The window length used is specified by the AVRG\_PERIOD register and is interpreted as AVRG\_PERIOD[3:0] \* 2<sup>15</sup>, the default period of 8 \* 2<sup>15</sup> is used if the DAP bit in the CONFIG register bank is set to 1. The number of 1's in the syndrome stream (divided by 16) which are accumulated over the specified period may be read from the registers QVALMSB[7:0] and QVALLSB[7:0]. The estimated value of p<sub>0</sub> is: $$p_0 = 1 - \frac{QVAL \times 2^4}{PERIOD \times 2^{15}}$$ The value of $p_0$ can be directly related to the signal quality for the various code rates via the curves shown in Figure 3-10. This signal quality value corresponds to the channel SNR of QPSK transmission over an AWGN channel. The curves are generated specifically for the syndrome polynomials actually used in the decoder. To derive a channel SNR value simply look up the value on the x-axis of a given $p_0$ value for a given code rate. Figure 3-10. p<sub>0</sub> Versus Channel SNR #### 3.2.3.2.8 Accuracy of SNR Estimate The accuracy of the p<sub>0</sub> estimate of channel SNR increases with longer averaging periods and with increased SNR. Table 3-6 shows the effect of increasing the AVRG\_PERIOD for different **Device Description** code rates and channel SNR. It shows the probability that the estimate from the graph is within +/- 0.1 dB of the actual channel SNR. Table 3-6. Probability Of p<sub>0</sub> Accuracy | AVRG_PERIOD | # Of Samples | Probability Of +/- 0.1dB Accuracy | | |-------------|--------------|--------------------------------------------|--------------------------------------------| | | | r=1/2, E <sub>b</sub> /N <sub>0</sub> =1.2 | r=7/8, E <sub>b</sub> /N <sub>0</sub> =3.5 | | 1 | 32768 | 0.541559 | 0.999799 | | 2 | 65536 | 0.700163 | 1 | | 4 | 131072 | 0.855141 | 1 | | 8 (default) | 262144 | 0.960214 | 1 | | 15 | 491520 | 0.995069 | 1 | From the table it can be seen that even using the default value for AVRG\_PERIOD the probability that the p<sub>0</sub> estimate of SNR is within 0.1 dB is 96% (even for small SNR values). For increased AVRG\_PERIOD values or increased SNR values the probability is 100% for all practical purposes. #### 3.2.3.3 Frame Synchronisation #### 3.2.3.3.1 MPEG Frame Synchroniser and Deinterleaver This section of the manual describes the Frontend of the Reed-Solomon decoder in the MC92314. The data received from the Viterbi decoder is internally a continuous stream of bits and must be segmented into blocks (MPEG-2 Transport Packets) and subsequently into bytes that the Reed-Solomon can manipulate. The Frame Synchroniser recognizes the Synchronisation Bytes (Sync Bytes) embedded in the data stream and communicates these as frame boundaries to the Reed-Solomon decoder and the other functional blocks. The 12x17 Forney Deinterleaver processes the input bit stream to break up and distribute the longer burst errors throughout the MPEG-2 packet. #### 3.2.3.3.2 Frame Structure and Synchronisation Scheme The MPEG-2 Transport Packet consists of one leading Sync Byte (0x47), 187 information bytes and 16 Reed-Solomon Check Bytes (for a total of 204). In addition, the Sync Byte of every eighth packet is inverted from 0x47 to 0xB8. The frame structure of the interleaved data is depicted in Figure 3-11. The synchroniser uses this structure to determine the byte and frame boundaries to synchronise the deinterleaver and the decoder and also to resolve the $\pi$ -ambiguity of the data within the input stream. Figure 3-11. MPEG-2 Frame Structure ## 3.2.3.3 Frame Synchroniser Modes The Frame Synchroniser has two operation modes: the Acquisition and Tracking Modes. The Acquisition Mode starts when an initial Sync Byte is detected and continues until a specified number of additional Sync Bytes has been found at the correct positions within a specified number of MPEG-2 transport packets. In this case the Tracking Mode is entered. The Frame Synchroniser remains in the Tracking mode as long as the (different) set of synchronisation conditions for tracking is met and maintained. Four integer parameters (set through the I<sup>2</sup>C Interface) are used to establish these two modes: Aq\_Sync\_Thresh, Aq\_Ref\_Thresh, Tr\_Sync\_Thresh and Tr\_Ref\_Thresh. Aq\_Sync\_Thresh and Aq\_Ref\_Thresh are used to set the desired level of Acquisition conditions. If Aq Sync\_Thresh Sync Byte or inverted Sync Byte matches are found in Aq Ref Thresh frame spaced positions (e.g. Aq Sync Thresh = 2 and Ag Ref Thresh = 8: if 2 Sync Bytes are found in 8 MPEG-2 frames or in 8 x 204 = 1632 bytes), In\_Sync is signalled and the Tracking Mode is enabled. Otherwise, the correlation upon the input bit stream is continued and the Frame Synchroniser further remains out of the synchronisation state. In the Tracking Mode, Tr Sync Thresh Sync Byte or inverted Sync Byte matches are necessary in Tr Ref Thresh frame spaced positions in order to stay In Sync. See Figure 3-12 for the state diagram of the Frame Synchroniser. The parameters Aq\_Ref\_Thresh (default: 8) and Tr\_Ref\_Thresh (default: 31) can be set between 0 and 31 and the parameters Aq\_Sync\_Thresh (default: 2) and Tr\_Sync\_Thresh (default: 3) can be set between 0 and 7. Figure 3-12. Frame Synchroniser State Diagram ## 3.2.3.3.4 $\pi$ -Ambiguity Resolution While in the Tracking Mode, $\pi$ -ambiguity is also determined and resolved. As frames enter the Frame Synchroniser the number of Sync Bytes found at frame start positions are compared to the number of inverted Sync Bytes that have been identified. If three inverted Sync Bytes are found per Sync Byte occurrence, a $\pi$ -offset synchronisation of the Viterbi decoder or QAM Demodulator is assumed and all received bits are inverted to correct the $\pi$ phase mismatch at the output. ## 3.2.3.3.5 Frame Synchroniser Performance The False Lock Probability (going into or staying in a state of synchronisation although synchronisation is lost), Loss of Sync Probability (detecting an Out\_of\_Sync state in spite of being In\_Sync), Acquisition Time (time needed to assert the In\_Sync condition), and Loss of Sync Time (time required to detect an Out\_of\_Sync situation when synchronisation is lost) are primarily influenced by the parameters: Aq\_Ref\_Thresh, Aq\_Sync\_Thresh, Tr\_Ref\_Thresh and Tr\_Sync\_Thresh, and the BER out of the Viterbi decoder. Typically, in the 1632 bit (204 x 8 = 1632 bits) frame, there are an average of 12.75, including 11.75 coincidental, matches of the (inverted) Sync Byte. Assuming these matches are uniformly distributed in the frame, the number of synchronisation trials (going from the Out\_of\_Sync state into the Acquisition Mode, see Figure 3-12) until the correct position of the Sync Byte is found averages 12.75 times. The probability of not going In\_Sync can be seen in Figure 3-13 for a BER of 5E-2 and in Figure 3-14 for a BER of 1 \* 10<sup>-4</sup>. The value "n" represents the parameter Aq\_Sync\_Thresh and on the x-axis is Aq\_Ref\_Thresh. These figures also show the Loss of Sync Probability if the Frame Synchroniser is in the Tracking Mode (the value "n" now corresponds to Tr\_Sync\_Thresh and on the x-axis is Tr\_Ref\_Thresh). The Acquisition Time increases with higher values of Aq\_Ref\_Thresh and decreases with higher MPEG-2 Transport Stream input data rates. Each of the 12.75 synchronisation trials needs the duration of Aq\_Ref\_Thresh (default: 8) times 204 bytes, times 8 bits/byte, and divided by the input data bit rate. At 50 Mbit/s, the time interval until the correct position of the Sync Byte is found averages 3.3 ms at a BER of 5 \* 10<sup>-2</sup>. Figure 3-13. Loss of Synchronisation Probability for BER=5E-2 Figure 3-14. Loss of Synchronisation for BER=1E-4 The False Lock Probability is independent of the BER and is depicted in Figure 3-15 for both the Acquisition and Tracking Modes. It gives the probability that in a random data stream the specified number of sync byte values (given with the ..\_Sync\_Thres value) in the expected distance of 204 bytes occurs in the specified window of ..\_Ref\_Thresh packets. Note that whenever a pattern with a period of 1632 bytes is fed into the scrambler at the transmitter side, a bit pattern that accidentally matches the Sync Byte has a 1632 period as well. This applies to any 1632 byte periodical pattern. **EXAMPLE:** Considering, for example, the case that an all zero bit stream is fed into the scrambling block at the transmitter. The Frame Synchroniser may lock falsely onto this bit pattern, if parameters Aq(Tr)\_Ref\_Thresh are set to eight times Aq(Tr)\_Sync\_Thresh or more (see "m=8n" line in Figure 3-15). Figure 3-15. False Lock Probability #### 3.2.3.4 Deinterleaver ## 3.2.3.4.1 Deinterleaver Functionality The error protected packets of 204 bytes are interleaved in the transmitter and the Deinterleaver must process the byte stream before the Reed-Solomon decoder. The Deinterleaver is a Convolutional Forney Deinterleaver with I=12 branches. Each branch consists of a shift register with M(11-j) cells (M=17, j=branch index). Each register has a word length of eight bits so that the data stream is deinterleaved byte wise. For synchronisation purposes, the (inverted) Sync Bytes (as well as some 16 other bytes) are always routed in the "0" branch of the Deinterleaver. Figure 3-16 depicts a conceptual diagram of the Convolutional Forney Deinterleaver. Figure 3-16. Deinterleaver Principle Block Diagram ## 3.2.3.4.2 Deinterleaver Latency The latency of the 12x17 Forney Deinterleaver is 17963 CLOCK cycles (not including the Frame Synchroniser synchronisation acquisition time). ## 3.2.3.5 Reed-Solomon Decoder ## 3.2.3.5.1 Reed-Solomon Decoder Module The algorithmic parameters of the Reed-Solomon decoder used in this block were chosen according to the DVB Specifications. The arithmetic is performed using a Finite Field GF(256) of byte data which is specified by the Field Generator Polynomial: $$p(x) = x^8 + x^4 + x^3 + x^2 + 1$$ The Reed-Solomon decoder works on a shortened (204,188,8) code with Generator Polynomial $g(x) = (x+\alpha^0)(x+\alpha^1)...(x+\alpha^{15})$ , where $\alpha$ =0x02. One Codeword consists of a total of 204 bytes, composed of 188 information bytes followed by 16 parity check bytes. Using this code, the Reed-Solomon decoder is able to detect and correct up to 8 byte errors per Codeword (a byte error specifies an erroneous byte, independently of the number of corrupted bits), which can be arbitrarily distributed within the data and check locations in a Codeword. The following is a summary of the Reed-Solomon parameters: - R = 16 Check Bytes - d = 8 Detection Power - K = 188 Message Length - m = 8 Symbol Size in Bits - N = 204 Codeword Length - T = 8 Number of Error Corrections ## 3.2.3.5.2 Reed-Solomon Functional Description The architecture of the Reed-Solomon decoder is shown in Figure 3-17. The Re-Encoder consists of a Linear Feedback Shift Register (LFSR) of length 16 (bytes) with the feedback connections as specified by the Code Generator Polynomial Coefficients. For each Codeword arriving byte by byte, the Re-Encoder performs a division of this Codeword by the Code Generator Polynomial and stores the remainder. After processing the first 188 information bytes, the Encoder appends the resulting 16 remainder bytes to the byte stream. If, after processing 188 bytes, the Re-Encoder register contents are identical to the 16 last bytes of the Codeword, the Codeword is assumed to have been received without error. Otherwise, the Syndrome (the EXOR of the 16 parity check bytes) and the register contents are stored in the Syndrome RAM. From the Syndrome, the Reed-Solomon Core iteratively determines the Error Location Polynomial (ELP) and the Error Evaluation Polynomial (EEP). The roots of the ELP specify the error locations inside the Codeword. These roots are determined in the Chien Search Unit, which checks for roots by evaluating the ELP for all 255 possible field elements. Simultaneously, the EEP polynomial is evaluated. For each root found, the corresponding EEP value is used to correct the byte error at the specific bit locations. The input data is stored in the Codeword RAM (Reed-Solomon FIFO) during the operation of the Core and the Chien Search Unit in order to take account of the latencies therein. After the roots and error values are determined by the Chien Search Unit, the data is read from the FIFO, and the necessary byte corrections are performed in the Error Correction Unit. If more than 8 byte errors occur in a single frame, this is recognized by the decoder and the input data is output unchanged. In this case, the "transport\_error\_indicator" bit in the MPEG-2 Transport Header is set and the RERRU output shall be asserted. Figure 3-17. Reed-Solomon Block Diagram ## 3.2.3.5.3 Reed-Solomon Performance Analysis The performance was evaluated by applying BPSK Modulation to the input bits and transmitting over an Additive White Gaussian Noise (AWGN) channel at different Signal-to-Noise Ratios (SNR). The results are shown in Figure 3-18. For high input byte error rates the Reed-Solomon is not able to correct errors since there are too many errors per frame. After crossing the point where the average input byte error rate becomes lower than 8/204, the error correction capability of the (204,188,8) code is used to correct most of the errors, leading to a substantial decrease in byte error rate. Figure 3-18. Input Byte Error Rate versus Output Byte Error Rate ## Freescale Semiconductor, Inc. | Device | Description | |--------|-------------| |--------|-------------| ## 3.2.3.5.4 Reed-Solomon Bit Error and Bad Frame Monitor There are two parameters accessible through the I<sup>2</sup>C Interface that the Reed-Solomon decoder circuit uses to track error rates: BER\_COUNT and BAD\_FRAME. ## BAD FRAME This parameter gives the number of bad frames that could not be decoded and corrected during an interval of frames specified through TIME\_COUNT (another I<sup>2</sup>C Interface parameter register). ## BER\_COUNT BER\_COUNT is the number of bit errors within the 188 information bytes during the same interval of frames specified by TIME\_COUNT. Hence, in order to determine a bit error rate, one Codeword should be counted as 188 bytes instead of 204 bytes. If more than 8 byte errors occur in a frame, BER\_COUNT cannot be updated since it is not possible to determine how many bits were corrupted. To obtain a better estimate of the BER rate into the Reed-Solomon decoder block when more than 8 bytes are corrupted, BAD\_FRAME and BER\_COUNT should be combined. ## TIME\_COUNT The parameter TIME\_COUNT specifies the number of Codewords during which the bit errors and bad frames are counted (note that a frame is used here to denote a Codeword of 204 bytes). The number of Codewords is given by (TIME\_COUNT \* 4) + 2. In addition, BER\_COUNT and BAD\_FRAMES are updated every (TIME\_COUNT \* 4) + 2 Codewords only. Internally, the corresponding counters are reset and immediately work on the following (TIME\_COUNT \* 4) + 2 window. Both counters have overflow protection; therefore, once the maximum value is reached, it will remain stable throughout the entire period. As an example, consider the calculation of the post-Viterbi BER using these registers. In the default configuration TIME\_COUNT contains 255, resulting in a number of (255 \* 4 + 2) = 1022 MPEG-2 packets for the update period of the BAD\_FRAME and BER\_COUNT registers. After reading both values immediately one after the other to ensure consistency of the results, first check the BAD\_FRAME. If it contains zero there were not more than 8 wrong bytes in all the MPEG-2 packets watched in the update period completed before the read-out. The **exact** number of bit errors detected and corrected by the Reed-Solomon decoder is therefore given in the BER\_COUNT register. To calculate the BER after the Viterbi decoder use the formula with the number of wrong bits in the numerator and the total number of bits (188 bytes per MPEG-2 packet) in the denominator. If the BAD\_FRAME is **not zero** there was **at least one** packet with more than 8 wrong bytes leading to a **not correctable packet**. This prevents the BER\_COUNT from being updated ## Freescale Semiconductor, Inc. correctly, therefore the number of wrong bits given there does not contain the wrong bits in the uncorrectable packets. Therefore the post-Viterbi BER from the above formula is not applicable. A threshold value of the post-Viterbi BER for the exact value can be obtained by taking the worst condition of 8 single bit errors leading to 8 wrong bytes in one RS packet of 204 bytes. This gives $8/(204*8) \sim 4.9*10^{-3}$ . If this threshold is kept in all packets of the update period the BER\_COUNT is guaranteed to be exact and the BAD\_FRAME is automatically zero. In case of more than one wrong bit in one byte the BAD\_FRAME still is zero. But of more than 8 wrong bytes are detected by the RS decoder the BAD\_FRAME is incremented, leading to an invalid BER calculation using the BER COUNT. ## 3.2.3.5.5 Typical Selection of the Parameters for System Application For the transmission conditions specified by the DVB, there should be only one frame with more then 8 byte errors per hour of operation. Therefore, the default setting is TIME\_COUNT = 255, which means that $(255 \times 4) + 2 = 1022$ frames are checked. For a typical transmission scenario, the BER\_COUNT should then include an averaged figure of the transmission quality before the Reed-Solomon, while the BAD\_FRAMES value should be zero. ## 3.2.3.5.6 Reed-Solomon Decoder Latency The latency of the Reed-Solomon is 3557 CLOCK cycles. #### 3.2.3.6 Descrambler #### 3.2.3.6.1 Descrambler Module To provide an even frequency spectrum distribution across the channel bandwidth and to allow for easier clock recovery, the data is scrambled prior to transmission with a Pseudo-Random Binary Sequence (PRBS) specified by the polynomial 1+x<sup>14</sup>+x<sup>15</sup>. This block performs the descrambling of the Reed-Solomon output to obtain the originally encoded data. ## 3.2.3.6.2 Descrambler/Synchronisation Functionality The PRBS generator's applied to all data except for the MPEG-2 Transport Stream Sync Bytes and inverted Sync Bytes. The seven Sync Bytes of a superframe pass the Descrambler unchanged, although the PRBS generator operates continuously, i.e. the output of the Descrambler is temporarily disabled for the specific transmission of a Sync Byte. Therefore, the period of the PRBS generator is still kept to 1504 bytes (8 x 188). In addition to the PRBS functionality this unit also re-inverts the inverted Sync Byte occurrences, thereby removing the superframe structure. It must be pointed out that the Descrambler will take a maximum value of 7 frames to synchronise internally to the inverted Sync Byte that denotes the superframe boundaries for the correct initialization of the PRBS. This may happen even after the Reed-Solomon decoder Block has signalled a valid synchronisation state by asserting the IN\_SYNC signal pin and is already providing MPEG-2 Transport Stream Bytes at the SPO[7:0] output signal pins and generating waveforms at the other related outputs. Therefore, it is recommended to wait for this period of time after Synchronisation Acquisition has been signalled by the Frame Synchroniser at the signal pins, before the decoding process of output data is initiated, e.g. within the MPEG-2 Transport Stream Demultiplexer. ## 3.2.3.6.3 Descrambler Latency The latency of the Descrambler is 13 CLOCK cycles. PreliminaryInformation Preliminary Information # SECTION 4 DVB-T DEMODULATOR INTERFACES Extensive control and insight into all relevant system parameters is given to the user of Motorola's single chip DVB-T demodulator by the interfaces of the IC. To control the actions of the chip several status lines as well as internal registers are provided. The information presented in this section describes the details of the external interfaces. Also all the information necessary to understand the setup of the circuit as described in Section 5 is given. According to the characteristics of the interfaces the description is separated into the (physical) control lines and software controllable registers. ## **4.1 General Purpose Outputs** Four general purpose output pins are provided that can be set via the I<sup>2</sup>C interface of the FEC block. The corresponding bits reside in the 4 MSBs of the SOFT\_RESET register (address \$1F in the FEC block), these bits set the outputs of the GP[3:0] pins (pin numbers 104, 102, 99 and 97) of the MC92314. Possible applications include control of the DVB-T tuner. In some applications it may be useful to prevent the tuner interface from listening to the I<sup>2</sup>C communication all the time to keep the noise introduced by the digitial signals away from the analog circuitry of the tuner. This can easily be achieved by feeding the SDA and SCL lines to the tuner via analog switches that are enabled by one of the general purpose outputs. Even in case of non-standardised serial tuner interfaces that need only input from the system controller the whole data transmission from the system controller to the tuner can be done by using these outputs. ## 4.2 I<sup>2</sup>C Interface Motorola's M-Bus implemented in the device is functionally identical to the well-known I<sup>2</sup>C bus. It is a two wire serial and bidirectional interface for (comparatively) slow data transmission. In many STB systems it is used to exchange control information between a host processor and peripherals using only 2 package pins. The I<sup>2</sup>C bus consists of a clock (SCL) and a data (SDA) signal. Both signals are bidirectional with open-drain output. Each device can send and receive clock and data. The master of the bus generates the clock. Figure 4-1 demonstrates the bidirectional open-drain bus configuration with 2 slaves and one master. The thick lines highlight the data flow during a read transfer from Slave1 to the master. Figure 4-1. Usual I<sup>2</sup>C Environment The protocol consists of a sequence of high and low states and additionally of certain edge dependencies for synchronisation. If more than one master is available a certain arbitration scheme is also defined. Arbitration is not object of this document because the MC92309 works only in slave mode. Each transmission sequence is synchronised by a start condition and finished by a stop condition. The data will be transmitted byte wise. Each transmitted byte will be acknowledged by the receiving slave module. ## 4.2.1 I<sup>2</sup>C Functionality ## 4.2.1.1 Start Condition Whenever SDA goes from high to low while SCL is constant high a data transfer sequence is started. ## 4.2.1.2 Stop Condition Whenever SDA goes from low to high while SCL is constant high a data transfer sequence is finished. ## 4.2.1.3 Transmitting "1" and "0" Whenever SDA changes its value SCL must be low. ## 4.2.1.4 Data Transfer Sequence Each I<sup>2</sup>C bus member has a 7-Bit address. The data transfer starts with the start condition and is followed by the 7-Bit address of the slave to be selected. The 8th bit after the address determines the direction of the initiated data transfer. The selected slave has to acknowledge the successful receipt of its address. If the transfer should be a read transfer from slave to the master, the slave starts transmitting byte by byte until the master forces the stop condition. Each byte will be acknowledged by the master. A new transfer sequence can start immediately issuing a new start condition instead of the stop condition. Figure 4-2. Read Sequence Figure 4-3. Write Sequence Figure 4-4. Combined Sequence ## 4.2.1.5 Accessing Registers via I<sup>2</sup>C Each internal register accessible by the I<sup>2</sup>C has an internal I<sup>2</sup>C register address. Before a register can be accessed the I<sup>2</sup>C register address must be transferred by a write sequence. After the data byte has been transmitted or received from or to the selected I<sup>2</sup>C register an additionally byte transfer can be initiated. This byte transfer will access register with the next following I<sup>2</sup>C register address. A short example describes typical I<sup>2</sup>C sequences in a short format: Figure 4-5. Typical I<sup>2</sup>C Sequence ## 4.2.1.5.1 Defining I<sup>2</sup>C Slave Address All I<sup>2</sup>C bus members must have different 7-Bit I<sup>2</sup>C addresses with the LSB defining the direction of data transfer (**0**: master **writes** into slave; **1**: master **reads** from slave). The selection of unique addresses within the system is done by setting certain addressbits of the devices. The bits that can be set individually by the user are explained below. ## 4.2.1.6 I<sup>2</sup>C Interface of the MC92314 Despite the device works with a supply voltage of 3.3 V it can be used without any modification in an environment with a H-Level voltage of 5 V due to the 5 V tolerant I/O drivers implemented. Because 2 devices out of the 3-chip set use their own I<sup>2</sup>C controllers it was decided to implement two different I<sup>2</sup>C addresses in the single chip demodulator to keep the necessary changes on the control software as small as possible. Therefore the I2C registers of the OFDM block have a different address than the registers of the FEC part. The four lower bits of the MC92314 address can be programmed by the board designer connecting the MBUSID[3..0] pins to VDD or VSS. The higher 3 bits are fixed to different patterns for the OFDM and the FEC part. # OFDM Block I<sup>2</sup>C Slave Address 0 1 0 MBUSID3 MBUSID2 MBUSID1 MBUSID0 ## FEC Block I<sup>2</sup>C Slave Address | 0 | 0 | 1 | MBUSID3 | MBUSID2 | MBUSID1 | MBUSID0 | |---|---|---|---------|---------|---------|---------| |---|---|---|---------|---------|---------|---------| PreliminaryInformation ## 4.2.2 I<sup>2</sup>C Register Maps of the MC92314 As the single chip DVB-T demodulator MC92314 is the integration of Motorola's 3 chip set into one device, the register structure of its ancestors was preserved to allow as much reuse of the control software as possible. Therefore the registers are grouped into the OFDM part and the FEC part, corresponding to the MC92308 and MC92309, as described in reference [1-4]. PreliminaryInformation ## 4.2.2.1 Register Map for the OFDM Part The complete register map of the OFDM block is given in Table 4-1: Preliminary Information AGCFIX[11:8] AGCFEEDBACK[11:8] VCXOFIX[11:0] AFCFEEDBACK[7:0] AFCFEEDBACK[15:8] AGCFEEDBACK[7:0] VCXOFIX[7:0] #### Addr Name Def **b7** b6 b5 b4 b3 b2 b1 b0 **Type** TPS R0 \$0 R S[7:0] \$1 TPS R1 R S[15:8] \$2 TPS R2 R S[23:16] \$3 TPS R3 R S[31:24] \$4 TPS R4 R S[39:32] \$5 TPS R5 R S[47:40] \$6 TPS R 6 R S[55:48] \$7 TPS R7 R S[63:56] \$8 TPS R 8 R **AFCL CLKL TPSV TPSL** S[67:64] \$9 TPS Idx W IDX[7:0] \$A Soft Reset W \$00 SRES **CODERATE GUARD** CONST \$B OFDM R0 R/W \$12 0 **ATPS AFC** \$C OFDM R1 W \$1C 00 **ASYN TSM** \$D OFDM R2 W \$75 **FTSE** AFCS AGCS 10 UHFI **ADCM CLKS CLK Coeff** \$1F **PROPORTIONAL INTEGRATOR** \$E R/W AGC Gain Offset **INT Gain Offs** R/W \$EF AFC Gain Offset AFC Strt 0 R/W AFCSTART[7:0] \$10 \$00 AFC Strt 1 R/W \$10 AFCSTART[15:8] \$11 AFC Thr 0 \$12 R/W \$13 AFCTHRESHOLD[7:0] AFC Thr 1 R/W \$10 AFCTHRESHOLD[15:8] \$13 \$14 AGC Thr R/W \$1**F** AGCTHRESHOLD[7:0] AFC Sw Sp 0 R/W \$80 \$15 AFCSWEEPSPEED[7:0] AFC Sw Sp 1 R/W \$00 AFCSWEEPSPEED[15:8] \$16 CSE R0 \$17 R/W \$C5 CSE[7:0] CSE R1 R/W \$18 \$D2 CSE[15:8] \$19 CSE R2 R/W \$DF CSE[23:16] CSE R3 R/W \$10S \$1A CSE[31:24] W \$FA \$21 Internal 0 AGC Fix 0 \$25 W \$00 AGCFIX[7:0] Table 4-1. I2C Registers of the OFDM Block ## 4.2.2.1.1 TPS Registers 0 - 8 (\$00..\$08, R) W R R R R W W \$00 \$00 \$00 AGC Fix 1 AFC Fdbk 0 AFC Fdbk 1 AGC Fdbk 0 AGC Fdbk 1 VCXO Fix 0 VCXO Fix 1 \$26 \$2F \$30 \$33 \$34 \$36 \$37 According to the DVB-T specification (see reference [1-1]) the TPS data are decoded inside of the OFDM block. These data are stored in the first 68 bits of the TPS registers. The remaining 0000 0000 0000 4 bits ( $s_{68}$ to $s_{71}$ ) contain status information concerning the decoding process. The TPS registers are updated continuously as the TPS data are decoded from the pilot information. To achieve read access to the TPS data this update process must be suspended prior to reading. This is accomplished by a write access to the TPS index register. Following this write the desired TPS data can be read. Table 4-2. TPS signalling information and format (see reference [1-1]) | Bit number | Values | Purpose/Content | |------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------| | s <sub>0</sub> | | Initialization bit for 2-DPSK modulation of TPS | | | 0011010111101110 | Synchronisation word for 1st and 3rd TPS block | | s <sub>1</sub> - s <sub>16</sub> | or | | | | 1100101000010001 | Synchronisation word for 2nd and 4th TPS block | | s <sub>17</sub> - s <sub>22</sub> | 010111 | Length indicator | | | 00: Frame #1<br>01: Frame #2 | | | s <sub>23</sub> , s <sub>24</sub> | 10: Frame #3 | Frame number within the superframe | | | 11: Frame #4 | | | | 00: QPSK | | | s <sub>25</sub> , s <sub>26</sub> | 01: 16-QAM | Constellation | | 025, 026 | 10: 64-QAM | - Constantion | | | 11: reserved | | | | 000: Non hierarchical<br>001: α = 1 | | | | $010: \alpha = 1$ | | | s <sub>27</sub> , s <sub>28</sub> , s <sub>29</sub> | 011: α = 4 | Hierarchy information (α-value) | | | 100: reserved | | | | | | | | 111: reserved | | | | 000: <sup>1</sup> / <sub>2</sub><br>001: <sup>2</sup> / <sub>3</sub> | | | • | 010: <sup>3</sup> / <sub>4</sub> | | | | 011: <sup>5</sup> / <sub>6</sub> | Code sate LID etroops | | s <sub>30</sub> , s <sub>31</sub> , s <sub>32</sub> | 100: $^{7}/_{8}^{\circ}$ | Code rate, HP stream | | | 101: reserved | | | | <br>111: recented | | | S <sub>33</sub> , S <sub>34</sub> , S <sub>35</sub> | 111: reserved same as above | Code rate, LP stream | | 333, 334, 335 | 00: <sup>1</sup> / <sub>32</sub> | Code rate, Er Stream | | | 01: 1/16 | O sellistered | | s <sub>36</sub> , s <sub>37</sub> | 10: <sup>1</sup> / <sub>8</sub> | Guard interval | | | 11: <sup>1</sup> / <sub>4</sub> | | | | 00: 2K mode | | | S <sub>38</sub> , S <sub>39</sub> | 01: 8K mode | Transmission mode | | - 307 - 39 | 10: reserved<br>11: reserved | | | S40 - S50 | all set to '0' | Reserved for future use | | s <sub>40</sub> - s <sub>53</sub><br>s <sub>54</sub> - s <sub>67</sub> | BCH code | Error protection | | S <sub>68</sub> | TPS lock | TPS acquired indicator | | ~00 | | • | | Seo | TPS valid | I unaveraged LPS indicator | | s <sub>69</sub> | Clock/Time Sync Lock | unaveraged TPS indicator Timing Synchronisation achieved lock | #### **NOTE** The status bits $s_{68}$ to $s_{71}$ are active H, unless the hardware pins a 1 in these bits always indicates successful lock. ## 4.2.2.1.2 TPS Index Register (\$09, W) The function of this register is twofold: Writing a value in the allowed range (0 to 8) stops automatic updates to the TPS data. The number of bytes to read is determined from the value written (x) according to 9 - x (a value of 0 corresponds to reading the complete TPS block of 9 bytes). The TPS bytes may be read in any order from arbitrary addresses but the specified number must be read. As an example consider the reading of TPS registers 0, 4 and 8: Write 6 to address 9 (TPS index register): Stop automatic update and prepare for 3 bytes to read. - Read address 0 -> TPS register 0. - Read address 8 -> TPS register 8. - Read address 4 -> TPS register 4. Note that the order of reading the 3 bytes is arbitrary. After reading the 3rd byte automatic update of the TPS registers is enabled again. ## 4.2.2.1.3 Software Reset (\$0A, W) Writing a sequence of 0 - 1 - 0 into this register issues a soft reset of the OFDM block. In this case all the internal control loops start again, but the internal values programmed into the registers are preserved. ## 4.2.2.1.4 OFDM Mode (\$0B..\$0D, R/W and W) These registers hold the internal settings of the OFDM block for the modulation and the guard interval. The bit assignments are shown in Table 4-3 through Table 4-5, the initial value after reset is given by the annotation (i.v.). Table 4-3. OFDM Register 0 (\$0B, R/W) | CODERATE BIT[7:4] | GUARD BIT[3:2 | CONST BIT[1:0] | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------| | 0000: <sup>1</sup> / <sub>2</sub><br>0001: <sup>2</sup> / <sub>3</sub> (I.V.)<br>0010: <sup>3</sup> / <sub>4</sub><br>0011: <sup>5</sup> / <sub>6</sub><br>0100: <sup>7</sup> / <sub>8</sub><br>0101: RESERVED<br>0110: RESERVED<br>0111: RESERVED<br>1XXX: RESERVED | 00: <sup>1</sup> / <sub>32</sub> (I.V.)<br>01: <sup>1</sup> / <sub>16</sub><br>10: <sup>1</sup> / <sub>8</sub><br>11: <sup>1</sup> / <sub>4</sub> | 00: QPSK<br>01: 16-QAM<br>10: 64-QAM (I.V.)<br>11: RESERVED | ## NOTE Note that the initial values of this register may be changed during the initialisation of the device. Note also that the ATPS Bit must be set to 0 to write into this register successfully. As the transmission parameters are available after decoding the TPS information any change in this register is beyond the normal use. Table 4-4. OFDM Register 1 (\$0C, W) | RESERVED BIT[7:4] | ASYN BIT[3] | ATPS BIT[2] | AFC BIT[1] | TSM BIT[0] | |-------------------|------------------------------------------------------|-----------------------------------------------------|-------------------------------------------------------------|--------------------------------------------------------------| | 0001: (I.V.) | 0: MANUAL<br>SWITCH<br>1: AUTOMATIC<br>SWITCH (I.V.) | 0: MANUAL LOAD 1: AUTOMATIC SETTING FROM TPS (I.V.) | 0: COARSE<br>ACQUISITION<br>(LV.)<br>1: FINE<br>ACQUISITION | 0: COARSE<br>ACQUISITION<br>(I.V.)<br>1: FINE<br>ACQUISITION | **Time Sync Mode [TSM]:** The OFDM block has two different modes to achieve and track the time synchronisation. Depending from bit O[11] it changes automatically from coarse mode (achieve sync) to fine mode (track sync). In some rare cases it might be necessary to set the mode manually using this bit. If bit O[11] is set to 1 the Time Sync Mode bit has no effect. **AFC Mode [AFC]:** The OFDM block has two different modes to achieve and track the frequency synchronisation. Depending from bit O[11] it changes automatically from coarse mode (continuous sweep through the available offset frequency range) to fine mode (track sync by using the pilot carriers). In some rare cases it might be necessary to set the mode manually using this bit. If bit O[11] is set to 1 the AFC Mode bit has no effect. **OFDM Mode Setting [ATPS]:** This bit is used to switch between <u>A</u>utomatic mode selection (modulation and coderate set based on the decoded <u>TPS</u> values) and manual mode setting. If set to 0 the manual mode settings must be loaded into the corresponding bits in the OFDM Mode register 0 as shown in Table 4-3. The initial value after reset is 1, corresponding to automatic setting. **OFDM Sync Mode Setting [ASYN]:** The changeover from coarse to fine acquisition mode for time sync and AFC control is normally done automatically. This automatic switch can be disabled, the initial value set after reset is automatic changeover. ## Table 4-5. OFDM Register 2 (\$0D, W) | FTSE BIT[7] | AFCS BIT[6] | AGCS BIT[5] | RESERVED<br>BIT[4:3] | UHFI BIT[2] | ADCM BIT[1] | CLKS BIT[0] | |------------------------------------------------|--------------------------------------------|-------------------------------------------------------------------------|----------------------|------------------------------------------|------------------|---------------------------------------------------------------------------| | 0: FTS<br>DISABLED (I.V.)<br>1: FTS<br>ENABLED | 0: INCR. FREQ.<br>1: DECR.<br>FREQ. (I.V.) | 0: INCR. VOLT -><br>INCR. GAIN<br>1: DECR. VOLT -><br>INCR. GAIN (I.V.) | 10: (I.V.) | 0: UPPER S.B.<br>1: LOWER S.B.<br>(I.V.) | 10.2/SCOMPLEMENT | 0: INCR. VOLT -><br>INCR. FREQ.<br>1: DECR. VOLT -><br>INCR. FREQ. (I.V.) | **OFDM Clock VCXO Slope [CLKS]:** The direction of the VCXO control signal to adjust the OFDM system clock can be adjusted using this register (of course it is also possible to select the appropriate control line, see the paragraph 4.3.4 Tuner Control signals from the MC92314). Initial value is that **decreasing voltage** from the OFDM block is assumed to result in **increasing frequency** of the VCXO. **Tuner ADC Input Format [ADCM]:** This register serves to adjust the input stage of the OFDM block to the ADC in the tuner. The initial value is set to 2's complement. **UHF Demodulation Sideband [UHFI]:** Normally the LO in the tuner's downconverter is located above the received channel. So the RF spectrum is inverted when arriving at the OFDM block. Using this register it is possible to select the appropriate sideband. The initial value is set corresponding to the inverted spectrum. **AGC Slope [AGCS]:** The direction of the AGC control signal to adjust the tuner's AGC amplifier can be adjusted using this register. The initial value is set that the OFDM block assumes increasing gain with decreasing voltage. **AFC Slope [AFCS]:** This bit sets the direction of the AFC control signal to compensate for LO drifts in the tuner. The initial value is set for the lower sideband used in the tuner. Fine Time Sync Enable [FTSE]: This bit enables the Fine Time synchronisation loop to control the VCXO via the $\sigma\delta$ -DAC in the device. To test the connection from the device to the tuner it is possible to disable this connection and to write into the VCXO Fix register. #### **NOTE** Please refer to Section 5 for additional details on the initialisation of the OFDM block. ## 4.2.2.1.5 Clock Loop Filter Coefficients (\$0E, R/W) This register sets the coefficients for the clock loop filter coefficients. Bits [7:4] control the gain of the proportional part, bits [3:0] control the gain of the integrator. The coefficients actual used are of the form $$C + 1 * 2^{XXXX}$$ ## Freescale Semiconductor, Inc. DVB-T Demodulator Interfaces with 'XXXX' being the programmed value (4 bit 2's compement numbers) and 'C' being a constant. For a description of the filter structure see paragraph 3.2.2.3. ## 4.2.2.1.6 AGC/AFC Integrator Gain (\$0F, R/W) This register allows control of the coefficients for the AGC and the AFC filter integrators. Bits [7:4] control the gain of the AGC integrator, bits [3:0] control the gain of the AFC integrator. The values programmed here increase or decrease the default values instead of setting the coefficients directly, therefore the default value is \$00. ## 4.2.2.1.7 AFC Sweep Start [1:0] (\$11:\$10, R/W) This registers holds the initial value of the accumulator for the coarse AFC frequency sweep algorithm. This corresponds to the start point of the sweep through the available range when the sweep starts, e.g. after a soft reset. Once synchronisation has been achieved, it may be possible to reduce the lock-in time of subsequent acquisition cycles by trying the previous lock-in value. ## 4.2.2.1.8 AFC Threshold [1:0] (\$13:\$12, R/W) This register holds the threshold value to switch off coarse AFC as a 16-bit value (register 0 at address \$12 corresponds to the LS byte, register 1 at address \$13 to the MS byte). By adjusting this value, it is possible to optimise the AFC acquisition time. ## 4.2.2.1.9 AGC Threshold (\$14, R/W) This register holds the compare value for the AGC module. By changing this value it is possible to alter the input peak-to-mean ratio of the OFDM time domain signal and therefore find the optimal compromise between quantisation noise and clipping. ## 4.2.2.1.10 AFC Sweep Speed [1:0] (\$16:\$15, R/W) This registers contains the increment value of the AFC offset stepsize during the sweep. ## 4.2.2.1.11 Channel State Estimation [3:0] (\$1A:\$17, R/W) This registers controls the generation of soft-decision information out of the Channel State Estimation block. As the terrestrial reception is subject to several kinds of disturbance (see Section 2) the optimal setting w.r.t. e.g. to noise is not optimal w.r.t. to single tone or co-channel interference. The default values in this register are optimised for best noise performance. In Section 5 another set of values for best CCI performance is given. ## 4.2.2.1.12 Internal Register (\$21, W) This register is used to select internal configurations of the OFDM. There's no need to use it for normal operation, but it can be used to enable the AGC Fix registers in the same way like the VCXO Fix registers described above. Refer to paragraph 4.2.2.1.13 for the value necessary. ## 4.2.2.1.13 AGC Fix [1:0] (\$26:\$25, W) This 2-byte register can be used to set the voltage at the $\sigma\delta$ -output for the AGC circuit in the tuner, mainly intended for test purposes, not for normal operation. To use them the value of \$BA must be written to the Internal register at address \$21. Afterwards the AGC Fix register can be used to set the analog voltage level at the AGC input of the tuner. The format is identical to the AGC Feedback register described below (12 bit width, 4 MSBs of register 1 are always 0). The following table summarises the voltage levels after the LPF in relation to the AGCS bit: Table 4-6. Voltages after the AGC LPF using the AGC Fix Register | AGC Fix Register Content | AGCS | Voltage Level | |---------------------------|------|----------------------------| | -2048 (00001000 00000000) | 0 | Lowest voltage (near 0 V) | | +2047 (00000111 11111111) | 0 | Highest Voltage (near 3 V) | | -2048 (00001000 00000000) | 1 | Highest Voltage (near 3 V) | | +2047 (00000111 11111111) | 1 | Lowest voltage (near 0 V) | ## 4.2.2.1.14 AFC Feedback [1:0] (\$30:\$2F, R) These two registers represent the current offset of the internal AFC block inside the available range (register 0 at address \$2F corresponds to the LS byte, register 1 at address \$30 to the MS byte). Values within the available range excluding the edges represent normal operation. ## 4.2.2.1.15 AGC Feedback [1:0] Register (\$34:\$33, R) Similar to the AFC Feedback register these two registers represent the current position of the AGC control inside the available range (register 0 at address \$33 corresponds to the LS byte, register 1 at address \$34 to the MS byte). The number format is 2's complement and the number contains 12 valid bits (the 4 MSBs of register 1 are not used, they are always 0). The AGC voltage levels corresponding to the numbers depend from the value of the AGC Slope bit AGCS: Table 4-7. Voltages according to the AGC Feedback Registers | AGC Feedback Register Content | AGCS | Voltage Level | |-------------------------------|------|----------------------------| | -2048 (00001000 00000000) | 0 | Lowest voltage (near 0 V) | | +2047 (00000111 11111111) | 0 | Highest Voltage (near 3 V) | | -2048 (00001000 00000000) | 1 | Highest Voltage (near 3 V) | | +2047 (00000111 11111111) | 1 | Lowest voltage (near 0 V) | Note that for correct operation bit AGCS must reflect the behaviour of the tuner's AGC circuitry. Given that this setting is correct and the OFDM block is locked onto the signal the <u>most negative value</u> corresponds to the <u>minimum gain</u> of the tuner and the **most positive value** corresponds to the **maximum gain**. ## 4.2.2.1.16 VCXO Fix [1:0] Register (\$37:\$36, W) This 2-byte register can be used to set the voltage at the $\sigma\delta$ -output for the VCXO in the tuner, mainly intended for test purposes, not for normal operation. To use them the FTSE bit must be set to 0. Afterwards the VCXO Fix register can be used to set the analog voltage level at the VCXO input of the tuner. Again, the 4 MSBs of register 1 are always 0. The following table summarises the voltage levels after the LPF in relation to the CLKS bit: Table 4-8. Voltages after the VCXO LPF using the VCXO Fix Register | VCXO Fix Register Content | CLKS | Voltage Level | |---------------------------|------|----------------------------| | -2048 (00001000 00000000) | 0 | Lowest voltage (near 0 V) | | +2047 (00000111 11111111) | 0 | Highest Voltage (near 3 V) | | -2048 (00001000 00000000) | 1 | Highest Voltage (near 3 V) | | +2047 (00000111 11111111) | 1 | Lowest voltage (near 0 V) | ## 4.2.2.2 Register Map for the FEC Part The table below describes the register map for the FEC block: Table 4-9. I<sup>2</sup>C Registers for the FEC Block | Addr | Name | Type | Def | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |------|--------------|------|-----|--------------|----------------------------------|------|------|-------|----------|----------|--------| | 0 | CONFIG_VIT | R/W | | DAP | DLT | DDEC | DTHR | IFS | V | SYNC[2:0 | 0] | | 1 | THRESHOLD | R/W | | | | | | Т | HRES[4:0 | )] | | | 2 | DECREMENT | R/W | | | | | | | DEC[4:0] | | | | 3 | TIMEOUT | R/W | | | | | | | TIM | [3:0] | | | 4 | AVG_PERIOD | R/W | | | | | | | PERIC | D[3:0] | | | 8 | QVALLSB | R | | | | | QVA | [7:0] | | | | | 9 | QVALMSB | R | | • QVAL[14:8] | | | | | | | | | \$A | SYNC_VIT | R | | | | | | VLCK | | | | | \$B | SELECTEDRATE | R | | | | | | | | SR[2:0] | | | \$C | FIFO_STATE | R | | | | | | | | VFF | VEF | | \$11 | AQ_THRESH | R/W | | | SYNC[2:0 | 1 | | | REF[4:0] | | | | \$12 | TR_THRESH | R/W | | | SYN <b>C</b> [2 <mark>:</mark> 0 | D, | | | REF[4:0] | | | | \$13 | TIME_COUNT | R/W | | | | | TC[7 | 7:0] | | | | | \$18 | BER_COUNT | R | | BER[7:0] | | | | | | | | | \$19 | BAD_COUNT | R | | BAD[3:0] | | | | | 3:0] | | | | \$1A | SYNC_RS | R | | 0 | 0 | 0 | 0 | 0 | RERRU | DEINT | INSYNC | | \$1F | SOFT_RESET | R/W | | GP3 | GP2 | GP1 | GP0 | | FFT | RS | VIT | ## 4.2.2.2.1 CONFIG\_VIT Register (\$0, W) | Read -<br>Write<br>Access | 7 | (8) | 5 | 4 | 3 | 2 | 1 | 0 | I2C<br>Register<br>Address | | |------------------------------|-----|-----|------|--------|-----|----------|----------|----------|----------------------------|--| | W | DAP | DLT | DDEC | DTHRES | IFS | VSYNC[2] | VSYNC[1] | VSYNC[0] | <b>.</b> | | | Default Setting After Reset: | | | | | | | | | | | | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | ## **DAP** Default Average Period Select - 0: Period for channel SNR measurement is defined by I2C Register AVRG\_RERIOD x $2^{15}$ - 1: Period for channel SNR measurement is 8 x 2<sup>15</sup> ## **DLT** Default Lock Time-out Select - 0: Lock time-out of Node Synchroniser is defined by I2C Register TIMEOUT x $2^{11}$ syndrome bits - 1: Lock time-out of Node Synchroniser is 8 x 2<sup>11</sup> syndrome bits #### **DDEC** Default Decrement Select - 0: Accumulator decrement in Node Synchroniser is defined by I2C Register DECREMENT - 1: Accumulator decrement in Node Synchroniser is used rate dependent from Table 3-1.. #### **DTHRES** Default Threshold Select - 0: Accumulator threshold in Node Synchroniser is defined by I2C Register THRESHOLD - 1: Accumulator threshold in Node Synchroniser is 8 x 29 ## **IFS** Input Format Select - 0: The I-Q-Inputs G1DATA2..0 and G2DATA2..0 are interpreted as offset binary - 1: The I-Q-Inputs G1DATA2..0 and G2DATA2..0 are interpreted as sign magnitude ## VSYNC[2:0] Decoder Rate Select - 000: Select fixed Viterbi decoder rate of 1/2 - 001: Select fixed Viterbi decoder rate of 2/3 - 010: Select fixed Viterbi decoder rate of 3/4 - 011: Select fixed Viterbi decoder rate of 5/6 - 100: Select fixed Viterbi decoder rate of 7/8 - 111: Automatic Viterbi decoder rate selection ## 4.2.2.2.2 THRESHOLD Register | Read -<br>Write<br>Access | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | I2C<br>Register<br>Address | | | |------------------------------|---|---|---|----------|----------|----------|----------|----------|----------------------------|--|--| | W | 0 | 0 | 0 | THRES[4] | THRES[3] | THRES[2] | THRES[1] | THRES[0] | <b>.</b> | | | | Default Setting After Reset: | | | | | | | | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | ## THRES[4:0] Accumulator Threshold Value When DTHRES is 0 THRES[4:0] will be used as threshold value in Node Synchroniser. ## 4.2.2.2.3 DECREMENT Register | Read -<br>Write<br>Access | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | I2C<br>Register<br>Address | |---------------------------|-----------------|-------|---|--------|--------|--------|--------|--------|----------------------------| | W | 0 | 0 | 0 | DEC[4] | DEC[3] | DEC[2] | DEC[1] | DEC[0] | \$02 | | Default Se | etting After Re | eset: | | | | | | | - | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ## DEC[3:0] Accumulator Decrement Value When DDEC is 0 DEC[4:0] is used to decrement the accumulator in Node Synchroniser. ## 4.2.2.2.4 TIMEOUT Register | Read -<br>Write<br>Access | 7 | 6 | 5 | 4 🕻 | 3 | 2 | 1 | 0 | I2C<br>Register<br>Address | | |------------------------------|---|---|---|-----|--------|--------|--------|--------|----------------------------|--| | W | 0 | 0 | 0 | 0 | TIM[3] | TIM[2] | TIM[1] | TIM[0] | \$03 | | | Default Setting After Reset: | | | | | | | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | _ | | TIM[3:0] Lock Time-out Value When DLT is 0 TIM[3:0] is used to define the time-out for out-of-lock condition. ## 4.2.2.2.5 AVRG\_PERIOD Register | Read -<br>Write<br>Access | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | I2C<br>Register<br>Address | |---------------------------|-----------------|-------|---|---|-----------|-----------|-----------|-----------|----------------------------| | W | 0 | 0 | 0 | 0 | PERIOD[3] | PERIOD[2] | PERIOD[1] | PERIOD[0] | | | Default Se | etting After Re | eset: | | | | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | PERIOD[3:0] SNR Measurement Period Value When DAP is 0 PERIOD[3:0] is used to define the period for SNR measurement. ## 4.2.2.2.6 QVAL Registers | Read -<br>Write<br>Access | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | I2C<br>Register<br>Address | |---------------------------|-----------------|---------|---------|---------|---------|---------|---------|---------|----------------------------| | R | QVAL[7] | QVAL[6] | QVAL[5] | QVAL[4] | QVAL[3] | QVAL[2] | QVAL[1] | QVAL[0] | \$08 | | Default Se | etting After Re | eset: | | | | | | | 1 | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | R | QVAL[15] | QVAL[14] | QVAL[13] | QVAL[12] | QVAL[11] | QVAL[10] | QVAL[9] | QVAL[8] | \$09 | | | |------------------------------|----------|----------|----------|----------|----------|----------|---------|---------|------|--|--| | Default Setting After Reset: | | | | | | | | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | ## QVAL[15:0] SNR Measurement Result From QVAL[15:0] it can be determined the SNR. The register is read only. A write access will not have any effect. ## 4.2.2.2.7 SYNC\_STATE Register | Read -<br>Write<br>Access | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | I2C<br>Register<br>Address | |---------------------------|-----------------|-------|---|---|------|---|---|---|----------------------------| | R | 0 | 0 | 0 | 0 | VLCK | Х | Х | Х | \$0A | | Default S | etting After Re | eset: | | | | | | | _ | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ## **VLCK** Node Synchroniser in Lock Indicator - 0: Node Synchroniser out of lock - 1: Node Synchroniser in lock Bit 2 to 0 are not documented indicators. They can have any values. The same information is provided at the output pin VLOCK. The register is read only. A write access will not have any effect. ## 4.2.2.2.8 SELECTED\_RATE Register | Read -<br>Write<br>Access | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | I2C<br>Register<br>Address | |---------------------------|-----------------|-------|---|---|---|-------|-------|-------|----------------------------| | R | 0 | 0 | 0 | 0 | 0 | SR[2] | SR[1] | SR[0] | \$0B | | Default Se | etting After Re | eset: | | | | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ## SR[2:0] Actual Rate of Node Synchroniser 000: Viterbi decoder rate is 1/2 001: Viterbi decoder rate is 2/3 010: Viterbi decoder rate is 3/4 011: Viterbi decoder rate is 5/6 100: Viterbi decoder rate is 7/8 The selected rate is also visible at the output pins SR2..0 The register is read only. A write access will not have any effect. ## 4.2.2.2.9 FIFO\_STATE Register | Read -<br>Write<br>Access | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | I2C<br>Register<br>Address | |---------------------------|-----------------|-------|---|---|---|---|-----|-----|----------------------------| | R | 0 | 0 | 0 | 0 | 0 | 0 | VFF | VEF | \$0C | | Default Se | etting After Re | eset: | | | | | | | _ | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ## VFF FIFO Full Indicator 0: FIFO not full 1: FIFO overflow ## VEF FIFO Empty Indicator 0: FIFO not empty 1: FIFO underflow The register is read only. A write access will not have any effect. ## 4.2.2.2.10 AQ\_THRESH Register | Read -<br>Write<br>Access | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | I2C<br>Register<br>Address | |---------------------------|-----------------|---------|---------|--------|--------|--------|--------|--------|----------------------------| | W | SYNC[2] | SYNC[1] | SYNC[0] | REF[4] | REF[3] | REF[2] | REF[1] | REF[0] | \$11 | | Default Se | etting After Re | eset: | | | | | | | | | | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | | ## REF[4:0] Acquisition Reference Packet Number Defines the number of MPEG-2 packets in which a sync byte is searched for acquisition of synchronisation. SYNC[2:0] Number of Sync Bytes for Acquisition Defines the number of MPEG-2 sync bytes which have to be found for acquisition of synchronisation. ## 4.2.2.2.11 TR\_THRESH Register | Read -<br>Write<br>Access | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | I2C<br>Register<br>Address | |---------------------------|-----------------|---------|---------|--------|--------|--------|--------|--------|----------------------------| | W | SYNC[2] | SYNC[1] | SYNC[0] | REF[4] | REF[3] | REF[2] | REF[1] | REF[0] | \$12 | | Default Se | etting After Re | eset: | | | | | | | _ | | | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | • | | | | - | ## **REF[4:0]** Tracking Reference Packet Number Defines the number of MPEG-2 packets in which a sync byte is searched to remain in sync. SYNC[2:0] Number of Sync Bytes for Tracking Defines the number of MPEG-2 sync bytes which have to be found to remain in sync. #### Read -I2C Write Register 7 6 5 4 3 2 1 0 Access Address \$13 W TC[6] TC[5] TC[4] TC[3] TC[2] TC[1] TC[0] TC[7] Default Setting After Reset: 1 1 1 1 1 1 1 1 ## TC[7:0] Reed-Solomon Time Count Register 4.2.2.2.12 TIME\_COUNT Register Defines the number of MPEG-2 packets during which bad frames and bit errors are counted. The number of packets is given by the formula (TIME\_GOUNT \* 4) + 2, see paragraph 3.2.3.5.4 Reed-Solomon Bit Error and Bad Frame Monitor. ## BER[7:0] Reed-Solomon Bit Error Count Register Reports the number of bit errors detected (and corrected) by the Reed-Solomon decoder that were found during the specified number of packets (using the TIME\_COUNT register mentioned above). Only the 188 bytes of the MPEG-2 packets are considered, not the bit errors found in the checkbytes. Refer to the description of TIME\_COUNT about the update intervals. The register is read only. A write access will not have any effect. ## 4.2.2.2.14 BAD\_COUNT Register | Read -<br>Write<br>Access | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | I2C<br>Register<br>Address | |---------------------------|-----------------|-------|---|---|--------|--------|--------|--------|----------------------------| | R | 0 | 0 | 0 | 0 | BAD[3] | BAD[2] | BAD[1] | BAD[0] | \$19 | | Default Se | etting After Re | eset: | | | | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ## BAD[3:0] Reed-Solomon Bad Frame Count Reports the number of corrupted frames during the time interval defined by TIME\_COUNT. Refer to the description of TIME\_COUNT for further details. The register is read only. A write access will not have any effect. ## 4.2.2.2.15 SYNC\_RS Register | Read -<br>Write | | | | | | | | | I2C | |-----------------|-----------------|-------|---|-----|---|-------|-------|--------|---------------------| | Write<br>Access | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Register<br>Address | | R | 0 | 0 | 0 | 0 | 0 | RERRU | DEINT | INSYNC | \$1A | | Default S | etting After Re | eset: | • | 11, | | | | | _ | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | , | ## **RERRU** A 1 in this bit position indicates that there were uncorrected errors in the MPEG-2 packet just output by the RS decoder. The same information is provided at the output pin TRERROR. ## **DEINT** This bit indicates that the Convolutional Deinterleaver is in sync. ## **INSYNC** The same information is provided at the output pin INSYNC. The register is read only. A write access will not have any effect. #### 4.2.2.2.16 SOFT\_RESET Register | Read -<br>Write<br>Access | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | I2C<br>Register<br>Address | |---------------------------|-----------------|-------|-----|-----|---|-----|----|-----|----------------------------| | R/W | GP3 | GP2 | GP1 | GP0 | 0 | FFT | RS | VIT | \$1F | | Default Se | etting After Re | eset: | | | | | | | , | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | #### **VIT** Writing the sequence of 0 - 1 - 0 into this bit initiates a soft-reset of the Viterbi decoder. #### RS Like the VIT bit before this bit does a soft-reset of the RS decoder. #### **FFT** Like the VIT bit before this bit does a soft-reset of the FFT block. #### **GP[3:0]** These bits set the logic levels at the general purpose output pins. #### 4.3 Tuner Interface The tuner is normally programmed by a microcontroller or the overall system processor via I<sup>2</sup>C interface. It must tune to the OFDM centre frequency of the desired VHF or UHF channel, normally possible offsets are taken into account by the controller. The interface between the tuner and the DVB-T demodulator MC92314 consists of the following signals: - The overall DVB-T system clock of 256/7 ~ 36.57 MHz. - Overall DVB-T system clock divided by 2 (128/7 ~ 18.28 MHz). - 8 bit parallel ADC data (real only), positioned in the IF range using an IF of 32/7 MHz - The VCXO control signal from the OFDM block. - The AGC control signal from the OFDM block. #### 4.3.1 General Tuner Characteristics To work in the appropriate way the tuner part of the DVB-T frontend has to meet the following specifications: Noise figure: 6 dB typical. 8 dB worst case. #### • Third order input intercept point: - >-10 dBm at maximum gain (i.e. when the noise figure meets the number stated above); - >+10 dBm if the frontend gain is reduced by 20 dB; - >+15 dBm at 30 dB gain reduction. - Image rejection: >53 dB. - LO synthesiser step size: dependent from the offset of the OFDM center frequency w.r.t. the centre frequency of the transmission channel. - LO synthesiser phase noise: - >65 dBc between 200 Hz and 2 KHz offset; - >83 dBc at 10 KHz offset: - >130 dBc at offset frequencies above 1.4 MHz. The numbers are obtained using the total LO power relative to the SSB noise power in 1 Hz bandwidth. - Frequency accuracy (measured at channel 69): 1/50 KHz maximum. All impairments of the LO's (e.g. tolerance, temperature drift and ageing) for the conversion from UHF/VHF to 1st IF and the conversion to the 2nd IF must be covered with this value. - 1st IF centre frequency: For the maximum step size (as stated above), an integer multiple of the RF LO synthesiser step size. - Final IF centre frequency (before ADC): 32/7 MHz for 8 MHz channel bandwidth (7.61 MHz used BW); 4 MHz for 7 MHz channels (6.66 MHz used). - ADC output signal SNR: The 'tuner-SNR' must be >33 dB. It is obtained by comparing (at the output of the ADC) the RMS of the OFDM signal (specified in the paragraph '4.3.3 Input from the Tuner Analog to Digital Converter') with all noise and distortion added by the tuner. - **Frequency response:** The following frequency values are relative to the center of the OFDM signal spectrum, the frequency response values are valid for the overall tuner, i.e. from the RF input until the digital output. <3.8 MHz: deviation less than +/-3 dB 4.35 MHz: rejection better than 15 dB 4.7 MHz: rejection better than 30 dB >5.3 MHz: rejection better than 70 dB #### 4.3.2 Clock Signals The overall DVB-T system clock of 256/7 ~ 36.57 MHz is provided by a VCXO in the tuner and must be fed to pin 61 (CLK) of the OFDM device. It is labelled 'clock' in Figure 4-6. Division by 2 provides the ADC clock signal ('clock/2') that is expected at pin 33, CLKEN18. The duty cycle for both signals must be between 40/60 and 60/40 with TTL compatible levels. As the inputs of the OFDM device are 5 V compatible either 3.3 V or 5 V signals are possible. Figure 4-6. Clock and Data phase relationship #### 4.3.3 Input from the Tuner Analog-to-Digital Converter The digital output of the ADC in the tuner must meet the following characteristics: - Format: 8-bit TTL compatible, either 2's complement or offset binary. The format can be set using bit O[17] in OFDM register 2. Default setting is 2's complement. The 8 bits are fed into the ADCDATA[7:0] of the OFDM block. - Sampling frequency: 18.29 MHz = clock/2. - Clocking: See Figure 4-6. Clock frequency is clock/2. The samples are clocked into the OFDM block with the rising edge of the clock signal, using the clock/2 as enable signal. - The rising edge of the 36.57 MHz clock is the active edge to clock the data into the OFDM block. Therefore the data signals should change during the falling edge of the clock/2 signal to minimise the effects of skew, as given in Figure 4-6. - Analog signal before the ADC: The <u>centre frequency</u> of the analog IF signal before the ADC is positioned at an IF of 4.57 MHz. - The OFDM can compensate an <u>offset in frequency</u>, e.g. due to deviations of the local oscillator in the tuner, of +/-50 KHz. - OFDM signal RMS: In the absence of noise or interference the peak to RMS ratio should be 14 dB. In an 8-bit ADC with digital level 128 (peak) this leads to a RMS digital level of 25. #### 4.3.4 Tuner Control signals from the MC92314 The VCXO in the tuner and the AGC amplifier are controlled by the OFDM block by differential $\sigma\delta$ -output lines (...P for positive and ...N for negative direction). The line giving the appropriate polarity should be chosen and fed to a RC lowpass filter to obtain the control voltage to be fed into the tuner. Refer to Section 5 for the appropriate circuit values. Common to the VCXO and the AGC control are the following output characteristics: - Signal level: The voltage level delivered by the device is within the range [0.3 V above V<sub>SS</sub> .. 0.3 V below V<sub>DD</sub>], leading to the range between 0.3 V and 3 V for the nominal supply voltage of 3.3 V. - Maximum current provided: 4 mA #### 4.3.4.1 VCXO Control Loop The differential control lines for the VCXO control are pin 41 (CLKCTLP) and pin 46 (CLKCTLN). The input at the tuner must meet the following characteristics: - VCXO Pulling range: minimum +/-2 KHz, maximum +/-6 KHz. This number applies to the clock signal, **not** to the clock/2 signal. This range must be maintained after taking into account all possible deviations, e.g. tolerance, temperature drift and ageing. - VCXO Quiescent Frequency: to keep the lock time as short as possible the deviation of the VCXO frequency corresponding to the center value of the CLKCTL output voltage should be as close as possible to the nominal frequency of (256 / 7) MHz. For best results is recommended not to exceed +/-10 ppm, this ensures fast response of the time synchronisation circuitry. - **Direction:** The direction of pulling the OFDM device assumes can be set using Bit O[16] of OFDM register 2. Default value is decreasing voltage -> increasing frequency. #### 4.3.4.2 AGC Control Loop The differential control lines for the AGC amplifier control are pin 36 (AGCCTLP) and pin 40 (AGCCTLN). The input at the tuner must meet the following characteristics: - AGC Range: 76 dB minimum for the worst case signal levels (this is dependent upon the sensitivity and the desired range). - Direction: The direction of pulling the OFDM block assumes can be set using Bit O[21] of OFDM register 2. Default value is <u>decreasing voltage</u> -> <u>increasing gain</u>. #### 4.4 MPEG-2 Output Interface of the MC92314 The interface to the MPEG-2 demultiplexer or CA processor after the DVB-T frontend consists of the following lines: MPEG-2 Byte clock: The TRCLOCK output (pin 120) maintains the overall clock of the MPEG-2 transport stream. Its average frequency corresponds to the datarate available for the transmitted DVB-T signal. - MPEG-2 Frame start: The TRSTART output (pin 125) provides one pulse at the start of each transport packet leaving the FEC block. It coincides with the syncbyte in the datastream. - Data Valid indicator: H level at the TRVALID output (pin 121) signals the presence of valid data at the output. - MPEG-2 parallel data: 8 bit parallel data exit at the TRDOUT[7:0] pins. #### 4.5 References [4-1] 2K - Samples FFT Processor. Advance Information on the MC92307 FFT device, available from http://design-net.sps.mot.com/ADC/markets/DSTB/fft.html Preliminary Information Usage and Performance of Motorola's Single-chip DVB-T Device ## SECTION 5 USAGE AND PERFORMANCE OF MOTOROLA'S SINGLECHIP DVB-T DEVICE #### 5.1 Remarks on the Circuit Diagram The basic interconnections to the device are already covered in the description of the DVB-T chipset given in Section 3. In the previous sections also all the information necessary to understand the function of the complete digital frontend are given. Therefore this section deals only with additional information useful for running a practical implementation of the device. The OFDM block generates internally signals for two loops to adjust the clock VCXO and the AGC amplifier in the tuner. This is done by delivering pulse-width modulated signals with one positive and one negative branch each. Depending from the polarity required the correct branch is lowpass filtered using a simple RC filter and fed into the tuner. The voltage swing for each branch is from 0.3 V to 3 V. The circuit values were adapted during the evaluation to the ALPS tuner module, they are given in Figure 5-1: Figure 5-1. LPF values for the OFDM block #### 5.2 Initialising the Chipset In this paragraph the necessary operations for the complete setup of the DVB-T device is described. During the evaluation a DVB-T tuner from ALPS was used, therefore the values are optimised for this. Other tuners may require some adaption. #### Usage and Performance of Motorola's Single-chip DVB-T Device #### 5.2.1 Setup of the OFDM Block #### 5.2.1.1 Registers of the OFDM Block Certain registers of the OFDM block need to be programmed after a hardware reset depending from the hardware of the tuner that is used in a particular design. The registers affected together with default values for the ALPS tuner can be found in the table below: Table 5-1. Initial Setting of the OFDM Registers | Register<br>Address | Register Name | Value | |---------------------|--------------------------------|-------| | \$0D | OFDM register 2 (O[23:16]) | \$D3 | | \$0E | Clock Loop Filter Coefficients | \$FE | #### **NOTE** These values are valid for an ALPS tuner with the CLKCTLP line of the MC92314 used to drive the LPF. After programming of these values it is recommended to do a soft-reset of the OFDM and the FFT device. #### 5.3 Monitoring the DVB-T Single Chip In this paragraph the optional monitoring of the receiving conditions valid for the received transmission channel is described. It may be possible to restrict the monitoring in a stable environment to the observation of the (Transmission Error Indicator -) TEI-bit in the MPEG-2 transport stream packets, nevertheless for diagnostic purposes e.g. antenna setup the status information provided by the devices of the chipset may be helpful. #### 5.3.1 Status Information of the OFDM Block #### 5.3.1.1 Hardware pins - TPSLOCKB (pin 141) is the most sensitive indicator, if L it shows that TPS decoding worked fine. - AFCLOCK (pin 139) & CLKLOCK (pin 138), both active H, indicate that the frequency correction unit achieved lock and the coarse time sync was successful. #### 5.3.1.2 Lock Status Registers - The status of the TPSLOCK pin is recorded in bit [68] of the TPS information. - Also the status of AFCLOCK & CLKLOCK are contained in bits [71] and [70] of the TPS information. Unlike the physical status pins a '1' indicates lock for all three status bits. Note that this register belongs to the TPS register bank. Simply reading the address doesn't work, refer to the description given in paragraph 4.2.2.1 Register Map for the OFDM Part for reading the TPS registers. Usage and Performance of Motorola's Single-chip DVB-T Device #### 5.3.1.3 Usage of the AGC Feedback Register The main purpose of using the AGC Feedback information is to compare different receiving conditions (e.g. during the setup of the antenna). The differences in the AGC Feedback value are correlated with the strength of the input signal (the lower the numbers read from the AGC Feedback registers the lower the gain the tuner is set to). But this holds only in the absence of interference! If interference (echoes or strong signals in adjacent channels or a co-channel transmitter) occurs, the AGC Feedback value obviously shows a very strong signal, but the signal strength monitored has no obvious relation to the desired OFDM signal. So to use the AGC information successfully it must be ensured that the antenna is adjusted initially towards the transmitter delivering the intended OFDM signal. Furthermore, once the OFDM is synchronised onto the transmitter and the Node synchroniser in the Viterbi decoder has locked, it is recommended to derive the quality information from the QVAL values of the Viterbi decoder. #### 5.3.2 Status Information of the FEC Block #### 5.3.2.1 Hardware Pins - VLOCK (pin 142) shows the lock condition of the Node Synchroniser in the Viterbi decoder. Use it with caution, the VLOCK pin alone is not a reliable indication for error-free reception. - INSYNC (pin 143): H level indicates that the Frame Synchroniser after the Viterbi decoder is in lock. - TRERROR (pin 130) is the most reliable indicator for correct decoding of the MPEG-2 transport stream. Hevel indicates that the RS decoder detected uncorrectable errors. #### 5.3.2.2 Software Registers - The QVAL registers provide information for an estimation of the channel quality. They have their roots in the FEC for the satellite system, therefore the internal calculations are normalised to the AWGN channel. Because the conditions for terrestrial reception are completely different the SNR values calculated with these registers don't reflect the real SNR in the terrestrial transmission, nevertheless they provide useful information about the overall channel quality. - All the functional blocks in the FEC part can be monitored: The signals VLCK, INSYNC, DEINT and RERRU are available as status bits. - The BAD COUNT register contains information on erroneous transport packets in a certain interval, its use is useful at the edges of the coverage area. #### 5.3.2.3 FEC Block QVAL Values corresponding to BER values In paragraph 3.2.3.2.7 a formula is given to estimate the BER from the QVAL values. Using Figure 3-10 and Figure 3-8 it is possible to estimate the BER from the QVAL values. In the table below the values for the BER of 2 \* 10<sup>-4</sup> are given for all coderates. Using these values (it is Usage and Performance of Motorola's Single-chip DVB-T Device recommended to use the moving average instead of single values) the decision below/above the QEF threshold is possible. Table 5-2. QVAL Values for BER QEF | Coderate | $\mathbf{p_0}$ | QVAL | |----------|----------------|--------| | 1/2 | 0.610 | \$18F6 | | 2/3 | 0.705 | \$12E1 | | 3/4 | 0.740 | \$10A4 | | 5/6 | 0.795 | \$0D1F | | 7/8 | 0.850 | \$099A | If an estimate for the BER is required from the QVAL the following procedure can be used: - Calculate the p<sub>0</sub> value from the QVAL according to the formula given in paragraph 3.2.3.2.7. - Get the corresponding E<sub>b</sub>/N<sub>0</sub> from Figure 3-10, take into account the different curves for the different coderates. - Using Figure 3-8 the BER estimate is available using the E<sub>b</sub>/N<sub>0</sub> curve corresponding to the same coderate. #### 5.4 Performance Considerations #### 5.4.1 Possible Changes in the OFDM Block #### 5.4.1.1 Speeding up the Acquisition Time All the actions necessary to acquire the MPEG-2 transport stream out of the sampled IF signal from the tuner are performed fully automatic once the tuner is set to the appropriate channel. This includes the synchronisation of the OFDM demodulator, the VCXO and AGC loops as well as the FEC part. This fully automatic process can be adjusted to the tuner used in a certain application to result in a shorter locktime. #### **NOTE** The hints given in this paragraph lead to configuration parameters highly dependent from the tuner hardware used and from the specific application. The values found to be optimal for one application may lead to different results in another environment. Usage and Performance of Motorola's Single-chip DVB-T Device #### 5.4.1.1.1 Changing AFC Sweep Start The AFC loop (described in paragraph 3.2.2.2) can be controlled by setting the parameters used during the initial sweep during acquisition. It is possible to adjust the speed as well as the starting point of the sweep (refer to paragraph 4.2.2.1.7 and paragraph 4.2.2.1.10). The current position of the AFC is reported in the AFC Feedback register (see paragraph 4.2.2.1.14). This number gives an indication of the LO offset in the tuner w.r.t. the center frequency of the current RF channel. To shorten the sweep time it is possible to use this feedback value. During normal operation or just before a channel change the value should be read by system controller and stored. As the LO offset maybe slighthly different for different RF channels, the new center frequency can be taken into account together with the feedback value to calculate an expectation for the new LO offset. Depending from the usual sweep direction this value should be *decreased* (*upward sweep*) or <u>increased</u> (<u>downward sweep</u>), e.g. by app. \$120 for a deviation of 10 KHz. If the new position is close to the lower edge of the range it may be useful to chose downward sweep and to increase the number. This results in the following recommended procedure associated with a channel change: - Read the AFC Feedback register and calculate the expectation for the new channel. - Program the tuner to the new channel, observe possible offsets in frequency. - Program the AFC start value in the appropriate register (2 byte I<sup>2</sup>C write). - Issue a soft reset for the QFDM part to force a new AFC sweep. These steps ensure that the AFC sweep starts near the point were the AFC circuit should find its final lock position. The deviation used must be searched by evaluating different distances, depending e.g. from the settling time of the tuner, the precision of the tuner LO or the other components that are controlled by the OFDM block like VCXO or AGC amplifier. Note that changing the AFC sweep start may have no effect in poor reception conditions. The reason for this is that in these cases several sweeps by the AFC circuit may be necessary. The value stored in the sweep start register is used only after a soft reset. If the sweep comes to the end of its range it starts at the opposite end instead of the sweep start position. This prevents unintentional conditions were lock can never be achieved because the position the AFC is looking for is outside of the sweep range. #### **5.4.1.1.2 Changing AGC Integrator Gain** Additional increase in acquisition speed may be possible by changing the gain of the AGC integrator during this phase. This loop defaults to be stable in all circumstances to allow for resolving the amplitude differences of 64-QAM. The default value (2's complement number) for normal operation is a small negative number. During the acquisition phase it may be tolerable to set it to a positive value (app. \$4) to increase the speed of the AGC control signal. Usage and Performance of Motorola's Single-chip DVB-T Device Especially in reception environments impaired by echoes or CCI transmissions it is essential to decrease the value if lock has been achieved to ensure stable behaviour of the AGC loop. #### 5.4.1.2 Co-Channel Protection vs. Noise As already mentioned in paragraph 4.2.2.1.11 the generation of the soft-decision information for the Viterbi decoder is optimised for best noise performance. Depending from the transmission environment it may be desirable to achieve better CCI performance at a very small penalty on the noise performance. This can be achieved by changing the CSE register using the values given in the table below: Table 5-3. CSE Register Values optimised for CCI Performance | Register<br>Address | Register Name | Initial Value | New Value | |---------------------|--------------------|---------------|-----------| | \$17 | CSE 0 (CSE[7:0]) | \$C5 | \$74 | | \$18 | CSE 1 (CSE[15:8]) | \$D2 | \$77 | | \$19 | CSE 2 (CSE[23:16]) | \$DF | \$7A | | \$1A | CSE 3 (CSE[31:24]) | \$10 | \$01 | #### 5.4.2 Possible Changes in the FEC Block #### 5.4.2.1 Fixing the Coderate for the Viterbi Decoder It is part of the usual lock procedure for the FEC to figure out the FEC parameters of the DVB-T signal received. The time necessary for this may be reduced by using the readily available FEC information transmitted via the TPS channel. To shorten the time necessary for the Viterbi decoder to synchronise on the datastream simply read the coderate from OFDM register 0 and program it into the CONFIG\_VIT register as it is described in paragraph 4.2,2.2.1. The time to allow the demodulator device to lock onto the TPS and to make the checked parameters readable in OFDM register 0 is dependent from the signal quality and the tuner design, it has to be investigated with the whole frontend in place. #### 5.4.2.2 Adjusting the MPEG Frame Synchroniser The function of this functional block is described in detail in paragraph 3.2.3.3. It works on the hexadecimal values of the MPEG-2 sync bytes (\$47 and \$B8 resp.) that are of course present in the normal payload. Depending on the characteristics of the MPEG-2 stream transmitted an adjustment of the AQ\_THRESH or the TR\_THRES registers may be necessary to prevent the MPEG frame synchroniser to lock on payload bytes erroneously. In case the frame synchroniser indicates that it is in lock and remains there the system controller may check the RERRU signal. If it persists to show values other than 0 this is either an indication that the received RF signal is so bad that no reliable reception is necessary or that (very rarely) a false lock occured. Usage and Performance of Motorola's Single-chip DVB-T Device In this case reprogramming the AQ\_THRES to a slightly higher forces the synchroniser in the aquisition mode again and requires a larger number of syncbytes to be found before changing to the tracking mode. Of course this reprogramming of the ..\_THRESH values must be repeated after a hardware reset of the MC92314. #### 5.5 MC92314 Performance The overall BER performance matches the requirements as defined in the DVB-T specification (see reference [1-1]), Annex A with a degradation margin of 3 dB. #### 5.5.1 Performance in a typical Consumer Application Preliminaryly #### 5.5.1.1 Typical Lock Performance The following figures show typical lock performance measured with the ALPS tuner mentioned before. Again the setup used was 64-QAM, coderate $^2/_3$ and guard interval $^1/_{32}$ in RF channel 68 (center frequency 850 MHz). In the following traces the upper channel indicates the AGC status of the tuner (AGC1, Pin#2) and the lower trace shows the RERRU pin of the FEC block. Usage and Performance of Motorola's Single-chip DVB-T Device Figure 5-2. Typical Lock Performance, #1 (fina2710.eps) Usage and Performance of Motorola's Single-chip DVB-T Device Figure 5-3. Typical Lock Performance, #2 (bsta2710.eps) From the figures above it can be seen that the typical lock time from the tuner to the transport stream output is around 200 ms. #### 5.5.1.2 Noise and Interference Performance Using a tuner together with the single-chip device MC92314 builds a complete frontend module for terrestrial DVB reception. To obtain typical performance values for a consumer-type frontend Motorola uses DVB-T tuners from ALPS together with the MC92314 on the demonstration boards. Typical values for certain performance measurements obtained with one of this boards (tuner model TDLB7X207A) are given in the table below: **Table 5-4. Typical Performance Values** | PARAMETER | VALUE | NOTE | |-----------------------------|---------|------| | Gaussian Noise | 19.5 dB | - | | Co-Channel PAL Interference | 1 dB | 1 | Usage and Performance of Motorola's Single-chip DVB-T Device **Table 5-4. Typical Performance Values** | PARAMETER | VALUE | NOTE | |-----------------------------------|--------|------| | Adjacent Channel PAL Interference | t.b.d. | | | One Echo of 0 dB | t.b.d. | | | Multipath Reception | t.b.d. | | #### NOTE The modulation scheme chosen was 64-QAM, coderate $^2/_3$ and guard interval $^1/_{32}$ . The failure point was defined to be a BER of 2 \* $10^{-4}$ at the output of the Viterbi decoder. The RF signal was transmitted in UHF channel 34. For the CSE registers in the MC92314 the values from Table 5-3 were used. - 1. Co-Channel PAL-I interference was provided via a UHF TV modulator with 75% colour bars, 1 kHz sound and PRBS Nicam. Using the the DVB-T local oscillator at the exact center frequency resulted in 1 dB (OFDM power 1 dB greater than PAL peak sync power). Changing the local oscillator frequency in small steps to simulate transmitters not synchronised resulted in a change of the protection ratio between 0 and 3 dB. - 2. ... # Preliminar 5.6 References ### SECTION 6 ELECTRICAL CHARACTERISTICS #### 6.1 MC92314 Electrical Considerations The power consumption of the device at full operation is app. 1.7 W in a typical DVB-T application, details are given below. The supply voltage for the MC92314 is 3.3 V. Using two samples of the MC92314 the current consumption in different modes of operation was measured. The supply voltage was 3.3 V. The results are given in Table 6-1 and Figure 6-1 below: Table 6-1. Current and Power Ponsumption at different datarates | | USEFUL | SAM | PLE 1 | SAMPLE 2 | | | |----------------------------------------------------------------------------------|----------------------|-----------------|--------------|-----------------|--------------|--| | CONFIGURATION | DATARATE<br>(MBit/s) | CURRENT<br>(mA) | POWER<br>(W) | CURRENT<br>(mA) | POWER<br>(W) | | | QPSK, coderate $^2/_3$ , G.I. $^1/_{32}$ | 8.04 | 460 | 1.52 | 470 | 1.55 | | | 16-QAM, coderate <sup>2</sup> / <sub>3</sub> , G.I. <sup>1</sup> / <sub>32</sub> | 16.09 | 485 | 1.60 | 490 | 1.62 | | | 64-QAM, coderate <sup>2</sup> / <sub>3</sub> , G.Î. <sup>1</sup> / <sub>32</sub> | 24.13 | 510 | 1.68 | 520 | 1.72 | | | 64-QAM, coderate <sup>7</sup> / <sub>8</sub> , G.h. <sup>1</sup> / <sub>32</sub> | 31.67 | 530 | 1.75 | 535 | 1.77 | | #### **NOTE** The figures for the useful datarate are taken from the DVB-T specifictaion reference [1-1], they give the datarate of the MPEG-2 transport stream at the output of the MC92314. It can be seen that the maximum supply current in the mode with the highest datarate doesn't exceed 535 mA, leading to a power consumption of about 1.77 W. In the figure below the mean value of both samples is drawn versus the useful datarate: 6.2 MC92314 DC Electrical Specifications t.b.d. PreliminaryInformation #### 6.3 MC92314 Timing Characteristics The timing characteristics of the MC92314 device are given in Figure 6-2 and Table 6-2: Figure 6-2. MC92314 Timing Characteristics #### Table 6-2. MC92314 Timing | No. | Characteristic | min | max | unit | |-----|-----------------------------|----------|------|------| | 1 | CLKEN18 to CLK setup time | | 6.0 | ns | | 2 | CLKEN18 to CLK hold time | | -0.7 | ns | | 3 | ADCDATA to CLK setup time | | 6.6 | ns | | 4 | ADCDATA to CLK hold time | | 0.6 | ns | | 5 | MSDA to CLK setup time | | 1.6 | ns | | 6 | MSDA to CLK hold time | | 1.4 | ns | | 5 | MSCL to CLK setup time | | 0.6 | ns | | 6 | MSCL to CLK hold time | <b>√</b> | 1.6 | ns | | 7 | RESB to CLK setup time | .0 | 18.8 | ns | | 8 | RESB to CLK hold time | X | 0 | ns | | 9 | CLK to AGCCTRLP/N out delay | 5.4 | 22.0 | ns | | 9 | CLK to CLKCTLP/N out delay | 5.0 | 18.1 | ns | | 10 | CLK to TRCLK out delay | 7.5 | 23.4 | ns | | 10 | CLK to TRSTART out delay | 7.8 | 25.1 | ns | | 10 | CLK to TRVALID out delay | 7.7 | 25.1 | ns | | 10 | CLK to TRERROR out delay | 7.0 | 21.9 | ns | | 11 | CLK to TRDOUT out delay | 6.9 | 25.5 | ns | | 12 | CLK period | 27.4 | | ns | Preliminary Information ## SECTION 7 MECHANICAL CHARACTERISTICS #### 7.1 Outlines of the 160PQFP Package The mechanical dimensions of the 160PQFP package (package code 864A-01) that is used for this device is shown below in Figure 7-1: PreliminaryInformation Figure 7-1. Mechanical Data of the 160QFP Package #### 7.2 Outlines of the 169BGA Package The mechanical details of the BGA package are shown in Figure 7-2 and Figure 7-3 above: PreliminaryInformation Figure 7-2. 169BGA Package, Drawing #1 | (M) MOTOROLA | MECHANICAL OUTLINES | | | | 98ASS23748W | | | |-------------------------------------------------|---------------------|-------|------|-----------|-------------|---|------| | Semiconductor Products Sector | DICTIONARY | | | PAGE 1140 | | ) | | | COPYRIGHT 1997 MOTOROLA INC ALL RIGHTS RESERVED | DO NOT | SCALE | THIS | DRAWING | ISSUE | 0 | DATE | #### NOTES - 1. DIMENSIONS AND TOLERANCING PER ASME Y14.5-1994. - 2. DIMENSIONS IN MILLIMETERS. - DIMENSION IS MEASURED AT THE MAXIMUM SOLDER BALL DIAMETER, PARALLEL TO PRIMARY DATUM A. - 4. PRIMARY DATUM A AND THE SEATING PLANE ARE DEFINED BY THE SPHERICAL CROWNS OF THE SOLDER BALLS. | | MILLIMETERS | | INC | HES | | MILLIN | 1ETERS | INC | HES | |---------------------------------------|--------------------------------------------|-------------------------------------------------------------------------------------------|-----|-----|-----|--------|----------|------|-----| | DIM | MIN | I MAX | MIN | MAX | DIM | MIN | MAX | MIN | MAX | | A A 1 A 2 A 3 b D D 1 D 2 E E 1 E 2 e | 14.4<br>16.8 | 0.70<br>0.36<br>9.0.89<br>0.90<br>0.17.20<br>0.24 REF<br>10.14.60<br>0.24 REF<br>10.14.60 | | | | | | | | | CASE NO. 1140-01 | | | | | | | | | | | STANDARD JEDEC MO-151 BAF | | .51 BAF-1 | | | | | | | | | REFERENCE | | | | | | | | | | | TITL | TITLE 169 PBGA (OM)<br>17 X 17, 1.27 PITCH | | | | | | SHEET 20 | )F 2 | | Figure 7-3. 169BGA Package, Drawing #2 Preliminary Information