

# DUAL INTERMEDIATE FREQUENCY (IF) ANALOG FRONT-END FOR DIGITAL RADIO

#### **FEATURES**

- Qualified for Automotive Applications
- Two Intermediate Frequency (IF)
   Analog-to-Digital Converters (ADCs)
- Two 12-Bit Auxiliary Digital-to-Analog Converters (DACs)
- 8-Bit Auxiliary ADCs with Four-Channel Input Multiplexer (MUX)
- Integrated IF Digital Processing Core
- Integrated Circuitry for Third-Overtone Master Clock Oscillator
- Wakeup Circuit/Real-Time Clock With Separate Crystal Oscillator

- Flexible Data Interface Optimized for TMS Family of Digital Baseband Processors
- Pin-Selectable SPI<sup>™</sup> and I<sup>2</sup>C<sup>™</sup> Control Interfaces
- 3.3-V/1.8-V Supply (Integrated Regulator Available to Optionally Generate 1.8-V Supply)
- TQFP-144 (RFP) PowerPAD™ Package

### **APPLICATIONS**

- IF-Sampled AM/FM Radio
- Hybrid Digital (HD) Digital Audio Broadcasting (DAB) Digital Radio

### **DESCRIPTION**

The AFE8221 implements the intermediate frequency (IF) sampling and processing functions of a digital radio receiver system. It is designed to be used with TI's digital radio baseband processors and AM/FM tuners. The AFE8221 can also be programmed by the baseband processor for use in conventional AM/FM and digital radio. This unit includes two IF inputs with associated filtering and digital processing circuitry.

The receive circuit oversamples the radio tuner IF output to reduce noise and improve dynamic range. The IF analog-to-digital converter (ADC) oversamples the IF input at rates up to 75 MHz. The AFE8221 then digitally mixes, filters, and decimates the signal to provide I and Q output signals to the baseband processor. A clock oscillator circuit is provided that can be used with an appropriate third-overtone crystal and external tank circuit to generate the sampling clock for the IF ADCs.

The AFE8221 also includes a real-time clock and associated low-power oscillator circuit. Two auxiliary digital-to-analog converters (DACs) are included for system control functions. An 8-bit auxiliary ADC and input multiplexer (MUX) can be used for system diagnostic functions. Other features include 12 general-purpose input/output (GPIO) lines, programmable interrupt generators, and an I<sup>2</sup>C master for communication between the AFE and the tuner(s).

The AFE8221 is available in a TQFP-144 (20 mm × 20 mm) package and uses a 3.3-V and a 1.8-V power supply. An onboard voltage regulator is included to optionally generate the 1.8-V digital supply for the AFE8221.

#### ORDERING INFORMATION(1)

| T <sub>A</sub> | PACKAGE <sup>(2)</sup> |            | ORDERABLE PART NUMBER | TOP-SIDE MARKING |
|----------------|------------------------|------------|-----------------------|------------------|
| –40°C to 85°C  | HTQFP – RFP            | Tray of 60 | AFE8221IRFPQ1         | AFE8221Q         |

- (1) For the most current package and ordering information, see the Package Option Addendum at the end of this document, or see the TI web site at www.ti.com.
- (2) Package drawings, thermal data, and symbolization are available at www.ti.com/packaging.



Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet.

PowerPAD is a trademark of Texas Instruments. SPI is a trademark of Motorola, Inc. I2C is a trademark of NXP Semiconductors.





This integrated circuit can be damaged by ESD. Texas Instruments recommends that all integrated circuits be handled with appropriate precautions. Failure to observe proper handling and installation procedures can cause damage.

ESD damage can range from subtle performance degradation to complete device failure. Precision integrated circuits may be more susceptible to damage because very small parametric changes could cause the device not to meet its published specifications.

# **ABSOLUTE MAXIMUM RATINGS**(1)

over operating free-air temperature range (unless otherwise noted)

|                  |                                      | AVDD          | –0.5 V to 3.6 V          |
|------------------|--------------------------------------|---------------|--------------------------|
|                  | Supply voltage range                 | DVDD          | –0.5 V to 3.6 V          |
|                  |                                      | IOVDD         | -0.5 V to 3.6 V          |
|                  | Voltage between                      | AGND to DGND  | -0.3 V to 0.5 V          |
|                  | Voltage between                      | AVDD to DVDD  | −3.3 V to 3.3 V          |
| $V_{IN}$         | Digital input voltages (2)           |               | -0.3 V to (DVDD + 0.3 V) |
| $V_{OUT}$        | Digital data output voltage          |               | -0.3 V to (DVDD + 0.3 V) |
| T <sub>A</sub>   | Operating free-air temperature range | -40°C to 85°C |                          |
| T <sub>stg</sub> | Storage temperature range            |               | -55°C to 125°C           |

<sup>(1)</sup> Stresses beyond those listed under absolute maximum ratings may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under recommended operating conditions is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

### RECOMMENDED OPERATING CONDITIONS

over operating free-air temperature range (unless otherwise noted)

|                 | PARAMETER                                | MIN         | TYP | MAX          | UNIT     |
|-----------------|------------------------------------------|-------------|-----|--------------|----------|
| AVDD            | Analog supply voltage                    | 3.14        | 3.3 | 3.6          | V        |
| DVDD            | Digital supply voltage                   | 1.6         | 1.8 | 2.0          | V        |
| IOVDD           | Output driver supply voltage             | 1.6         |     | 3.6          | V        |
|                 | Input common-mode voltage                |             | VCM |              | V        |
|                 | Differential input voltage               |             | 2   |              | $V_{PP}$ |
| V <sub>IH</sub> | High-level input voltage, digital inputs | 0.7 × IOVDD |     |              | V        |
| V <sub>IL</sub> | Low-level input voltage, digital inputs  |             |     | 0.25 × IOVDD | V        |
| T <sub>A</sub>  | Operating free-air temperature           | -40         |     | +85          | °C       |

Submit Documentation Feedback

<sup>(2)</sup> Measured with respect to DGND.

## **POWER SUPPLY SPECIFICATIONS**

 $T_A = 25$ °C, AVDD = IOVDD = 3.3 V, DVDD = 1.8 V (unless otherwise noted)

| PARAMETER                  | TEST CONDITIONS                          | MIN TYP | MAX | UNIT |  |  |
|----------------------------|------------------------------------------|---------|-----|------|--|--|
| Power Consumption          |                                          | ·       |     |      |  |  |
| Analog supply current      |                                          | 130     | 155 | mA   |  |  |
| Digital supply current     | REG_ENB disabled                         | 65      | 85  | mA   |  |  |
| Digital I/O august august  | REG_ENB disabled                         | 35      | 50  | mA   |  |  |
| Digital I/O supply current | REG_ENB enabled                          | 105     | 125 | mA   |  |  |
| Davis dissination          | REG_ENB disabled                         | 660     |     | mW   |  |  |
| Power dissipation          | REG_ENB enabled                          | 725     |     | mW   |  |  |
| Reduced-Power Modes        |                                          |         |     |      |  |  |
| Software power-down        | Control register address 1 set to 0x0000 | 100     |     | mW   |  |  |
| Hardware power-down        | PWD enabled                              | 50      |     | μW   |  |  |

## IF ADC SPECIFICATIONS

 $T_A = 25$ °C, AVDD = IOVDD = 3.3 V, DVDD = 1.8 V,  $f_S = 75$  MHz (unless otherwise noted)

|                        | PARAMETER                              | TEST CONDITIONS                              | MIN | TYP | MAX | UNIT     |
|------------------------|----------------------------------------|----------------------------------------------|-----|-----|-----|----------|
| DC Acc                 | curacy                                 |                                              | ,   |     | ,   |          |
| Input im               | npedance                               |                                              |     | 2   |     | kΩ       |
| Offset e               | error                                  |                                              |     | 3.0 |     | mV       |
| Gain er                | ror                                    |                                              |     | 1.0 |     | %FS      |
| Full see               | de ienad level                         | Peak differential, 1x gain                   |     | 2.0 |     | $V_{PP}$ |
| Full-scale input level |                                        | Peak differential, 2x gain                   |     | 1.0 |     | $V_{PP}$ |
| Power :                | Supply                                 |                                              | •   |     | ·   |          |
| PSRR                   | Power-supply rejection ratio           | AVDD = 3.15 VDC to 3.6 VDC                   |     | 72  |     | dB       |
| Referer                | nces                                   |                                              |     |     |     |          |
| REFP                   | Positive reference                     |                                              | 1.9 | 2.0 | 2.1 | V        |
| REFN                   | Negative reference                     |                                              | 0.9 | 1.0 | 1.1 | V        |
| VCM                    | Common-mode voltage                    |                                              | 1.4 | 1.5 | 1.6 | V        |
| AC Per                 | formance                               |                                              |     |     |     |          |
| Input sa               | ample rate                             |                                              | 75  |     |     | MHz      |
| CNID                   | Signal-to-noise ratio within a limited | Input 10.7 MHz, -1 dBFS, in 3-kHz passband   |     | 105 |     | -ID-     |
| SNR                    | passband                               | Input 10.7 MHz, -1 dBFS, in 100-kHz passband | 85  | 90  |     | dBc      |
|                        | Third-order intermodulation            | -7-dB signals at 10.656 MHz and 10.729 MHz   |     | 91  |     | ٩D       |
|                        | distortion                             | -10-dB signals at 10.656 MHz and 10.729 MHz  |     | 94  |     | dB       |
| SFDR                   | Spurious-free dynamic range            | -1-dB input at 10.7 MHz, 100-kHz passband    | 88  | 96  |     | dBc      |



## **AUXILIARY DAC SPECIFICATIONS**

T<sub>A</sub> = 25°C, AVDD = IOVDD = 3.3 V, DVDD = 1.8 V (unless otherwise noted)

| PARAMETER            | TEST CONDITIONS                              | MIN TYP | MAX | UNIT     |
|----------------------|----------------------------------------------|---------|-----|----------|
| Resolution           |                                              | <u></u> |     |          |
| Resolution           |                                              | 12      |     | Bits     |
| Output Voltage Range |                                              |         | •   |          |
| Output voltage range | Input code 0x000                             | 0       |     | V        |
|                      | Input code 0x3FF                             | 2.7     |     | V        |
| Settling Time        |                                              |         |     |          |
| Settling time        | 0.1% of FSR                                  |         | 10  | μs       |
| DC Performance       |                                              |         | •   |          |
| Offset               |                                              | ±1      |     | % of FSR |
| Gain error           |                                              | ±5      |     | % of FSR |
| DNL                  | Monotonic ±0.5                               |         |     | LSB      |
| INL                  | Offset and gain errors removed               | ±3.0    | LSB |          |
| PSRR                 | Input code 0x200, AVDD = 3.15 VDC to 3.6 VDC | 30      | dB  |          |

# **AUXILIARY ADC SPECIFICATIONS**

 $T_A = 25$ °C, AVDD = IOVDD = 3.3 V, DVDD = 1.8 V (unless otherwise noted)

| PARAMETER           | TEST CONDITIONS                            | MIN      | TYP  | MAX  | UNIT        |
|---------------------|--------------------------------------------|----------|------|------|-------------|
| Resolution          |                                            | <u>.</u> |      |      |             |
| Resolution          |                                            |          | 10   |      | Bits        |
| Input Voltage Range | ,                                          | ,        |      |      |             |
| Input voltage range | Input code 0x00                            |          | 0    |      | V           |
|                     | Input code 0xFF                            |          | 3.0  |      | V           |
| Input Impedance     |                                            | <u>.</u> |      |      |             |
| Input impedance     |                                            |          | 30   |      | kΩ          |
| Conversion Time     |                                            |          |      |      |             |
| Conversion Time     |                                            |          |      | 8704 | MCLK cycles |
| DC Performance      |                                            |          |      |      |             |
| Offset              |                                            |          | ±1.0 |      | % of FSR    |
| Gain error          |                                            |          | ±1.5 |      | % of FSR    |
| DNL                 | Monotonic                                  | -1.0     |      | 1.5  | LSB         |
| INL                 | Offset and gain errors removed             | -1.5     | ±0.5 | 1.5  | LSB         |
| PSRR                | Midscale input, AVDD = 3.15 VDC to 3.6 VDC |          | 30   |      | dB          |

## **DIGITAL I/O SPECIFICATIONS**

 $T_A = 25$ °C, IOVDD = 3.3 V (unless otherwise noted)

|                 | PARAMETER                 | TEST CONDITIONS                  | MIN         | TYP MAX     | UNIT |
|-----------------|---------------------------|----------------------------------|-------------|-------------|------|
| I <sub>IH</sub> | High-level input current  | V <sub>IH</sub> = 1.6 V to 3.6 V | -10         | 10          | μΑ   |
| I <sub>IL</sub> | Low-level input current   | V <sub>IL</sub> = 0 V to 0.4 V   | -10         | 10          | μΑ   |
| $V_{OH}$        | High-level output voltage | $I_{OH} = -50 \mu A$             | 0.8 × IOVDD |             | V    |
| V <sub>OL</sub> | Low-level output voltage  | I <sub>OL</sub> = 50 μA          |             | 0.2 × IOVDD | V    |

## **CLOCK OSCILLATOR SPECIFICATIONS**

T<sub>A</sub> = 25°C, DVDD = 1.8 V, IOVDD = 3.3 V (unless otherwise noted)

| PARAMETER  |                   | TEST CONDITIONS                         |    | TYP MAX | UNIT |
|------------|-------------------|-----------------------------------------|----|---------|------|
| $f_{XTAL}$ | Crystal frequency | See the Master Clock Oscillator section | 20 | 75      | MHz  |



## **FUNCTIONAL BLOCK DIAGRAM**





www.ti.com

# **TERMINAL ASSIGNMENTS**

TQFP-144 **Top View** 





## **TERMINAL FUNCTIONS**

| TERMINAL |     | FUNCTION      | DESCRIPTION                               |
|----------|-----|---------------|-------------------------------------------|
| NAME     | NO. |               |                                           |
| NC       | 1   | Open          | No connect                                |
| NC       | 2   | Open          | No connect                                |
| NC       | 3   | Open          | No connect                                |
| AUX_ADC0 | 4   | Analog input  | Auxiliary ADC channel 0                   |
| AUX_ADC1 | 5   | Analog input  | Auxiliary ADC channel 1                   |
| AUX_ADC2 | 6   | Analog input  | Auxiliary ADC channel 2                   |
| AUX_ADC3 | 7   | Analog input  | Auxiliary ADC channel 3                   |
| AVDD1    | 8   | Supply        | 3.3-V analog supply (internally switched) |
| CDAC0    | 9   | Output        | Control DAC 0 output                      |
| AVSS     | 10  | Ground        | Analog ground                             |
| CDAC1    | 11  | Output        | Control DAC 1 output                      |
| AVDD1    | 12  | Supply        | 3.3-V analog supply (internally switched) |
| AVDD1    | 13  | Supply        | 3.3-V analog supply (internally switched) |
| AVSS     | 14  | Ground        | Analog ground                             |
| AVSS     | 15  | Ground        | Analog ground                             |
| AVSS     | 16  | Ground        | Analog ground                             |
| IF_INP0  | 17  | Input         | IF ADC channel 0 positive input           |
| IF_INM0  | 18  | Input         | IF ADC channel 0 negative input           |
| IF_VCM   | 19  | Output        | IF ADC common-mode voltage                |
| IF_REFP  | 20  | Output        | IF ADC positive reference                 |
| IF_REFM  | 21  | Output        | IF ADC negative reference                 |
| AVSS     | 22  | Ground        | Analog ground                             |
| AVDD1    | 23  | Supply        | 3.3-V analog supply (internally switched) |
| AVDD1    | 24  | Supply        | 3.3-V analog supply (internally switched) |
| AVSS     | 25  | Ground        | Analog ground                             |
| AVSS     | 26  | Ground        | Analog ground                             |
| IF_BIAS  | 27  | Input         | IF ADC bias input                         |
| AVSS     | 28  | Ground        | Analog ground                             |
| IF_INM1  | 29  | Input         | IF ADC channel 1 negative input           |
| IF_INP1  | 30  | Input         | IF ADC channel 1 positive input           |
| AVSS     | 31  | Ground        | Analog ground                             |
| AVSS     | 32  | Ground        | Analog ground                             |
| AVSS     | 33  | Ground        | Analog ground                             |
| AVDD1    | 34  | Supply        | 3.3-V analog supply (internally switched) |
| NC       | 35  | Open          | No connect                                |
| NC       | 36  | Open          | No connect                                |
| AVDD     | 37  | Supply        | 3.3-V analog supply                       |
| AVDD     | 38  | Supply        | 3.3-V analog supply                       |
| AVDD     | 39  | Supply        | 3.3-V analog supply                       |
| AVDD     | 40  | Supply        | 3.3-V analog supply                       |
| NC       | 41  | Open          | No connect                                |
| SDA1     | 42  | Bidirectional | Channel 1 tuner I <sup>2</sup> C data     |
| SCL1     | 43  | Output        | Channel 1 tuner I <sup>2</sup> C clock    |
| AVSS     | 44  | Ground        | Analog ground                             |
| AVDD     | 45  | Supply        | 3.3-V analog supply                       |
| REFCLK   | 46  | Output        | Inverted reference clock output           |



# **TERMINAL FUNCTIONS (continued)**

| TERMIN   | IAL |          |                                            |
|----------|-----|----------|--------------------------------------------|
| NAME     | NO. | FUNCTION | DESCRIPTION                                |
| REFCLK   | 47  | Output   | Reference clock output                     |
| AVSS     | 48  | Ground   | Analog ground                              |
| DVSS     | 49  | Ground   | Digital ground (for MCLK oscillator)       |
| MCLKI    | 50  | Input    | MCLK oscillator input                      |
| MCLKO    | 51  | Output   | MCLK oscillator output                     |
| DVDD2    | 52  | Supply   | 1.8-V digital supply (for MCLK oscillator) |
| AVSS     | 53  | Ground   | Analog ground                              |
| AVDD     | 54  | Supply   | 3.3-V analog supply                        |
| AVSS     | 55  | Ground   | Analog ground                              |
| DVDD     | 56  | Supply   | 1.8-V digital supply                       |
| IOVDD    | 57  | Supply   | 3.3-V digital I/O supply                   |
| DVSS     | 58  | Ground   | Digital ground                             |
| IOVSS    | 59  | Ground   | Digital I/O ground                         |
| BB_WS    | 60  | Output   | Secondary baseband word select             |
| BB_BCK   | 61  | Output   | Secondary baseband word bit clock          |
| BB_IDAT0 | 62  | Output   | Secondary baseband channel 0 output (I)    |
| BB_QDAT0 | 63  | Output   | Secondary baseband channel 0 output (Q)    |
| BB_IDAT1 | 64  | Output   | Secondary baseband channel 1 output (I)    |
| BB_QDAT1 | 65  | Output   | Secondary baseband channel 1 output (Q)    |
| GRST     | 66  | Input    | Global reset (active low)                  |
| WAKEUP   | 67  | Output   | WAKEUP interrupt output                    |
| IRQ0     | 68  | Output   | Interrupt output 0                         |
| IRQ1     | 69  | Output   | Interrupt output 1                         |
| IRQ2     | 70  | Output   | Interrupt output 2                         |
| PWD      | 71  | Input    | Power-down pin (active high)               |
| RST      | 72  | Input    | Reset pin (active low)                     |
| NC       | 73  | Open     | No connect                                 |
| NC       | 74  | Open     | No connect                                 |
| NC       | 75  | Open     | No connect                                 |
| NC       | 76  | Open     | No connect                                 |
| NC       | 77  | Open     | No connect                                 |
| NC       | 78  | Open     | No connect                                 |
| NC       | 79  | Open     | No connect                                 |
| NC       | 80  | Open     | No connect                                 |
| NC       | 81  | Open     | No connect                                 |
| NC       | 82  | Open     | No connect                                 |
| DVSS     | 83  | Ground   | Digital ground                             |
| DVDD     | 84  | Supply   | 1.8-V digital supply                       |
| IOVSS    | 85  | Ground   | Digital I/O ground                         |
| IOVDD    | 86  | Supply   | 3.3-V digital I/O supply                   |
| IF_DFSO  | 87  | Output   | IF interface frame sync                    |
| IF_DCLK  | 88  | Output   | IF interface bit clock                     |
| IF_DOUT3 | 89  | Output   | IF interface data out 3                    |
| DVSS     | 90  | Ground   | Digital ground                             |
| DVDD     | 91  | Supply   | 1.8-V digital supply                       |
| IF_DOUT2 | 92  | Output   | IF interface data out 2                    |



# **TERMINAL FUNCTIONS (continued)**

|         | TERMINAL      | FUNCTION      | PEGGDIPTION                                                   |
|---------|---------------|---------------|---------------------------------------------------------------|
| NAME    | NO.           | FUNCTION      | DESCRIPTION                                                   |
| IF_DOUT | Γ1 93         | Output        | IF interface data out 1                                       |
| IF_DOUT | Γ0 94         | Output        | IF interface data out 0                                       |
| IOVSS   | 95            | Ground        | Digital I/O ground                                            |
| IOVDD   | 96            | Supply        | 3.3-V digital I/O supply                                      |
| CS/A1   | 97            | Input         | SPI chip select (active low) / I <sup>2</sup> C address bit 1 |
| MOSI/A0 | 98            | Input         | SPI data in / I <sup>2</sup> C address bit 0                  |
| MISO/SE | DA 99         | Bidirectional | SPI data out / I <sup>2</sup> C SDA                           |
| SCK/SCI | L 100         | Input         | SPI clock / I <sup>2</sup> C SCL                              |
| CTRL_M  | IODE 101      | Input         | Control interface mode select (SPI = $0$ , $I^2C = 1$ )       |
| REG_EN  | <u>IB</u> 102 | Input         | Enable onboard DVDD regulator (active low)                    |
| DVSS    | 103           | Ground        | Digital ground                                                |
| DVDD    | 104           | Supply        | 1.8-V digital supply                                          |
| GPIO7   | 105           | Bidirectional | GPIO 7                                                        |
| GPIO6   | 106           | Bidirectional | GPIO 6                                                        |
| GPIO5   | 107           | Bidirectional | GPIO 5                                                        |
| NC      | 108           | Open          | No connect                                                    |
| GPIO4   | 109           | Bidirectional | GPIO 4                                                        |
| GPIO3   | 110           | Bidirectional | GPIO 3                                                        |
| GPIO2   | 111           | Bidirectional | GPIO 2                                                        |
| GPIO1   | 112           | Bidirectional | GPIO 1                                                        |
| GPIO0   | 113           | Bidirectional | GPIO 0                                                        |
| GPIO11  | 114           | Bidirectional | GPIO 11                                                       |
| GPIO10  | 115           | Bidirectional | GPIO 10                                                       |
| GPIO9   | 116           | Bidirectional | GPIO 9                                                        |
| GPIO8   | 117           | Bidirectional | GPIO 8                                                        |
| DVSS    | 118           | Ground/input  | Digital ground/Test1                                          |
| DVSS    | 119           | Ground/input  | Digital ground/Test0                                          |
| IOVSS   | 120           | Ground        | Digital I/O ground                                            |
| DVSS    | 121           | Ground        | Digital ground                                                |
| IOVDD   | 122           | Supply        | 3.3-V digital I/O supply                                      |
| DVDD    | 123           | Supply        | 1.8-V digital supply                                          |
| AVSS    | 124           | Ground        | Analog ground                                                 |
| AVDD    | 125           | Supply        | 3.3-V analog supply                                           |
| AVSS    | 126           | Ground        | Analog ground                                                 |
| DVDD1   | 127           | Supply        | 1.8-V digital supply (for RTC oscillator)                     |
| RTCO    | 128           | Output        | RTC oscillator output                                         |
| RTCI    | 129           | Input         | RTC oscillator input                                          |
| DVSS    | 130           | Ground        | Digital ground (for RTC oscillator)                           |
| AVSS    | 131           | Ground        | Analog ground                                                 |
| RTC_RE  | F 132         | Output        | RTC output                                                    |
| RTC_RE  | F 133         | Output        | Inverted RTC output                                           |
| AVDD    | 134           | Supply        | 3.3-V analog supply                                           |
| AVSS    | 135           | Ground        | Analog ground                                                 |
| SCL0    | 136           | Output        | Channel 0 tuner I <sup>2</sup> C clock                        |
| SDA0    | 137           | Bidirectional | Channel 0 tuner I <sup>2</sup> C data                         |
| NC      | 138           | Open          | No connect                                                    |

# **TERMINAL FUNCTIONS (continued)**

| TERMINAL |     | FUNCTION      | DESCRIPTION         |  |
|----------|-----|---------------|---------------------|--|
| NAME     | NO. | FUNCTION      | DESCRIPTION         |  |
| NC       | 139 | Open          | No connect          |  |
| NC       | 140 | Open          | No connect          |  |
| AVDD     | 141 | Supply        | 3.3-V analog supply |  |
| AVDD     | 142 | Supply        | 3.3-V analog supply |  |
| AVDD     | 143 | Supply        | 3.3-V analog supply |  |
| AVDD     | 144 | Supply        | 3.3-V analog supply |  |
| AVSS     | _   | Analog ground | Center pad          |  |



## **TIMING DIAGRAMS**

# **Output Data Interface Timing**

|                 | PARAMETER           | TEST CONDITIONS | MIN  | TYP | MAX | UNIT |
|-----------------|---------------------|-----------------|------|-----|-----|------|
| t <sub>D1</sub> | DCLK to DFSO delay  |                 | -2.9 |     | 3.7 | ns   |
| t <sub>D2</sub> | DCLK to DOUTx delay |                 | -3.1 |     | 3.8 | ns   |



**Figure 1. Output Data Interface Timing** 

# **Primary Data Interface Timing**

|                 | PARAMETER           | TEST CONDITIONS | MIN  | TYP MAX | UNIT |
|-----------------|---------------------|-----------------|------|---------|------|
| t <sub>D1</sub> | BCLK to WS delay    |                 | -2.9 | 3.7     | ns   |
| t <sub>D2</sub> | BCLK to DOUTx delay |                 | -3.1 | 3.8     | ns   |



Figure 2. Primary Data Interface Timing



# **SPI Control Interface Timing**

|                  | PARAMETER              | TEST CONDITIONS            | MIN | TYP MAX | UNIT |
|------------------|------------------------|----------------------------|-----|---------|------|
| f <sub>SCK</sub> | Maximum SCK frequency  |                            |     | 20      | MHz  |
| tL               | CS lead time           | Trailing CS to leading SCK | 5.0 |         | ns   |
| t <sub>T</sub>   | CS trail time          | Trailing SCK to leading CS | 5.0 |         | ns   |
| t <sub>l</sub>   | CS idle time           | Leading CS to trailing CS  | 5.0 |         | ns   |
| t <sub>SU3</sub> | MOSI to SCK setup time |                            | 5.0 |         | ns   |
| t <sub>H3</sub>  | MOSI to SCK hold time  |                            | 1.0 |         | ns   |
| t <sub>D4</sub>  | SCK to MISO delay      |                            | 1.0 | 10.4    | ns   |



Figure 3. SPI Control Interface Timing

# I<sup>2</sup>C Bus Interface Timing

|                     | PARAMETER                                        | MIN                 | TYP MAX               | UNIT |  |
|---------------------|--------------------------------------------------|---------------------|-----------------------|------|--|
| f <sub>SCK</sub>    | SCK clock frequency                              | 0                   | 400                   | kHz  |  |
| V <sub>IL</sub>     | Input voltage, low                               |                     | 0.3 × V <sub>DD</sub> | V    |  |
| V <sub>IH</sub>     | Input voltage, high                              | $0.7 \times V_{DD}$ |                       | V    |  |
| t <sub>START</sub>  | Setup time for START or repeated START condition | 0.6                 |                       | μs   |  |
| t <sub>STOP</sub>   | Setup time for STOP condition                    | 0.6                 |                       | μs   |  |
| t <sub>LOW</sub>    | LOW period of SCK clock                          | 1.3                 |                       | μs   |  |
| t <sub>HIGH</sub>   | HIGH period of SCK clock                         | 0.6                 |                       | μs   |  |
|                     | Data hald time from COV falling                  | 100 <sup>(1)</sup>  |                       |      |  |
| t <sub>HD_DAT</sub> | Data hold time from SCK falling                  | 250                 |                       | ns   |  |
| •                   | Determine the COV states                         | 100 <sup>(1)</sup>  |                       |      |  |
| t <sub>SU_DAT</sub> | Data setup time to SCK rising                    | 250                 |                       | ns   |  |
| t <sub>BUF</sub>    | Bus free time between a STOP and START condition | 4.7                 |                       | μs   |  |

(1) Valid when MCLK > 20 MHz; otherwise, is 250 ns.



Figure 4. I<sup>2</sup>C Bus Interface Timing



#### **DETAILED DESCRIPTION**

#### **Reset Pins**

The AFE8221 has two active-low reset pins,  $\overline{GRST}$  and  $\overline{RST}$ . When  $\overline{GRST}$  is brought low, all registers on the chip are brought to default values (0, unless otherwise specified). When  $\overline{RST}$  is brought low, all registers are brought to default values except for:

- Real-time clock registers (counters and alarms)
- · Registers to configure the WAKEUP interrupt
- Registers controlling the GPIO pins

These registers are left in the previously programmed states.

## **Analog Supply Connections**

A clean 3.3-V analog supply should be connected to all AVDD pins (37–40, 45, 54, 125, 134, and 141–144). Limited decoupling is required on the AVDD pins; a  $0.1-\mu F$  capacitor near pins 45 and 54 and another capacitor near pins 125 and 134 should suffice.

The AFE8221 contains an internal analog switch that is used to disconnect power from the major analog blocks when the PWD pin is high. When the PWD pin is low, the AVDD1 pins (8, 12, 13, 23, 24, and 34) are internally connected to the AVDD pins (37–40 and 141–144). Since the AVDD1 pins are actually the active supply pins for the IF ADC and other analog components, the AVDD1 pins should be heavily bypassed with a minimum of parallel 0.1-μF and 0.01-μF ceramic capacitors at each pin (or pin pair).

## **Digital Supply Connections**

The digital supply connections depend on whether the onboard regulators are used to generate the 1.8-V digital core voltage (REG\_ENB low); or if the digital core voltage comes from a system-level supply (REG\_ENB high). In either case, all IOVDD pins should be connected to the 3.3-V I/O supply and appropriately bypassed. If the internal regulators are used, this supply also sources the current drawn by the digital core.

#### **External 1.8-V Core Supply**

If an external 1.8-V supply is used, all DVDD pins should be connected to the 1.8-V supply and appropriately bypassed with 0.1- $\mu$ F and 0.01- $\mu$ F capacitors. DVDD1 and DVDD2 pins may also be connected directly to the 1.8-V supply or may be optionally connected through a small (1  $\Omega$  to 10  $\Omega$ ) series resistor to reduce supply noise coupling into the MCLK oscillator (powered through DVDD1) or the RTC oscillator (powered through DVDD2).

When using an external supply, the PWD pin disables the MCLK oscillator when high, shutting off the clock to most of the digital core. As long as the external 1.8-V supply is maintained, all register settings in the digital core are maintained when PWD is high.

#### Internal 1.8-V Regulator

If the internal 1.8-V regulator is used, then  $0.1-\mu F$  and  $0.01-\mu F$  decoupling capacitors should still be put at the DVDD, DVDD1, and DVDD2 pins. DVDD2 should still be connected to the DVDD pins either directly or through a small series resistor. DVDD1 must be isolated from DVDD and DVDD2.

While using the internal regulators, the MCLK oscillator and the internal regulators are disabled when the PWD pin is high. This condition causes most of the register settings to be lost, except for the registers associated with the real-time clock, GPIO, and WAKEUP interrupt. For this reason, the RST pin should be brought low prior to bringing the PWD pin low (to come out of power-down). The RST pin should be held low for at least 10 ms after PWD goes low to allow the internal regulators to stabilize.

Note that the internal regulators are linear regulators, and therefore are relatively inefficient. Power dissipation as a result of the digital core almost doubles when the internal regulators are used (same core current, but drawn from a 3.3-V supply instead of a 1.8-V supply). Whenever possible, the use of a more efficient external switching regulator is encouraged in order to minimize overall system power as well as to reduce the thermal stress on the AFE8221.

Submit Documentation Feedback

#### **Control Interface**

Configuration and control data are written to the AFE8221 via the control interface. The control interface supports two protocols, SPI and I<sup>2</sup>C. If the CTRL\_MODE pin is tied low, then an SPI interface is implemented. If CTRL\_MODE is tied high, then an I<sup>2</sup>C protocol-compatible interface is implemented.

#### **SPI Interface**

The SPI interface consists of four signals: a serial clock (SCK), an active-low chip select  $(\overline{CS})$ , a serial data input (MOSI—master out, slave in), and a serial data output (MISO—master in, slave out). Data are transferred in groups of 32 bits. The first 16 bits are the instruction, which indicates:

- 1. If data are to be written or to be read;
- 2. If the data target is a register or RAM; and
- 3. The address of the data target.

The second 16 bits are the data transfer, which is input on MOSI for a write cycle or output on MISO for a read cycle.

Figure 5 shows an SPI write cycle. The cycle is initiated by the high-to-low transition of the  $\overline{CS}$  line. 32 SCK pulses clock the instruction and the data into the MOSI line. Data are clocked in MSB first. The first 16 bits are the instruction. There are two possible write cycle instructions: register write and memory write. The formats for these instructions are shown in Figure 6 and Figure 7, respectively.

The only information required for a register write is the seven-bit register address (REG\_ADDR). For a memory write, both the five-bit memory select (MEM) plus the six-bit memory address (MEM\_ADDR) are required.

Following the 16-bit instruction, the 16-bit data word is clocked in, again MSB first. At the end of the write cycle, this data word is written to the appropriate register or memory location in the AFE8221.



NOTE: To terminate a Write/Read cycle, CS must be brought high.

Figure 5. SPI Control Interface Write Cycle



Figure 7. Memory Write Instruction Format

Figure 8 shows the SPI interface read cycle. It is similar to the write cycle, except that instead of the data word being clocked into MOSI during the second half of the cycle, the data word is clocked out of MISO. Note that only register reads are permitted; RAM reads cannot be read back.



For reading and writing, data block transfers are supported. For a block transfer, multiple data words are transmitted following the memory read or write instruction. The data words are read from or written sequentially starting at the address contained in the instruction. The sequential access terminates when the  $\overline{CS}$  line goes high. Figure 9 shows a register block read cycle. In the illustration, three succeeding register locations are read starting at address N. The block write cycle is similar except, of course, data are clocked into MOSI.

In all cases, the control interface is reset when  $\overline{CS}$  goes high. If the final SCK is not received before  $\overline{CS}$  goes high, then the cycle ends prematurely. For a read cycle, data transfer terminates; for a write cycle, no data are written to either a register or to memory.

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

The AFE8221 control interface can be configured to provide I<sup>2</sup>C slave operation. It has a 10-bit slave address of 00010010AB and complies with the Philips I<sup>2</sup>C specification. Note that address bits A and B are determined by the state of the I<sup>2</sup>C address pins A1 and A0. The mapping of SPI pins to I<sup>2</sup>C pins is shown in Table 1.

Table 1. SPI/I<sup>2</sup>C Pin Mapping

| CTRL_MODE = 0 (SPI)        | CTRL_MODE = 1 (I <sup>2</sup> C)  |
|----------------------------|-----------------------------------|
| Chip select (CS)           | I <sup>2</sup> C address bit (A1) |
| Master out slave in (MOSI) | I <sup>2</sup> C address bit (A0) |
| Master in slave out (MISO) | Serial data line (SDA)            |
| SPI clock (SCK)            | Serial clock line (SCL)           |

The AFE8221 I<sup>2</sup>C interface supports both fast mode (400K bits/sec) and standard mode (100K bits/sec) operation. However, if the master crystal frequency is less than 20 MHz, then only standard mode is supported.



Figure 8. SPI Control Interface Read Cycle



Figure 9. SPI Control Interface Block Read Cycle

As a reference, a typical data transfer on the I<sup>2</sup>C bus is described in Figure 10. Each data byte is eight bits long and must be followed by an Acknowledge bit. Start and stop conditions are defined as a transition of the SDA signal with SCL high. A pulse of the SCL clock signal indicates the transfer of data or an Acknowledge bit on the SDA pin. The transmitting device drives SDA data during clock periods 1–8. The receiving device acknowledges by driving SDA low during clock 9. Master devices always generate the SCL clock and initiate transactions. Refer to the Philips I<sup>2</sup>C Bus Specification for further details.

The AFE8221 has 16-bit internal registers and operates on 16-bit instructions. Because the I<sup>2</sup>C interface is inherently an 8-bit interface, special formats are required to send instructions and data between an I<sup>2</sup>C Master and the AFE8221. The I<sup>2</sup>C Write Operation and I<sup>2</sup>C Read Operation sections describe these formats in detail.

### **PC** Write Operation

Write operations require a start condition followed by two bytes describing both a 10-bit address format and the AFE8221 10-bit slave address. The next two bytes must contain the 16-bit instruction word format described previously in Figure 6 or Figure 7, depending on the internal resource being addressed. Finally, a pair of bytes containing the 16-bit write data must be provided. If additional 16-bit writes are required, further pairs of bytes may be used as part of a block transfer. After the final pair of write data bytes, an I<sup>2</sup>C stop condition must be provided to terminate the transaction. Figure 12 illustrates a block write transfer of *N* 16-bit data words. Gray areas denote slave-driven SDA cycles; white areas are master-driven.

#### **PC** Read Operation

Read operations require a start condition followed by two bytes describing both a 10-bit address format and the AFE8221 10-bit slave address. The next two bytes must contain the 16-bit instruction word format, as illustrated in Figure 11. A repeated start followed by the first byte of the slave address is then required to create a combined transaction. Note that the  $R/\overline{W}$  bit is set to 1 (read), indicating that subsequent bytes are to be read from the slave. The AFE8221 presents addressed 16-bit data words in 8-bit pairs until a NACK (N) is provided by the master. After the final pair of read data bytes, an  $I^2C$  stop condition must be provided to terminate the transaction. Figure 13 illustrates a block read transfer of N 16-bit data words. Gray areas denote slave-driven SDA cycles; white areas are master-driven.



Figure 10. Example Data Transfer on the I<sup>2</sup>C Bus



Figure 11. Register Read Instruction Format



Figure 12. Example I<sup>2</sup>C Write Operation





Figure 13. Example I<sup>2</sup>C Read Operation

### IF Analog-to-Digital Converters (IF\_ADC0 and IF\_ADC1)

IF\_ADC0 and IF\_ADC1 are 12-bit pipeline ADCs that are used to sample the output of the tuner(s). Figure 14 shows recommended connections for the IF ADCs.

The IF ADCs have three power modes controlled by ifadc\_en[0] and ifadc\_en[1]. Full-power mode occurs when both ifadc en[0] and ifadc en[1] are high. In this case, both ADCs are biased to the highest levels and are ready to operate. If only ifadc en[0] or ifadc en[1] is high, then the converters are operating in reduced-power mode, where the enabled ADC is fully biased and ready to operate while the second ADC is in a low (but not zero) bias state (a minimum bias current is necessary to maintain safe voltages within the ADC core). In low-power mode, both ifadc en[0] and ifadc en[1] are low. In this case, all IF ADC circuits are in the minimum bias mode. Note that to reach a true sleep mode, the analog supply to the IF ADC block must be turned off.

When ifadc\_gain0 is low, IF\_ADC0 is in its normal 1x gain operating state. If ifadc\_gain0 is high, then the gain of IF ADC0 is changed to 2x. In a similar fashion, ifadc gain1 controls the gain of IF ADC1. Table 2 shows the ifadc en and ifadc gain control variable parameters.

Table 2. IF\_ADC Control Register Settings

| PARAMETER   | ADDRESS | BITS |
|-------------|---------|------|
| ifadc_en[0] | 1       | 0    |
| ifadc_en[1] | 1       | 1    |
| ifadc_gain0 | 1       | 2    |
| ifadc_gain1 | 1       | 3    |



Figure 14. IF ADC Connections

#### IF ADC Alarm/Attenuator

The output of each IF ADC is monitored to ensure that the full-scale input range is not exceeded. If an ADC over-range condition occurs, an overflow signal is generated that may be used to generate an interrupt on the IRQ line, depending on the settings in the IRQ interrupt generator.

In addition, programmable limits may be set for each IF ADC. If the absolute value of IF\_ADC0 exceeds if\_adc\_limit0 or the absolute value of IF\_ADC1 exceeds ifadc\_limit1, then an interrupt may be generated on IRQ again depending on the settings in the IRQ interrupt generator.

In the case of an IF ADC event, the IRQ status register can be read back to determine the type of event and on which ADC channel it occurred. The IRQ status register can be polled to determine if an IF ADC event has occurred in the case where IF ADC events are masked from generating an interrupt.

The control variable  $ddc0\_atten$  causes an attenuation of the IF\_ADC0 output prior to the DDC. The attenuation ranges in 3-dB steps from 0 dB (for  $ddc0\_atten = 0$ ) to -18 dB (for  $ddc0\_atten = 6$ ).  $ddc1\_atten$  has the same effect on the output of IF\_ADC1.

To better synchronize the IF ADC attenuator with the tuner automatic gain control (AGC), a delay may be programmed between when a new value of *ddc\_atten* is written and when it takes effect. When a new value of *ddc0\_atten* is written, a counter (driven by MCLK) is initialized to *ddc0\_delay*. When the counter reaches zero, the actual attenuation change occurs. Likewise, *ddc1\_delay* affects *ddc1\_atten*. Note that if a new *ddc0\_atten* is written before the delay counter has reached zero from the previous write, the previous write is discarded. Table 3 shows the attenuator, delay, and limit control variables.

Table 3. IF ADC Control Register Settings

| PARAMETER    | ADDRESS | BITS |
|--------------|---------|------|
| ddc0_atten   | 3       | 2:0  |
| ddc1_atten   | 15      | 2:0  |
| ddc0_delay   | 4       | 15:0 |
| ddc1_delay   | 16      | 15:0 |
| ifadc_limit0 | 46      | 11:0 |
| ifadc_limit1 | 47      | 11:0 |

# **Digital Downconverter 0 (DDC0)**

DDC0 operation is controlled by  $ddc\_en[0]$ . When  $ddc\_en[0]$  is 1, operation of DDC0 is enabled. If  $ddc\_en[0]$  is 0, operation of DDC0 is disabled. Table 4 shows the DDC0 operation control settings.

**Table 4. DDC Control Register Settings** 

| PARAMETER               | ADDRESS | BITS |
|-------------------------|---------|------|
| ddc0_cic_dec_rate       | 9       | 8:0  |
| ddc0_cic_scale          | 10      | 11:6 |
| ddc0_cic_shift          | 10      | 5:0  |
| ddc0_demod_freq[31:16]  | 5       | 15:0 |
| ddc0_demod_freq[15:0]   | 6       | 15:0 |
| ddc0_demod_phase[31:16] | 7       | 15:0 |
| ddc0_demod_phase[15:0]  | 8       | 15:0 |
| ddc0_fir1_base_address  | 11      | 13:8 |
| ddc0_fir1_mode          | 11      | 1:0  |
| ddc0_fir1_ncoeffs       | 11      | 7:2  |
| ddc0_fir1_nodec         | 14      | 9    |
| ddc0_fir2_nodec         | 14      | 10   |
| ddc0_fir2a_base_address | 12      | 15:9 |
| ddc0_fir2a_mode         | 12      | 1:0  |
| ddc0_fir2a_ncoeffs      | 12      | 8:2  |
| ddc0_fir2a_shift        | 14      | 3:0  |
| ddc0_fir2b_base_address | 13      | 15:9 |
| ddc0_fir2b_mode         | 13      | 1:0  |
| ddc0_fir2b_ncoeffs      | 13      | 8:2  |
| ddc0_fir2b_shift        | 14      | 7:4  |
| ddc0_interleave         | 14      | 8    |
| ddc_en[0]               | 1       | 4    |
| ddc_sync                | 1       | 6    |



#### **Quadrature Mixer/NCO**

The NCO frequency and initial phase are set by the 32-bit unsigned variables ddc0\_demod\_freq and ddc0\_demod\_phase. The I and Q outputs of the mixer can be calculated by Equation 1 and Equation 2.

$$I = ADC \times \cos(2\pi ft + \phi) \tag{1}$$

$$Q = ADC \times \sin(2\pi ft + \phi)$$
 (2)

where ADC is the output of the IF analog-to-digital converter, f is the NCO phase offset (in radians) given by Equation 3, and  $\phi$  is the NCO phase offset (in radians) given by Equation 4.

$$f = f_{MCLK} \frac{ddc0\_demod\_freq}{2^{32}}$$
(3)

$$\phi = 2\pi \frac{\text{ddc0\_demod\_phase}}{2^{32}} \tag{4}$$

The *ddc\_sync* signal can be used to control the phase of the mixer. While the *ddc\_sync* signal is high, the phase accumulator is held to a constant value *ddc0\_demod\_phase*, essentially holding it to 0 in Equation 1 and Equation 2. When the *ddc\_sync* signal is brought low, the phase accumulator is incremented by the value *ddc0\_demod\_freq* once per MCLK cycle.

#### **CIC Filter**

The first stage of decimation filtering is provided by a fifth-order CIC filter. The operation of the CIC filter is controlled by the unsigned variables  $ddc0\_cic\_dec\_rate$ ,  $ddc0\_cic\_scale$ , and  $ddc0\_cic\_shift$ . The valid range for  $ddc0\_cic\_dec\_rate$  is from 4 to 256.

The inherent dc gain of the CIC filter is  $ddc0\_cic\_dec\_rate$ . The control variables  $ddc0\_cic\_shift$  and  $ddc0\_cic\_scale$  are used to reduce this very high gain before the signal is output to the next stage of the decimation filter. The combined effect of  $ddc0\_cic\_dec\_rate$ ,  $ddc0\_cic\_shift$ , and  $ddc0\_cic\_scale$  produces an overall dc gain for the CIC filter of Equation 5.

GAIN = 
$$ddc0\_cic\_dec\_rate^{5} \frac{ddc0\_cic\_scale/32}{2_{ddc0\_cic\_shift}}$$
 (5)

In general,  $ddc0\_cic\_shift$  and  $ddc0\_cic\_scale$  should be chosen to make GAIN as close to 1 as possible. For example, if  $ddc0\_cic\_dec\_rate$  is 20, setting  $ddc0\_cic\_shift$  to 22 and  $ddc0\_cic\_scale$  to 41 results in a GAIN of 0.9775.

### First FIR Filter

The block following the CIC filter is a decimate-by-two finite impulse response (FIR) filter with programmable coefficients. *ddc0\_fir1\_mode* sets the type of filter response—ODD (MODE = 00: symmetric impulse response, odd number of taps), EVEN (MODE = 01: symmetric impulse response, even number of taps), HALFBAND (MODE = 10), and ARBITRARY (MODE = 11: non-symmetric impulse response).

The 16-bit wide filter coefficients are stored in memory bank 0. Up to 64 coefficients can be stored in this memory. Depending on the types of filters desired and the number of taps, coefficients for multiple filter responses may be stored in the memory bank. The filter response may be changed simply by updating the control register with new values for ddc0\_fir1\_mode, ddc0\_fir1\_ncoeff, and ddc0\_fir1\_base\_addr.

ddc0\_fir1\_ncoeff defines the number of unique filter coefficients that make up the filter response. ddc0\_fir1\_base\_addr defines the memory location where the first filter coefficient is stored. The actual filter length is a function of the ddc0\_fir1\_mode and ddc0\_fir1\_ncoeff, as shown in Equation 6.

(6)



www.ti.com SBAS434-DECEMBER 2008

Filter Length =  $2 \times (ddc0 \text{ fir1 ncoeff} - 1) + 1 \text{ for ODD}$ 

Filter Length = 2 × ddc0 fir1 ncoeff for EVEN

Filter Length =  $4 \times (ddc0 \text{ fir1 ncoeff} - 1) + 1 \text{ for HALFBAND}$ 

The maximum filter length that can be realized is limited by two factors. First, the number of clock cycles between successive filter outputs limits the number of coefficients that can be processed, as shown in Equation 7.

$$ddc0_fir1_ncoeff \le 2 \times ddc0_cic_dec_rate$$
 (7)

where ddc0\_cic\_dec\_rate is the decimation ration of the CIC filter.

Second, the size of the data memory (which stores incoming data samples) limits filter length to 62 taps. Note that two data memory locations are required to filter processing.

The dc gain of the FIR filter depends on the coefficient values and the filter mode. For ODD mode and HALFBAND mode, the dc gain is given by Equation 8:

$$GAIN = \left(\frac{h_{NCOEFF} + \sum_{n=1}^{NCOEFF-1} 2h_n}{2^{15} - 1}\right)$$
(8)

where h<sub>n</sub> is the n<sup>th</sup> of NCOEFF filter coefficients stored in memory.

For EVEN mode the, dc gain is shown by Equation 9:

$$GAIN = \left(\frac{\sum_{n=1}^{NCOEFF} 2h_n}{2^{15} - 1}\right)$$
(9)

while for ARBITRARY mode the gain is shown by Equation 10:

$$GAIN = \left(\frac{\sum_{n=1}^{NCOEFF} h_n}{2^{15} - 1}\right)$$
(10)

#### **Second FIR Filters**

The first FIR filter is followed by two parallel second FIR filters, FIR2A and FIR2B. Duplicate filters allow the output of two I and Q output streams with different bandwidths. For example, the bandwidth of FIR2A may be set wide to accommodate reception of digital broadcasts, while FIR2B may be set narrower to receive an analog broadcast sharing the same band. Coefficients for FIR2A are stored in memory bank 1 (MEM = 1) and coefficients for FIR2B are stored in memory bank 2 (MEM = 2).

The operation of the second FIR filter is similar to the first FIR filter with several notable exceptions. First, the depths of the coefficient and data memories are doubled to 128. This size increase allows for filters up to 126 taps to be realized without running out of data memory. It also allows longer sets of filter coefficients to be stored in coefficient memory.

Second, because of the additional decimation by two from the first FIR filter, twice as many MCLK cycles are available to process coefficients, increasing the maximum allowable value of NCOEFF, as shown in Equation 11 and Equation 12.

$$ddc0_fir2a_ncoeff \le 4 \times ddc0_cic_dec_rate$$
 (11)

$$ddc0_fir2b_ncoeff \le 4 \times ddc0_cic_dec_rate$$
 (12)

Third, in the first FIR filter the total of all the filter tap weights must add up to  $(2^{15} - 1)$  to achieve unity gain through the filter. With longer filters (and therefore, smaller coefficients), frequency response errors may be introduced as a result of coefficient truncation. A Shift parameter has been added to the second FIR filter to alleviate this problem. The total of all filter tap weights must add up to  $(2^{15+ddc0}_{fir2a\_shift} - 1)$  to achieve unity gain through FIR2A (similarly for  $ddc0_{fir2b\_shift}$  and FIR2B). Note that shift values for FIR2A and FIR2B can be set separately.



#### Extended-Length Filter Mode

If FIR2A or FIR2B cannot provide enough filter taps to achieve the desired frequency response, setting control bit *ddc0\_interleave* puts the two filters into an interleaved mode that doubles the length of the filter that can be realized. However, there are several limitations:

- 1. Only odd symmetrical filters may be realized;
- 2. The filter length M must be such that (M + 1)/4 is an integer; and
- 3. Only one filter can be realized (in *ddc\_interleave* mode the A and B outputs are identical: IB = IA and QB = QA).

In addition to setting the *ddc0\_interleave* bit, FIR2A must be set to EVEN mode and FIR2A must be set to ODD mode. *ddc0\_fir2a\_ncoeff* and *ddc0\_fir2b\_ncoeff* are both set to (M + 1)/4. *ddc0\_fir2a\_shift* and *ddc0\_fir2b\_shift* should be identical. There are no restrictions on *ddc0\_fir2a\_base\_addr* or *ddc0\_fir2b\_base\_addr*.

The M-tap filter has (M + 1)/2 unique coefficients. The first, third, fifth, etc. coefficients are loaded into the FIR2A coefficient memory; the second, fourth, sixth, etc. coefficients are loaded into the FIR2B memory. The center coefficients of the filter end up as the last coefficient loaded into FIR2B.

#### FIR Filter Transfer Functions

Equation 13 to Equation 21 show transfer functions and dc gain for the various filter modes. Generic names for the control variables are used; just substitute the appropriate variable (that is, ddc0\_fir2a\_ncoeff for NCOEFF) as necessary. Also, note that SHIFT has a value of 0 for FIR1.

#### **Basic Filter Modes**

$$H_{\text{EVEN}}(z) = \sum_{n=0}^{\text{NCOEFF}-1} \text{COEFF}_{\text{BASE\_ADDR}+n} \times (z^{-n} + z^{-(2 \times \text{NCOEFF}-1-n)})$$
(13)

$$H_{ODD}(z) = \sum_{n=0}^{NCOEFF-2} COEFF_{BASE\_ADDR+n} \times (z^{-n} + z^{-(2 \times NCOEFF-2-n)}) + COEFF_{BASE\_ADDR+NCOEFF-1} \times z^{NCOEFF-1}$$
(14)

$$H_{\text{HALFBAND}}(z) = \sum_{n=0}^{\text{NCOEFF}-2} \text{COEFF}_{\text{BASE\_ADDR}+n} \times (z^{-2n} + z^{-(4 \times \text{NCOEFF}-6-2n)}) + \text{COEFF}_{\text{BASE\_ADDR}+\text{NCOEFF}-1} \times z^{2 \times \text{NCOEFF}-3}$$

$$(15)$$

$$H_{ARBITRARY}(z) = \sum_{n=0}^{NCOEFF-1} COEFF_{BASE\_ADDR+n} \times z^{-n}$$
(16)

$$GAIN_{EVEN}(z) = 2^{-SHIFT} \times \frac{2 \times \sum_{n=0}^{NCOEFF-1} COEFF_{BASE\_ADDR+n}}{2^{15}-1}$$
(17)

$$GAIN_{ODD} = GAIN_{HALFBAND} = 2^{-SHIFT} \times \frac{2 \times \sum_{n=0}^{NCOEFF-2} COEFF_{BASE\_ADDR+n} + COEFF_{BASE\_ADDR+NCOEFF-1}}{2^{15} - 1}$$
(18)

$$GAIN_{ARBITRARY}(z) = 2^{-SHIFT} \times \frac{\sum_{n=0}^{NCOEFF-1} COEFF_{BASE\_ADDR+n}}{2^{15}-1}$$
(19)

### **Extended-Length Filter Mode**

**NSTRUMENTS** 

$$H_{\text{EXTENDED}}(z) = 2^{-\text{SHIFT}} \times \begin{pmatrix} \text{NCOEFF} - 1 \\ \sum_{n=0}^{S} \text{COEFF} \_A_{\text{BASE\_ADDR\_A} + n} \times (z^{-2 \times n} + z^{-2 \times (2 \times \text{NCOEFF} - 1 - n)}) \\ + \sum_{n=0}^{\text{NCOEFF} - 2} \text{COEFF\_B}_{\text{BASE\_ADDR\_B} + n} \times (z^{-2 \times n + 1} + z^{-2 \times (2 \times \text{NCOEFF} - 2 - n) + 1}) \\ + \text{COEFF\_B}_{\text{BASE\_ADDR\_B} + \text{NCOEFF} - 1} \times z^{2 \times \text{NCOEFF}} \end{pmatrix}$$

$$(20)$$

$$GAIN_{\text{EXTENDED}} = \frac{2^{-\text{SHIFT}}}{2^{15} - 1} \times \begin{pmatrix} 2 \times \sum_{n=0}^{\text{NCOEFF} - 2} \text{COEFF\_A}_{\text{BASE\_ADDR\_A} + n} \\ + 2 \times \sum_{n=0}^{\text{NCOEFF} - 2} \text{COEFF\_B}_{\text{BASE\_ADDR\_B} + n} \\ + \text{COEFF\_B}_{\text{BASE\_ADDR\_B} + \text{NCOEFF} - 1} \end{pmatrix}$$

$$(21)$$

## **Digital Downconverter 1 (DDC1)**

The description of DDC1 is identical to the description of DDC0, with the following exceptions:

- 1. DDC1 is enabled by ddc\_en[1].
- 2. Control variables are prefixed with ddc1 instead of ddc0.
- 3. FIR coefficients are stored in memory banks 3, 4, and 5 instead of 0, 1, and 2.

Table 5 shows the DDC1 operation control settings.

## **Primary IF Data Interface**

The two DDCs produce a total of eight 16-bit output values (I and Q from each of four final-stage FIR filters). The IF data interface time-multiplexes these eight values onto four serial lines. The IF data interface also generates the necessary clock and frame sync signals to complete the interface to the DSP. The general timing of the IF data interface is shown in Figure 15.

Note that each serial line (IF\_DOUT0 through IF\_DOUT3) can carry up to four time-multiplexed 16-bit signals. The actual number of signals per line is limited by:

- a. the frequency of IF\_DCLK, which can be programmed to be the same as the IF sampling clock (MCLK), one-half the IF sampling frequency, or one-fourth the IF sampling frequency; and
- b. the overall decimation ratio of the DDC that determines the frequency of IF\_DFSO pulses and therefore the number of IF\_DCLK cycles available to clock out data.

**Table 5. IF Control Register Settings** 

| PARAMETER               | ADDRESS | BITS |
|-------------------------|---------|------|
| ddc1_cic_dec_rate       | 21      | 8:0  |
| ddc1_cic_scale          | 22      | 11:6 |
| ddc1_cic_shift          | 22      | 5:0  |
| ddc1_demod_freq[31:16]  | 17      | 15:0 |
| ddc1_demod_freq[15:0]   | 18      | 15:0 |
| ddc1_demod_phase[31:16] | 19      | 15:0 |
| ddc1_demod_phase[15:0]  | 20      | 15:0 |
| ddc1_fir1_base_address  | 23      | 13:8 |
| ddc1_fir1_mode          | 23      | 1:0  |
| ddc1_fir1_ncoeffs       | 23      | 7:2  |
| ddc1_fir1_nodec         | 26      | 9    |
| ddc1_fir2_nodec         | 26      | 10   |
| ddc1_fir2a_base_address | 24      | 15:9 |
| ddc1_fir2a_mode         | 24      | 1:0  |
| ddc1_fir2a_ncoeffs      | 24      | 8:2  |

**Table 5. IF Control Register Settings (continued)** 

| PARAMETER               | ADDRESS | BITS |
|-------------------------|---------|------|
| ddc1_fir2a_shift        | 26      | 3:0  |
| ddc1_fir2b_base_address | 25      | 15:9 |
| ddc1_fir2b_mode         | 25      | 1:0  |
| ddc1_fir2b_ncoeffs      | 25      | 8:2  |
| ddc1_fir2b_shift        | 26      | 7:4  |
| ddc1_interleave         | 26      | 8    |
| ddc_en[1]               | 1       | 5    |
| ddc_sync                | 1       | 6    |



Figure 15. IF Data General Timing

Control register variables *dout0\_config*, *dout1\_config*, *dout2\_config*, and *dout3\_config*, are used to assign specific output data streams to particular time slots in the IF interface output frame. Each register is broken into four 4-bit values, each of which is used to assign the source for a given time slot according to Table 6.

**Table 6. Time Slot Sources** 

| VALUE | SOURCE             |
|-------|--------------------|
| 0     | No source assigned |
| 1     | DDC0, FIR2A, I     |
| 2     | DDC0, FIR2A, Q     |
| 3     | DDC0, FIR2B, I     |
| 4     | DDC0, FIR2B, Q     |
| 5     | DDC1, FIR2A, I     |
| 6     | DDC1, FIR2A, Q     |
| 7     | DDC1, FIR2B, I     |
| 8     | DDC1, FIR2B, Q     |

doutO\_config controls the four time slots of IF\_DOUT0, register 24 controls the four time slots of IF\_DOUT1, and so on. The mapping of register bits to time slots is summarized in Table 7.

**Table 7. Register Bit Mapping** 

| PARAMETER    | [15:12] | [11:8] | [7:4] | [3:0] |
|--------------|---------|--------|-------|-------|
| dout0_config | D0      | C0     | В0    | A0    |
| dout1_config | D1      | C1     | B1    | A1    |
| dout2_config | D2      | C2     | B2    | A2    |
| dout3_config | D3      | C3     | В3    | А3    |

Submit Documentation Feedback

For example, bits [11:8] of dout2\_config set the source assignment for time slot C2 of IF\_DOUT2.

The control variable if\_dclk\_div sets the frequency of IF\_DCLK, as shown in Equation 22 and Equation 23.

$$f_{\text{IF\_DCLK}} = \frac{\frac{\text{MCLK}}{\text{if\_dclk\_div}}}{\text{if\_dclk\_div}} \qquad \text{if\_dclk\_div} > 1$$
(22)

$$f_{\text{IF\_DCLK}} = f_{\text{MCLK}}$$
 if\_dclk\_div \leq 1 (23)

Normally the data and the frame sync change on the rising edge of IF\_DCLK. If *if\_dclk\_edge* is set to 1 then IF DCLK is inverted so that data and frame sync change on the falling edge of IF DCLK.

The control value *if\_dfso\_select* determines which DDC is responsible for generating IF\_DFSO. If *if\_dfso\_select* is 0, then an IF\_DFSO pulse is generated each time a new output is ready from DDC0. Similarly, if *if\_dfso\_select* is 1, then an IF\_DFSO pulse is generated each time a new output is ready from DDC1. If the decimation rates of DDC0 and DDC1 are identical, then it does not matter which DDC initiates the IF\_DFSO pulse. If the decimation rates are different, then the DDC with the smaller decimation ratio (higher output rate) should be chosen to generate the IF\_DFSO pulse. Note that in this case, outputs from the slower DDC are repeated for multiple frames and it is the responsibility of the DSP software to compensate. This compensation is easiest to do if the higher decimation rate is an integer multiple of the lower decimation rate.

Finally, *if\_dfso\_mode* is used to select alternate forms of frame sync. In the default case (*if\_dfso\_mode* = 0), the frame sync is a high pulse one clock period wide that occurs the clock cycle before the first data bit of the serial output. If *if\_dfso\_mode* is set to 1, then the frame sync changes polarity once per frame; again, one clock cycle before the first data bit of the frame. If *if\_dfso\_mode* is set to 2, then the frame sync behaves like the default frame sync except that the sync pulse is 16 clock periods wide. The three frame sync modes are illustrated in Figure 16 and Figure 17. Table 8 shows the detailed timing conditions for Figure 17.

It is recommended that the DSP interface be configured to sample IF\_DFSO and the four IF\_DOUT lines on the trailing edge of IF\_DCLK. Table 9 shows the *dout*, *if\_dclk*, *if\_dfso*, and *if\_dout* operation control settings.

**Table 8. Detailed Timing Conditions** 

| PARAMETER       | DESCRIPTION                | MIN  | TYP | MAX | UNIT |
|-----------------|----------------------------|------|-----|-----|------|
| t <sub>D1</sub> | IF_DCLK0 to IF_DFS0 delay  | -2.9 | 0   | 3.7 | ns   |
| t <sub>D2</sub> | IF_DCLK0 to IF_DOUTx delay | -3.1 | 0   | 3.8 | ns   |

**Table 9. Primary IF Control Register Settings** 

| PARAMETER       | ADDRESS | BITS |
|-----------------|---------|------|
| dout_en         | 1       | 7    |
| if_dclk_div     | 31      | 4:0  |
| if_dclk_edge    | 31      | 5    |
| if_dfso_mode    | 31      | 8:7  |
| if_dfso_select  | 31      | 6    |
| if_dout0_config | 27      | 15:0 |
| if_dout1_config | 28      | 15:0 |
| if_dout2_config | 29      | 15:0 |
| if_dout3_config | 30      | 15:0 |



Figure 16. Frame Sync Modes





Figure 17. Detailed Timing

#### **Alternate IF Data Interface**

The operation and timing of the alternate IF data interface are identical to the primary IF data interface. Pin names are changed such that BB\_BCK is equivalent to IF\_DCLK; BB\_WS is equivalent to IF\_DFSO;` and BB\_IOUT0, BB\_IOUT1, BB\_QOUT0, and BB\_QOUT1 are each equivalent to any IF\_DOUTx pins. The parameter names are also changed to reflect the different interface pin names. Table 10 shows the BB operation control settings.

**Table 10. Alternate IF Control Register Settings** 

| PARAMETER       | ADDRESS | BITS |
|-----------------|---------|------|
| bb_dclk_edge    | 36      | 5    |
| bb_dclk_div     | 36      | 4:0  |
| bb_dout0_config | 32      | 15:0 |
| bb_dout1_config | 33      | 15:0 |
| bb_dout2_config | 34      | 15:0 |
| bb_dout3_config | 35      | 15:0 |
| bb_en           | 1       | 8    |
| bb_ws_mode      | 36      | 10:7 |
| bb_ws_select    | 36      | 6    |

### **Auxiliary DACs**

CDAC0 is enabled by a high value set for  $cdac\_en[0]$ . Similarly, CDAC1 is enabled by a high value set for  $cdac\_en[1]$ . A control DAC that is disabled is put into a low-power state.

The control DAC outputs are set by the control variable *cdac0\_out* for CDAC0 and *CDAC1\_OUT* for CDAC1. A value of zero generates a 0 output from the control DAC while a value of *4095* generates a full-scale output from the control DAC. Table 11 shows the CDAC operation control settings.

Table 11. CDAC Control Register Settings

| PARAMETER  | ADDRESS | BITS |
|------------|---------|------|
| cdac_en[0] | 1       | 9    |
| cdac_en[1] | 1       | 10   |
| cdac0_out  | 37      | 11:0 |
| cdac1_out  | 38      | 11:0 |

8 Submit Documentation Feedback

## **Auxiliary ADC**

The auxiliary ADC is an 8-bit successive approximation converter that is intended for low-speed, low-accuracy tasks such as system diagnostics. Any one of four input pins can be connected to the auxiliary ADC. The parameter  $aux\_adc\_sel$  is used to connect a particular input pin to the converter. This input multiplexer operates according to the following sequence:

- aux adc sel = 0:
  - No aux ADC inputs are connected, all inputs high impedance
- aux\_adc\_sel = 1:
  - AUX ADC0 pin connected to aux ADC
- aux\_adc\_sel = 2:
  - AUX ADC1 pin connected to aux ADC
- aux\_adc\_sel = 3:
  - AUX\_ADC2 pin connected to aux ADC
- aux\_adc\_sel = 4:
  - AUX\_ADC3 pin connected to aux ADC

A conversion in initiated by writing to register 39 with bit 15 (aux\_adc\_trig) high. The conversion time is 8704 MCLK cycles. At the end of the conversion auc\_adc\_done goes high and the result is returned in aux\_adc\_out. As an alternative to polling aux\_adc\_done, the AFE8221 can be configured to generate an interrupt when an auxiliary ADC conversion is completed. Table 12 shows the aux\_adc operation control settings.

Table 12. AUX\_ADC Control Register Settings

| PARAMETER    | ADDRESS | BITS |
|--------------|---------|------|
| aux_adc_done | 39      | 15   |
| aux_adc_out  | 39      | 7:0  |
| aux_adc_sel  | 39      | 11:8 |
| aux_adc_trig | 39      | 15   |

#### **Master Clock Oscillator**

The master clock oscillator supports third-overtone designs from 55 MHz to 75 MHz. It can also support fundamental operations in the 20-MHz to 30-MHz range. The recommended third-overtone circuit for third-overtone operation is shown in Figure 18 and Table 13.



Figure 18. Third-Overtone Operation

**Table 13. Third-Overtone Operation Recommendations** 

| FREQUENCY (MHz) | C <sub>1</sub> (pF) | C <sub>2</sub> (pF) | <b>L1</b> (μ <b>H</b> ) | <b>L2</b><br>(μ <b>H</b> ) | R <sub>1</sub><br>(kΩ) |
|-----------------|---------------------|---------------------|-------------------------|----------------------------|------------------------|
| 55              | 3                   | 10                  | 0.1                     | 4.7                        | 6.8                    |
| 60              | 5                   | 10                  | 0.82                    | 3.3                        | 4.7                    |
| 65              | 4                   | 10                  | 0.68                    | 2.7                        | 3.3                    |
| 70              | 5                   | 10                  | 0.56                    | 2.7                        | 3.3                    |
| 75              | 3                   | 10                  | 0.56                    | 2.2                        | 3.3                    |

The master clock oscillator may be optionally divided down to provide a reference clock on the REFCLK pin. Control variable  $refclk\_en$  enables the generation of the reference clock when high. Two variables,  $refclk\_hi$  and  $refclk\_lo$ , define the high and low periods of REFCLK in terms of MCLK cycles. REFCLK is high for  $refclk\_hi$  cycles of MCLK, then low for  $refclk\_lo$  periods of MCLK. REFCLK frequency is limited to integer submultiples of MCLK. Table 14 shows the refclk operation control settings.

**Table 14. REFCLK Control Register Settings** 

| PARAMETER | ADDRESS | BITS |
|-----------|---------|------|
| refclk_en | 1       | 13   |
| refclk_hi | 41      | 15:0 |
| refclk_lo | 40      | 15:0 |

### **Real-Time Clock Oscillator**

The real-time clock oscillator supports crystals in the frequency range of 32.768 kHz through 150 kHz. The real-time clock module can be programmed to operate accurately with crystals in this frequency range.

The real-time clock oscillator output may be optionally output on the RTC\_OUT pin when *rtc\_oe* is set high. This option allows the real-time clock oscillator to be used as an alternate reference clock in the event that an acceptable frequency cannot be derived from MCLK. Table 15 shows the *rtc\_oe* control setting.

**Table 15. RTC Control Register Setting** 

| PARAMETER | ADDRESS | BITS |
|-----------|---------|------|
| rtc_oe    | 1       | 12   |

### I<sup>2</sup>C Master

The I<sup>2</sup>C Master interface uses control variables (as shown in Table 16) and two 16-byte buffers to create I<sup>2</sup>C bus transactions compliant with the Philips I<sup>2</sup>C-Bus Specification Version 2.1. Both 7- and 10-bit addressing schemes are supported. Control variables supply address, data transfer direction, data burst length, and transaction control information to an I<sup>2</sup>C master engine. This engine handles the details of the I<sup>2</sup>C signaling and uses two 16-byte buffers to store data transferred during the transaction. A block diagram for this interface is illustrated in Figure 19.

SCL clock rates are controlled using the i2cm\_clk\_cycles control variable given by Equation 24.

$$f_{SCL} = \frac{f_{MCLK}}{4 \times i2cm\_clk\_cycles}$$
 (24)

The interface supports both standard and fast-mode clock rates of 100 kHz and 400 kHz, respectively. Although two pairs of SCL and SDA pins are provided, the pins share a common master function. Reprogramming of the *i2cm\_if\_select* variable should only be performed when the *i2cm\_done* status is 1, indicating that all pending I<sup>2</sup>C transactions have completed and that it is safe to change the selected pair.



www.ti.com

# Table 16. I<sup>2</sup>C Control Register Settings

| PARAMETER                | ADDRESS | BITS |
|--------------------------|---------|------|
| i2cm_10b_addressing      | 124     | 12   |
| i2cm_allow_slave_nack    | 124     | 10   |
| i2cm_clear_slave_nack    | 124     | 11   |
| i2cm_clk_cycles          | 124     | 7:0  |
| i2cm_done                | 124     | 15   |
| i2cm_holding             | 124     | 14   |
| i2cm_if_sel              | 121     | 14   |
| i2cm_multimaster         | 124     | 8    |
| i2cm_read_auto_inc       | 123     | 15   |
| i2cm_read_byte           | 123     | 7:0  |
| i2cm_read_byte_ptr       | 123     | 11:8 |
| i2cm_restart_data_length | 121     | 12:8 |
| i2cm_restart_rw          | 121     | 13   |
| i2cm_scl_sync_en         | 124     | 9    |
| i2cm_slave_addr          | 120     | 14:0 |
| i2cm_start_data_length   | 121     | 4:0  |
| i2cm_start_rw            | 121     | 5    |
| i2cm_use_sr              | 121     | 15   |
| i2cm_use_stop            | 124     | 13   |
| i2cm_write_auto_inc      | 122     | 15   |
| i2cm_write_byte          | 122     | 7:0  |
| i2cm_write_byte_ptr      | 122     | 11:8 |





Figure 19. I<sup>2</sup>C Master Block Diagram

#### I<sup>2</sup>C Write Transactions

Write data must be stored in sequential locations in the write buffer starting at location zero. *i2cm\_write\_byte\_ptr[3:0]* specifies one of the 16 memory locations where *i2cm\_write\_byte[7:0]* data will be written. An auto-increment feature permits the internal update of this pointer without specifying an offset for each byte after the first byte.

Once the desired write data are loaded into this memory, *i2cm\_start\_data\_length[4:0]* must specify the number of bytes to write and *i2cm\_start\_rw* should be set to 0, indicating that write data will follow the address. *i2cm\_10b\_addr* should be set to select the desired 7- or 10-bit addressing scheme as described in the Control Register Assignments section of this document.

The write transaction is initiated by writing the slave address to  $i2cm\_slave\_addr$ . The host controller should poll the  $i2cm\_done$  bit for a 1, indicating that the transaction has completed. The sequence of actions generated on the  $I^2C$  bus are:

Start → Slave Addr → Write Data Burst → Stop

#### I<sup>2</sup>C Read Transactions

i2cm\_start\_data\_length[4:0] must specify the number of bytes to read and i2cm\_start\_rw should be 1, indicating that read data will follow the address. i2cm\_10b\_addr specifies the addressing scheme.

The read transaction is initiated by writing the slave address to *i2cm\_slave\_addr*. The host controller should poll the *i2cm\_done* bit for a 1, indicating the transaction has completed. Once completed, the read data can be extracted from the read buffer using the control variables *i2cm\_read\_ptr[3:0]* and *i2cm\_read\_byte[7:0]*. The sequence of actions generated on the bus are:

Start → Slave Addr → Read Data Burst → Stop

#### I<sup>2</sup>C Combined Format Transactions

The I<sup>2</sup>C specification describes combined write/read formats where a master initially transmits data to a slave and then reads data from the same slave. The *i2cm\_use\_sr* parameter is used to create a repeated START condition to support this format. By setting the *i2cm\_use\_sr* parameter to 1, the master interface can create the following sequence of actions:

Start → Slave Addr → Data Burst 1 →

Start → Slave Addr → Data Burst 2 → Stop

*i2cm\_start\_data\_length[4:0]* and *i2cm\_start\_rw* control the data burst length and direction for DATA BURST 1. *i2cm\_restart\_data\_length[4:0]* and *i2cm\_restart\_rw* control the data burst length and direction for DATA BURST 2. If the data direction is the same for both halves of the combined transaction, data are stored sequentially in the 16-byte buffer. Writing *i2cm\_slave\_addr* initiates the transaction.

#### I<sup>2</sup>C Data Bursts Greater than 16 Bytes

To create an I<sup>2</sup>C read or write burst greater than 16 bytes, the *i2cm\_use\_stop* parameter should be set to 0, causing the interface to pause between each burst of bytes transferred. This pause allows the host to either reload or empty the buffers, depending on the direction of data transfer.

After starting the transaction by writing *i2cm\_slave\_addr*, the *i2cm\_holding* status bit should be monitored for a logic 1, indicating that the interface has completed the current set of byte transfers and is waiting for the host to continue. After reloading or emptying the buffers as needed, the host should rewrite *i2cm\_slave\_address* to continue the transfer for the next block of up to 16 bytes. For the final transfer of the long data burst, *i2cm\_use\_stop* must be set to 1 prior to re-writing the *i2cm\_slave\_address*. This configuration creates a normal STOP condition to properly terminate the transfer.

### **Interrupt Operation**

As an alternative to polling the values of *i2cm\_done* or *i2cm\_use\_stop*, the AFE8221 can be programmed to generate an interrupt when either of these values goes high.

#### **Real-Time Clock**

The real-time clock (RTC) is enabled by setting *rtc\_en* to 1. While *rtc\_en* is 0, the RTC oscillator continues to run but the RTC registers do not advance.

The RTC can operate with a range of oscillator frequencies up to 100 kHz. At the beginning of each second, 2x the value of *rtc\_max\_count* is loaded into the RTC crystal counter. This counter is decremented at the rate of the RTC oscillator until it hits zero, which generates a strobe that increments the seconds counter as well as re-initializes the RTC crystal counter. For a nominal 32.768-kHz clock crystal, *rtc\_max\_count* should be set to 16,384 (the default value); for a nominal 100-kHz crystal, *rtc\_max\_count* should be set to 50,000. Table 18 illustrates the RTC control variable settings.

The RTC can be coarsely calibrated by adjusting the *rtc\_max\_count* to an appropriate value other than half the nominal crystal frequency. If finer calibration is required, compensation mode can be enabled by setting *rtc\_comp\_en* to 1. In compensation mode, the two's-complement value stored in *rtc\_comp\_val* is added to the one-second counter when it is re-initialized at the beginning of each hour; thus, the first second of each hour is lengthened or shortened depending on the sign of *rtc\_comp\_val*. The compensation can be applied to several seconds at the beginning of each hour; *rtc\_comp\_cnt* holds the number of seconds per hour to which the compensation is applied. By spreading the compensation out over a number of seconds, the impact on the length of any given second is minimized.

## Setting and Reading the RTC

Because of the need to carefully synchronize any update of the RTC time registers (*rtc\_seconds*, *rtc\_minutes*, etc.), they must be written in a slightly different manner than the other control registers. Time registers must be written individually; after a particular register address is written, at least two clock cycles of the RTC oscillator must pass before another register write occurs. The MSB of each time register address can be polled to determine if it is safe to make another write: if the MSB is 1, the interface is still busy and a new write should not be initiated. If the MSB is 0, then the interface is ready to accept another write. There is no limitation on reading the time registers.



Note that all time register values are BCD-encoded. Also note that the *rtc\_day\_of\_week* is a read-only value that is internally calculated from the *rtc\_day*, *rtc\_month*, and *rtc\_year* registers. Ranges on the various time registers are shown in Table 17. When the rtc\_mode changes, the real-time clock alarm settings should also be changed to reflect the new time format. For instance, an alarm setting of 1300 hours never generates an interrupt in 12-hour mode. This setting should be reset to 1:00 PM when the mode is changed to 12-hour mode.

**Table 17. Time Register Ranges** 

| PARAMETER       | RANGE                                             |
|-----------------|---------------------------------------------------|
| rtc_seconds     | 0 to 59                                           |
| rtc_minutes     | 0 to 59                                           |
| rtc_hours       | 1 to 12 (12-hour mode);<br>0 to 23 (24-hour mode) |
| rtc_ampm        | 0 (AM) or 1 (PM)<br>12-hour mode only             |
| rtc_day         | 1 to 31, depending on month                       |
| rtc_month       | 1 to 12                                           |
| rtc_year        | 0 to 99<br>(for years 2000 to 2099)               |
| rtc_day_of_week | 0 (Sunday) to 6 (Saturday)                        |

Invalid combinations of *rtc\_day* and *rtc\_month* (trying to set February 30, for example) cause unpredictable behavior and should be avoided. The February 28/29 rollover variation based on leap year is automatically corrected for.

The RTC defaults to operate in 12-hour plus AM/PM mode. To operate in 24-hour mode (where the AM/PM bits are disabled) set *rtc\_mode* to 1. Care must be taken when switching between AM/PM mode and 24-hour mode to avoid setting the time to a invalid value. See Figure 20 and Figure 21 for the proper procedures.

#### **Real-Time Clock Alarm**

The real-time clock alarm function can be used to generate an interrupt (or a wakeup interrupt) at a pre-programmed time. If the appropriate bit in an interrupt enable register is set, an interrupt will be generated when the values in the RTC time registers become equal to the values in the RTC alarm registers. The register settings are shown in Table 18.

**Table 18. RTC Alarm Control Register Settings** 

| PARAMETER              | ADDRESS | BITS |
|------------------------|---------|------|
| rtc_seconds_alarm[6:0] | 67      | 6:0  |
| rtc_minutes_alarm[6:0] | 68      | 6:0  |
| rtc_hours_alarm[5:0]   | 69      | 5:0  |
| rtc_ampm_alarm         | 69      | 7    |
| rtc_day_alarm[5:0]     | 70      | 5:0  |
| rtc_month_arlarm[4:0]  | 71      | 4:0  |
| rtc_year_alarm[7:0]    | 72      | 7:0  |

### **GPIO**

12 general-purpose I/O pins are provided, labeled GPIO0 through GPIO11. The direction of the 12 GPIO pins can be independently set through control variable *gpio\_oe(11:0)*. A pin is an input if the corresponding bit of *gpio\_oe* is 0; a pin is an output if the corresponding bit of *gpio\_oe* is 1.

The control variable *gpio(11:0)* serves different functions, depending on whether it is read from or written to. A read operation from *gpio* returns the logic state of the eight GPIO pins regardless of their direction. A write to *gpio* sets the output state of the GPIO pins if they are configured as outputs; there is no effect if the pin is configured as an input. Note that the write value of *gpio* is stored in a register, so that if a GPIO pin is changed from an input to an output its logic state is set by the stored value of *gpio*. Table 21 shows the *gpio* control variable settings.

The GPIO inputs can be optionally debounced if an RTC oscillator is running. Debouncing is controlled by *gpio\_delay*, which is divided into 12 2-bit fields, each controlling a particular GPIO input according to Table 19.

### Table 19. gpio\_delay

| [23:22] | [21:20] | [19:18] | [17:16] | [15:14] | [13:12] | [11:10] | [9:8] | [7:6] | [5:4] | [3:2] | [1:0] |
|---------|---------|---------|---------|---------|---------|---------|-------|-------|-------|-------|-------|
| GPIO11  | GPIO10  | GPIO9   | GPIO8   | GPIO7   | GPIO6   | GPIO5   | GPIO4 | GPIO3 | GPIO2 | GPIO1 | GPIO0 |



Figure 20. Procedure for Updating RTC Hour When Going from 12-Hour Mode to 24-Hour Mode





Figure 21. Procedure for Updating RTC Hour When Going from 24-Hour Mode to 12-Hour Mode

The debounce circuitry uses a clock divided from the RTC oscillator, with a debounce clock frequency given by Equation 25.

$$f_{DEBOUNCE} = \frac{f_{RTC}}{2^{2 \times GPIO\_DEBOUNCE\_FREQ+1}}$$
(25)

If debounce is enabled, then in order for a GPIO input to change value (and possibly generate an interrupt if so programmed) it must remain stable for the number of debounce clock cycles (zero to three) given in the appropriate field of *gpio\_delay*.



www.ti.com SBAS434-DECEMBER 2008

Table 20. General RTC Control Register Settings

| PARAMETER            | ADDRESS | BITS |
|----------------------|---------|------|
| rtc_ampm             | 75      | 7    |
| rtc_comp_cnt[5:0]    | 64      | 12:7 |
| rtc_comp_en          | 64      | 2    |
| rtc_comp_val         | 66      | 15:0 |
| rtc_day[5:0]         | 76      | 5:0  |
| rtc_day_of_week[2:0] | 79      | 2:0  |
| rtc_en               | 64      | 0    |
| rtc_hours[5:0]       | 75      | 5:0  |
| rtc_max_count[15:0]  | 65      | 15:0 |
| rtc_minutes[6:0]     | 74      | 6:0  |
| rtc_mode             | 64      | 1    |
| rtc_month[4:0]       | 77      | 4:0  |
| rtc_seconds[6:0]     | 73      | 6:0  |
| rtc_year[7:0]        | 78      | 7:0  |

**Table 21. GPIO Control Register Settings** 

| PARAMETER        | ADDRESS | BITS |
|------------------|---------|------|
| gpio             | 43      | 11:0 |
| gpio_delay[15:0] | 44      | 15:0 |
| gpio_oe          | 42      | 11:0 |

### Alternate Registers (GPIO and Input Attenuator)

If some of the GPIO pins on the AFE8221 are to be used to control the gain of a tuner, it may be desirable to change the GPIO values at the same time as the input attenuation to the DDC. To make this process more deterministic, the control parameters *gpio*, *ddc0\_atten*, and *ddc1\_atten* can be accessed through the alternate control register addresses of 96 and 97. By writing to register 96, *gpio* and *ddc0\_atten* can be changed in a single register write; by writing to register 97, *gpio* and *ddc1\_atten* can be changed in a single register write. Table 22 shows the operation control settings for these parameters.

Table 22. Alternate GPIO and DDC Control Register Settings

| PARAMETER  | ADDRESS | BITS  |
|------------|---------|-------|
| anio       | 96      | 11:0  |
| gpio       | 97      | 11.0  |
| ddc0_atten | 96      | 14:12 |
| ddc1_atten | 97      | 14:12 |

#### **Interrupt Generators**

There are three programmable interrupt pins; IRQ0, IRQ1, and IRQ2. Only the operation of IRQ0 is described here; IRQ1 and IRQ2 are programmed in the same way, using different control variables.

Interrupts can be generated from various sources. Interrupt generation is enabled through *irq0\_en*, as Table 23 shows.



**Table 23. Interrupt Generation** 

| BIT POSITION | SOURCE                       | BIT POSITION | SOURCE               |
|--------------|------------------------------|--------------|----------------------|
| 0            | GPIO                         | 8            | RTC alarm            |
| 1            | None                         | 9            | RTC seconds rollover |
| 2            | I <sup>2</sup> C Master done | 10           | RTC minutes rollover |
| 3            | Aux ADC done                 | 11           | RTC hours rollover   |
| 4            | IFADC0 over-range            | 12           | RTC months rollover  |
| 5            | IFADC1 over-range            | 13           | RTC day rollover     |
| 6            | IFADC0 limit                 | 14           | RTC year rollover    |
| 7            | IFADC1 limit                 | 15           | _                    |

Setting a bit of *irq0\_en* allows the generation of an interrupt for the corresponding event. All three IRQ generators run on the master clock (MCLK). When an interrupt event occurs on a given source signal, a value of 1 is written to the corresponding bit of *irq0\_status*. This value is held in *irq0\_status* until it is explicitly cleared by writing a 0 to the appropriate bit of *irq0\_status*. A typical sequence upon receipt of an interrupt would be to poll *irq0\_status* to determine the source of the interrupt, take whatever system action is appropriate, and then clear *irq0\_status*.

Changes to any of the GPIO pins can also be programmed as interrupts. GPIO pin events are defined as changes from low to high or from high to low, depending on whether the corresponding bit in  $irq0\_gpio\_edge$  is high or low. GPIO interrupts are enabled by setting the corresponding bit in  $irq0\_gpio\_en$ ; they are identified and cleared by reading and writing the corresponding bit in  $irq0\_gpio\_status$ .

The behavior of the IRQ0 pin is determined by *irq0\_sense*. When *irq0\_sense* is 0, IRQ0 is normally low and goes high on an unmasked interrupt event. When *irq0\_sense* is 1, IRQ0 is normally high and goes low on an unmasked interrupt event. Table 24 shows the *irq0*, *irq1*, and *irq2* operations control settings.

**Table 24. IRQ Control Register Settings** 

| 3       |                                                                                                      |  |  |
|---------|------------------------------------------------------------------------------------------------------|--|--|
| ADDRESS | BITS                                                                                                 |  |  |
| 50      | 15:0                                                                                                 |  |  |
| 55      | 15:0                                                                                                 |  |  |
| 60      | 15:0                                                                                                 |  |  |
| 48      | 11:0                                                                                                 |  |  |
| 53      | 11:0                                                                                                 |  |  |
| 58      | 11:0                                                                                                 |  |  |
| 49      | 11:0                                                                                                 |  |  |
| 54      | 11:0                                                                                                 |  |  |
| 59      | 11:0                                                                                                 |  |  |
| 52      | 11:0                                                                                                 |  |  |
| 57      | 11:0                                                                                                 |  |  |
| 62      | 11:0                                                                                                 |  |  |
| 2       | 1                                                                                                    |  |  |
| 2       | 2                                                                                                    |  |  |
| 2       | 3                                                                                                    |  |  |
| 51      | 15:0                                                                                                 |  |  |
| 56      | 15:0                                                                                                 |  |  |
| 61      | 15:0                                                                                                 |  |  |
|         | 50<br>55<br>60<br>48<br>53<br>58<br>49<br>54<br>59<br>52<br>57<br>62<br>2<br>2<br>2<br>2<br>51<br>56 |  |  |

www.ti.com SBAS434-DECEMBER 2008

### **Wakeup Interrupt Generator**

The WAKEUP interrupt generator functions in the same way as the IRQ generators with the following exceptions:

- 1. The WAKEUP generator runs on the RTC clock instead of MCLK;
- The WAKEUP generator operates when the AFE is in low-power mode, whereas the IRQ generators do not; and
- 3. The interrupt sources for the WAKEUP interrupt generator are slightly different.

Table 25 shows the wakeup control settings. Table 26 shows the generator functions.

**Table 25. Wakeup Control Register Settings** 

| PARAMETER          | ADDRESS | BITS |
|--------------------|---------|------|
| wakeup_sense       | 2       | 0    |
| wakeup_gpio_edge   | 80      | 11:0 |
| wakeup_gpio_en     | 81      | 11:0 |
| wakeup_en          | 82      | 15:0 |
| wakeup_status      | 83      | 15:0 |
| wakeup_gpio_status | 84      | 11:0 |

**Table 26. WAKEUP Interrupt Generator** 

| BIT POSITION | SOURCE               |  |
|--------------|----------------------|--|
| 0            | GPIO                 |  |
| 1            | None                 |  |
| 2            | None                 |  |
| 3            | None                 |  |
| 4            | None                 |  |
| 5            | None                 |  |
| 6            | None                 |  |
| 7            | None                 |  |
| 8            | RTC alarm            |  |
| 9            | RTC seconds rollover |  |
| 10           | RTC minutes rollover |  |
| 11           | RTC hours rollover   |  |
| 12           | RTC months rollover  |  |
| 13           | RTC day rollover     |  |
| 14           | RTC year rollover    |  |



# **Control Register Assignments**

### **Table 27. Control Registers**

|       | Address:     | 1                                    |                         |
|-------|--------------|--------------------------------------|-------------------------|
|       |              | Functional Block Enables             |                         |
| Bits  |              | Action                               | Parameter Name          |
| 1:0   | Range        | Enable IFADC converters              |                         |
| -     | 03           |                                      | ifadc_en(1:0)           |
| 2     | 0/1          | Gain control for IF_ADC0             | ifadc_gain0             |
| 3     | 0/1          | Gain control for IF_ADC1             | ifadc_gain1             |
| 5:4   | 03           | Enable DDCs                          | ddc_en(1:0)             |
| 6     | 0/1          | Synchronize DDC0 and DDC1            | ddc_sync                |
| 7     | 0/1          | Enable primary IF data interface     | dout_en                 |
| 8     | 0/1          | Enable secondary IF data interface   | bb_en                   |
| 10:9  | 03           | Enable auxiliary DACs                | cdac_en(1:0)            |
| 11    | 0/1          | Enable auxiliary ADC                 | aux_adc_en              |
| 12    | 0/1          | Enable RTC output pins               | rtc_oe                  |
| 13    | 0/1          | Enable reference clock output pins   | refclk_en               |
|       | Address:     | 2                                    |                         |
|       | Description: | Interrupt Output Level Configuration |                         |
| Bits  | Range        | Action                               | Parameter Name          |
| 0     | 0/1          | 0 = Active high WAKEUP interrupt     | wokeup conce            |
| U     | 0/1          | 1 = Active low WAKEUP interrupt      | wakeup_sense            |
| 4     | 0.44         | 0 = Active high IRQ0 interrupt       | :0                      |
| 1     | 0/1          | 1 = Active low IRQ0 interrupt        | irq0_sense              |
| 0     | 0.14         | 0 = Active high IRQ1 interrupt       |                         |
| 2     | 0/1          | 1 = Active low IRQ1 interrupt        | irq1_sense              |
|       | 24           | 0 = Active high IRQ2 interrupt       |                         |
| 3     | 0/1          | 1 = Active low IRQ2 interrupt        | irq2_sense              |
|       | Address:     | 3                                    |                         |
|       | Description: | DDC0 Input Attenuator                |                         |
| Bits  | Range        | Action                               | Parameter Name          |
| 2:0   | 06           | Attenuation setting for DDC0         | ddc_atten(2:0)          |
| I     | Address:     | 4                                    |                         |
|       | Description: | DDC0 Input Attenuator                |                         |
| Bits  | Range        | Action                               | Parameter Name          |
| 15:0  | 065535       | Delay setting for DDC0 attenuator    | ddc0_delay(15:0)        |
|       | Address:     |                                      | 1 - ,,                  |
|       | Description: | DDC0 NCO Frequency                   |                         |
| Bits  | Range        | Action                               | Parameter Name          |
| 15:0  | 065535       | Upper bytes of DDC0 NCO frequency    | ddc0_demod_freq(31:16)  |
|       | Address:     | <u> </u>                             |                         |
|       |              | DDC0 NCO Frequency                   |                         |
| Bits  | Range        | Action                               | Parameter Name          |
| 15:0  | 065535       | Lower bytes of DDC0 NCO frequency    | ddc0_demod_freg(15:0)   |
| . 5.0 | Address:     | , ,                                  |                         |
|       |              | DDC0 NCO Phase                       |                         |
| Bits  | Range        | Action                               | Parameter Name          |
|       |              |                                      |                         |
| 15:0  | 065535       | Upper bytes of DDC0 NCO phase        | ddc0_demod_phase(31:16) |



|            | Address:     | 8                                                           |                                              |
|------------|--------------|-------------------------------------------------------------|----------------------------------------------|
|            |              | DDC0 NCO Phase (continued)                                  |                                              |
| Bits       | Range        | Action                                                      | Parameter name                               |
| 15:0       | 065535       | Lower bytes of DDC0 NCO phase                               | ddc0_demod_phase(15:0)                       |
|            | Address:     | 9                                                           |                                              |
|            | Description: | DDC0 CIC Filter                                             |                                              |
| Bits       | Range        | Action                                                      | Parameter Name                               |
| 8:0        | 4256         | CIC filter decimation rate                                  | ddc0_cic_dec_rate(8:0)                       |
|            | Address:     | 10                                                          |                                              |
|            | Description: | DDC0 CIC Filter                                             |                                              |
| Bits       | Range        | Action                                                      | Parameter Name                               |
| 5:0        | 063          | CIC filter post-filter shift                                | ddc0_cic_shift(5:0)                          |
| 11:6       | 032          | CIC filter post-filter scale                                | ddc0_cic_scale(5:0)                          |
|            | Address:     | 11                                                          |                                              |
|            | Description: | DDC0 FIR Filter 1                                           |                                              |
| Bits       | Range        | Action                                                      | Parameter Name                               |
| 1:0        | 03           | FIR filter mode                                             | ddc0_fir1_mode(1:0)                          |
| 7:2        | 063          | Number of coefficients to process                           | ddc0_fir1_ncoeffs(5:0)                       |
| 13:8       | 063          | Coefficient base address                                    | ddc0_fir1_base_addr(5:0)                     |
|            | Address:     |                                                             |                                              |
|            | •            | DDC0 FIR Filter 2A                                          | 1-                                           |
| Bits       | Range        | Action                                                      | Parameter Name                               |
| 1:0        | 03           | FIR filter mode                                             | ddc0_fir2a_mode(1:0)                         |
| 8:2        | 0127         | Number of coefficients to process                           | ddc0_fir2a_ncoeffs(6:0)                      |
| 15:9       | 0127         | Coefficient base address                                    | ddc0_fir2a_base_addr(6:0)                    |
|            | Address:     |                                                             |                                              |
| Dito.      |              | DDC0 FIR Filter 2B                                          | Daramatar Nama                               |
| Bits       | Range        | Action                                                      | Parameter Name                               |
| 1:0<br>8:2 | 03           | FIR filter mode                                             | ddc0_fir2b_mode(1:0) ddc0_fir2b_ncoeffs(6:0) |
| 15:9       | 0127         | Number of coefficients to process  Coefficient base address | ddc0_fir2b_ficoefis(6:0)                     |
| 13.3       | Address:     |                                                             | ddco_iii2b_base_addi(0.0)                    |
|            |              | DDC0 FIR Filter Extended Features                           |                                              |
| Bits       | Range        | Action                                                      | Parameter Name                               |
| 3:0        | 015          | Post-filter shift for FIR filter 2A                         | ddc0_fir2a_shift(3:0)                        |
| 7:4        | 015          | Post-filter shift for FIR filter 2B                         | ddc0_fir2b_shift(3:0)                        |
| 8          | 0/1          | Enable interleave mode for FIR filter 2A and FIR filter 2B  | ddc0_interleave                              |
| 9          | 0/1          | Disable decimation for FIR filter 1                         | ddc0_fir1_nodec                              |
| 10         | 0/1          | Disable decimation for FIR filter 2A and FIR filter 2B      | ddc0_fir2_nodec                              |
| I          | Address:     | 15                                                          |                                              |
|            | Description: | DDC1 Input Attenuator                                       |                                              |
| Bits       | Range        | Action                                                      | Parameter Name                               |
| 2:0        | 06           | Attenuation setting for DDC1                                | ddc1_atten(2:0)                              |
|            | Address:     | 16                                                          | ,                                            |
|            | Description: | DDC1 Input Attenuator                                       |                                              |
| Bits       | Range        | Action                                                      | Parameter Name                               |
| 15:0       | 065535       | Delay setting for DDC1 attenuator                           | ddc1_delay(15:0)                             |
|            |              |                                                             |                                              |

SBAS434-DECEMBER 2008





|       | A dalue c c -            | 147                               | ,                         |
|-------|--------------------------|-----------------------------------|---------------------------|
|       | Address:                 |                                   |                           |
| Dito. |                          | DDC1 NCO Frequency Action         | Devemeter Name            |
| Bits  | Range                    |                                   | Parameter Name            |
| 15:0  | 065535<br>Address:       | Upper bytes of DDC1 NCO frequency | ddc1_demod_freq(31:16)    |
|       |                          |                                   |                           |
| Dito. |                          | DDC1 NCO Frequency Action         | Devemeter Name            |
| Bits  | Range                    |                                   | Parameter Name            |
| 15:0  | 065535                   | Lower bytes of DDC1 NCO frequency | ddc1_demod_freq(15:0)     |
|       | Address:                 |                                   |                           |
| D't-  | •                        | DDC1 NCO Phase                    | Decreased in Name         |
| Bits  | Range                    | Action                            | Parameter Name            |
| 15:0  | 065535                   | Upper bytes of DDC1 NCO phase     | ddc1_demod_phase(31:16)   |
|       | Address:                 |                                   |                           |
|       | -                        | DDC1 NCO Phase                    |                           |
| Bits  | Range                    | Action                            | Parameter Name            |
| 15:0  | 065536                   | Lower bytes of DDC1 NCO phase     | ddc1_demod_phase(15:0)    |
|       | Address:                 |                                   |                           |
|       | •                        | DDC1 CIC Filter Decimation        |                           |
| Bits  | Range                    | Action                            | Parameter Name            |
| 8:0   | 4256                     | CIC filter decimation rate        | ddc1_cic_dec_rate(8:0)    |
|       | Address:<br>Description: | DDC1 CIC Filter                   |                           |
| Bits  | Range                    | Action                            | Parameter Name            |
| 5:0   | 063                      | CIC filter post-filter shift      | ddc1_cic_shift(5:0)       |
| 11:6  | 032                      | CIC filter post-filter scale      | ddc1_cic_scale(5:0)       |
|       | Address:                 | 23                                |                           |
|       | Description:             | DDC1 FIR Filter 1                 |                           |
| Bits  | Range                    | Action                            | Parameter Name            |
| 1:0   | 03                       | FIR filter mode                   | ddc1_fir1_mode(1:0)       |
| 7:2   | 063                      | Number of coefficients to process | ddc1_fir1_ncoeffs(5:0)    |
| 13:8  | 063                      | Coefficient base address          | ddc1_fir1_base_addr(5:0)  |
|       | Address:                 | 24                                |                           |
|       | Description:             | DDC1 FIR Filter 2A                |                           |
| Bits  | Range                    | Action                            | Parameter Name            |
| 1:0   | 03                       | FIR filter mode                   | ddc1_fir2a_mode(1:0)      |
| 8:2   | 0127                     | Number of coefficients to process | ddc1_fir2a_ncoeffs(6:0)   |
| 15:9  | 0127                     | Coefficient base address          | ddc1_fir2a_base_addr(6:0) |
| I     | Address:                 | 25                                | ,                         |
|       | Description:             | DDC1 FIR Filter 2B                |                           |
| Bits  | Range                    | Action                            | Parameter Name            |
| 1:0   | 03                       | FIR filter mode                   | ddc1_fir2b_mode(1:0)      |
| 8:2   | 0127                     | Number of coefficients to process | ddc1_fir2b_ncoeffs(6:0)   |
| 15:9  | 0127                     | Coefficient base address          | ddc1_fir2b_base_addr(6:0) |



|      | Address:            | 26                                                                                                                 |                       |
|------|---------------------|--------------------------------------------------------------------------------------------------------------------|-----------------------|
|      | Description:        | DDC1 FIR Filter Extended Features                                                                                  |                       |
| Bits | Range               | Action                                                                                                             | Parameter Name        |
| 3:0  | 015                 | Post-filter shift for FIR filter 2A                                                                                | ddc1_fir2a_shift(3:0) |
| 7:4  | 015                 | Post-filter shift for FIR filter 2B                                                                                | ddc1_fir2b_shift(3:0) |
| 8    | 0/1                 | Enable interleave mode for FIR filter 2A and FIR filter 2B                                                         | ddc1_interleave       |
| 9    | 0/1                 | Disable decimation for FIR filter 1                                                                                | ddc1_fir1_nodec       |
| 10   | 0/1                 | Disable decimation for FIR filter 2A and FIR filter 2B                                                             | ddc1_fir2_nodec       |
|      | Address:            | 27                                                                                                                 |                       |
|      | Description:        | Data Interface Configuration                                                                                       |                       |
| Bits | Range               | Action                                                                                                             | Parameter Name        |
| 15:0 | 065535              | Configuration for IF_DOUT0                                                                                         | if_dout0_config       |
|      | Address:            | 28                                                                                                                 |                       |
|      |                     | Data Interface Configuration                                                                                       |                       |
| Bits | Range               | Action                                                                                                             | Parameter Name        |
| 15:0 | 065535              | Configuration for IF_DOUT1                                                                                         | if_dout1_config       |
|      | Address:            |                                                                                                                    |                       |
|      |                     | Data Interface Configuration                                                                                       |                       |
| Bits | Range               | Action                                                                                                             | Parameter Name        |
| 15:0 | 065535              | Configuration for IF_DOUT2                                                                                         | if_dout2_config       |
|      | Address:            |                                                                                                                    |                       |
|      |                     | Data Interface Configuration                                                                                       |                       |
| Bits | Range               | Action                                                                                                             | Parameter Name        |
| 15:0 | 065535              | Configuration for IF_DOUT3                                                                                         | if_dout3_config       |
|      | Address:            |                                                                                                                    |                       |
| Bits |                     | Data Interface Configuration  Action                                                                               | Parameter Name        |
| 4:0  | <b>Range</b><br>016 | Divide factor to derive IF_DCLK from MCLK                                                                          | if_dclk_div(4:0)      |
| 4.0  | 010                 | 0: IF_DFSO and IF_DOUTx change on rising edge of IF_DCLK                                                           | II_dCIK_dIV(4.0)      |
| 5    | 0/1                 | If _DFSO and IF_DOUTX change on falling edge of IF_DCLK  I: IF_DFSO and IF_DOUTX change on falling edge of IF_DCLK | if_dclk_edge          |
|      |                     | 0: IF_DFSO generated by DDC0                                                                                       |                       |
| 6    | 0/1                 | 1: IF_DFSO generated by DDC1                                                                                       | if_dfso_select        |
|      |                     | 0: IF_DFSO one IF_DCLK cycle wide                                                                                  |                       |
| 8:7  | 02                  | 1: IF_DFSO toggles once per frame                                                                                  | if_dfso_mode(1:0)     |
| -    | - <del>-</del>      | 2: IF_DFSO 16 IF_DCLK cycles wide                                                                                  |                       |
|      | Address:            |                                                                                                                    |                       |
|      | Description:        | Data Interface Configuration                                                                                       |                       |
| Bits | Range               | Action                                                                                                             | Parameter Name        |
| 15:0 | 065535              | Configuration for BB_DOUT0                                                                                         | bb_dout0_config       |
| l.   | Address:            | 33                                                                                                                 | ·                     |
|      | Description:        | Data Interface Configuration                                                                                       |                       |
| Bits | Range               | Action                                                                                                             | Parameter Name        |
| 15:0 | 065535              | Configuration for BB_DOUT1                                                                                         | bb_dout1_config       |
| l.   | Address:            | 34                                                                                                                 | ·                     |
|      | Description:        | Data Interface Configuration                                                                                       |                       |
| Bits | Range               | Action                                                                                                             | Parameter Name        |
| 15:0 | 065535              | Configuration for BB_DOUT2                                                                                         | bb_dout2_config       |
|      |                     |                                                                                                                    |                       |



|        | A .1.1              | Table 27. Control Registers (continued)                                                 |                  |
|--------|---------------------|-----------------------------------------------------------------------------------------|------------------|
|        | Address:            |                                                                                         |                  |
| D't-   |                     | Data Interface Configuration (continued)                                                | Danier Maria     |
| Bits   | Range               | Action                                                                                  | Parameter Name   |
| 15:0   | 065535              | Configuration for BB_DOUT3                                                              | bb_dout3_config  |
|        | Address:            |                                                                                         |                  |
| Bits   | •                   | Data Interface Configuration  Action                                                    | Parameter Name   |
|        | <b>Range</b><br>016 |                                                                                         |                  |
| 4:0    | 016                 | Divide factor to derive BB_BCK from MCLK                                                | bb_bck_div(4:0)  |
| 5      | 0/1                 | 0: BB_WS and BB_DOUTx change on rising edge of BB_BCK                                   | bb_bck_edge      |
|        |                     | 1: BB_WS and BB_DOUTx change on falling edge of BB_BCK                                  |                  |
| 6      | 0/1                 | 0: BB_WS generated by DDC0                                                              | bb_ws_select     |
|        |                     | 1: BB_WS generated by DDC1                                                              |                  |
| 0.7    | 0.0                 | 0: BB_WS one BB_BCK cycle wide                                                          | ht               |
| 8:7    | 02                  | 1: BB_WS toggles once per frame                                                         | bb_ws_mode(1:0)  |
|        | A .l .l             | 2: BB_WS 16 BB_BCK cycles wide                                                          |                  |
|        | Address:            |                                                                                         |                  |
| D't-   |                     | CDAC0 Output Action                                                                     | Parameter Name   |
| Bits   | Range               |                                                                                         |                  |
| 11:0   | 04095               | Output value for CDAC0                                                                  | cdac0_out(11:0)  |
|        | Address:            |                                                                                         |                  |
| Dita   |                     | CDAC1 Output                                                                            | Danamatan Nama   |
| Bits   | Range               | Action                                                                                  | Parameter Name   |
| 11:0   | 04095               | Output value for CDAC1                                                                  | cdac1_out(11:0)  |
|        | Address:            |                                                                                         |                  |
| Dito   | Description:        | Action                                                                                  | Parameter Name   |
| Bits   | Range               |                                                                                         |                  |
| 7:0    | 0255                | Register read: Conversion result for auxiliary ADC (read only)                          | aux_adc_out(7:0) |
|        |                     | 0: No aux ADC inputs connected                                                          |                  |
| 44.0   | 0.4.0.4.5.0         | 1: AUX_ADC0 pin connected to aux ADC                                                    |                  |
| 11:8   | 0, 1, 2, 4, or 8    | 2: AUX_ADC1 pin connected to aux ADC                                                    | aux_adc_sel(3:0) |
|        |                     | 4: AUX_ADC2 pin connected to aux ADC                                                    |                  |
| 4.4.40 |                     | 8: AUX_ADC3 pin connected to aux ADC                                                    |                  |
| 14:12  |                     | Not used                                                                                |                  |
| 15     | 0/1                 | Register write: Starts a conversion when 1 is written                                   | aux_adc_done     |
| 15     | 0/1                 | Register read: Returns 0 while conversion is in progress, 1 when conversion is finished | aux_auc_uone     |
|        | Address:            |                                                                                         |                  |
|        |                     | Reference Clock Configuration                                                           |                  |
| Bits   | Range               | Action                                                                                  | Parameter Name   |
| 15:0   | 04095               | Low period ( in units of MCLK cycles) for reference clock output                        | refclk_lo(15:0)  |
| II.    | Address:            |                                                                                         |                  |
|        |                     | Reference Clock Configuration                                                           |                  |
| Bits   | Range               | Action                                                                                  | Parameter Name   |
|        | 04095               | High period (in units of MCLK cycles) for reference clock output                        | refclk_hi(15:0)  |



|       |              | Table 27. Control Registers (continued)                        |                |
|-------|--------------|----------------------------------------------------------------|----------------|
|       | Address:     |                                                                |                |
|       | Description: | GPIO Configuration                                             |                |
| Bits  | Range        | Action                                                         | Parameter Name |
| 0     | 0/1          | 0 = GPIO0 set as input                                         | gpio_oe(0)     |
|       | <u> </u>     | 1 = GPIO0 set as output                                        | gb::=_cc(c)    |
| 1 0/1 |              | 0 = GPIO1 set as input                                         | gpio_oe(1)     |
| •     | 0/1          | 1 = GPIO1 set as output                                        | gpio_00(1)     |
| 2     | 0/1          | 0 = GPIO2 set as input                                         | gpio_oe(2)     |
|       | 0/1          | 1 = GPIO2 set as output                                        | gpio_00(2)     |
| 3     | 0/1          | 0 = GPIO3 set as input                                         | gpio_oe(3)     |
| 5     | 0/1          | 1 = GPIO3 set as output                                        | gριο_σε(3)     |
| 4     | 0/1          | 0 = GPIO4 set as input                                         | gpio_oe(4)     |
| 4     | 0/1          | 1 = GPIO4 set as output                                        | gpio_0e(4)     |
| _     | 0/1          | 0 = GPIO5 set as input                                         | ania aa(F)     |
| 5     | 0/1          | 1 = GPIO5 set as output                                        | gpio_oe(5)     |
| )     | 0/4          | 0 = GPIO6 set as input                                         |                |
| 6     | 0/1          | 1 = GPIO6 set as output                                        | gpio_oe(6)     |
| 7     | 0/4          | 0 = GPIO7 set as input                                         |                |
| 7     | 0/1          | 1 = GPIO7 set as output                                        | gpio_oe(7)     |
|       | 8 0/1        | 0 = GPIO8 set as input                                         | . (0)          |
| 8     |              | 1 = GPIO8 set as output                                        | gpio_oe(8)     |
|       | 0/1          | 0 = GPIO9 set as input                                         | . (0)          |
| 9     |              | 1 = GPIO9 set as output                                        | gpio_oe(9)     |
| 4.0   | 0/1          | 0 = GPIO10 set as input                                        | . (10)         |
| 10    |              | 1 = GPIO10 set as output                                       | gpio_oe(10)    |
|       |              | 0 = GPIO11 set as input                                        |                |
| 11    | 0/1          | 1 = GPIO11 set as output                                       | gpio_oe(11)    |
|       | Address:     | 43                                                             |                |
|       | Description: | GPIO Configuration (continued)                                 |                |
| Bits  | Range        | Action                                                         | Parameter Name |
|       | 244          | Register write: drives value on GPIO0 pin if enabled as output |                |
| 0     | 0/1          | Register read: returns value on GPIO0 pin                      | gpio(0)        |
|       |              | Register write: drives value on GPIO1 pin if enabled as output |                |
| 1     | 0/1          | Register read: returns value on GPIO1 pin                      | gpio(1)        |
|       |              | Register write: drives value on GPIO2 pin if enabled as output |                |
| 2     | 0/1          | Register read: returns value on GPIO2 pin                      | gpio(2)        |
|       |              | Register write: drives value on GPIO3 pin if enabled as output |                |
| 3     | 0/1          | Register read: returns value on GPIO3 pin                      | gpio(3)        |
|       |              | Register write: drives value on GPIO4 pin if enabled as output |                |
| 4     | 0/1          | Register read: returns value on GPIO4 pin                      | gpio(4)        |
|       |              | Register write: drives value on GPIO5 pin if enabled as output |                |
| 5     | 0/1          | Register read: returns value on GPIO5 pin                      | gpio(5)        |
|       |              | Register write: drives value on GPIO6 pin if enabled as output |                |
| 6     | 0/1          | Register read: returns value on GPIO6 pin                      | gpio(6)        |
|       |              | Register write: drives value on GPIO7 pin if enabled as output |                |
| 7     | 0/1          | Register read: returns value on GPIO7 pin                      | gpio(7)        |
|       |              | Register write: drives value on GPIO8 pin if enabled as output |                |
| 8     | 0/1          | Register read: returns value on GPIO8 pin                      | gpio(8)        |
|       |              | negister reau. returns value un Grico pin                      |                |



# **Table 27. Control Registers (continued)**

|        |              | rable 27. Control Registers (Continued)                         |                    |  |  |  |  |  |
|--------|--------------|-----------------------------------------------------------------|--------------------|--|--|--|--|--|
| 9      | 0/1          | Register write: drives value on GPIO9 pin if enabled as output  | gpio(9)            |  |  |  |  |  |
|        | 5/1          | Register read: returns value on GPIO9 pin                       | 98.0(0)            |  |  |  |  |  |
| 10     | 0/1          | Register write: drives value on GPIO10 pin if enabled as output | gpio(10)           |  |  |  |  |  |
|        | <b>3</b> / 1 | Register read: returns value on GPIO10 pin                      | gpio(10)           |  |  |  |  |  |
| 11 0/1 |              | Register write: drives value on GPIO11 pin if enabled as output | gpio(11)           |  |  |  |  |  |
|        | 0/ 1         | Register read: returns value on GPIO11 pin                      | gp.5(11)           |  |  |  |  |  |
|        | Address:     | 44                                                              |                    |  |  |  |  |  |
| 1      | Description: | GPIO Configuration                                              |                    |  |  |  |  |  |
| Bits   | Range        | Action                                                          | Parameter Name     |  |  |  |  |  |
| 1:0    | 03           | GPIO0 debounce setting                                          | gpio_delay(1:0)    |  |  |  |  |  |
| 3:2    | 03           | GPIO1 debounce setting                                          | gpio_delay(3:2)    |  |  |  |  |  |
| 5:4    | 03           | GPIO2 debounce setting                                          | gpio_delay(5:4)    |  |  |  |  |  |
| 7:6    | 03           | GPIO3 debounce setting                                          | gpio_delay(7:6)    |  |  |  |  |  |
| 9:8    | 03           | GPIO4 debounce setting                                          | gpio_delay(9:8)    |  |  |  |  |  |
| 11:10  | 03           | GPIO5 debounce setting                                          | gpio_delay(11:10)  |  |  |  |  |  |
| 13:12  | 03           | GPIO6 debounce setting                                          | gpio_delay(13:12)  |  |  |  |  |  |
| 15:14  | 03           | GPIO7 debounce setting                                          | gpio_delay(15:14)  |  |  |  |  |  |
|        | Address:     | 45                                                              |                    |  |  |  |  |  |
|        | Description: | GPIO Configuration                                              |                    |  |  |  |  |  |
| Bits   | Range        | Action                                                          | Parameter Name     |  |  |  |  |  |
| 1:0    | 03           | GPIO8 debounce setting                                          | gpio_delay(17:16)  |  |  |  |  |  |
| 3:2    | 03           | GPIO9 debounce setting                                          | gpio_delay(19:18)  |  |  |  |  |  |
| 5:4    | 03           | GPIO10 debounce setting                                         | gpio_delay(21:20)  |  |  |  |  |  |
| 7:6    | 03           | GPIO11 debounce setting                                         | gpio_delay(23:22)  |  |  |  |  |  |
|        | Address:     | 46                                                              |                    |  |  |  |  |  |
| 1      | Description: | IF ADC Alarm                                                    |                    |  |  |  |  |  |
| Bits   | Range        | Action                                                          | Parameter Name     |  |  |  |  |  |
| 11:0   | 02047        | Alarm limit for IF_ADC0                                         | ifadc0_limit(11:0) |  |  |  |  |  |
|        | Address:     |                                                                 |                    |  |  |  |  |  |
|        | Description: | IF ADC Alarm                                                    |                    |  |  |  |  |  |
| Bits   | Range        | Action                                                          | Parameter Name     |  |  |  |  |  |
| 11:0   | 02047        | Alarm limit for IF_ADC1                                         | ifadc1_limit(11:0) |  |  |  |  |  |
|        | Address:     |                                                                 |                    |  |  |  |  |  |
|        | Description: | IRQ0 Configuration                                              |                    |  |  |  |  |  |
| Bits   | Range        | Action                                                          | Parameter Name     |  |  |  |  |  |
| 11:0   | 04095        | GPIO input edge select for IRQ0 irq0_gpio_edge(11:0)            |                    |  |  |  |  |  |
|        | Address:     |                                                                 |                    |  |  |  |  |  |
|        | Description: | IRQ0 Configuration                                              |                    |  |  |  |  |  |
| Bits   | Range        | Action                                                          | Parameter Name     |  |  |  |  |  |
| 11:0   | 04095        | IRQ0 GPIO enable                                                | irq0_gpio_en(11:0) |  |  |  |  |  |
|        | Address:     |                                                                 |                    |  |  |  |  |  |
|        | •            | IRQ0 Configuration                                              |                    |  |  |  |  |  |
| Bits   | Range        | Action                                                          | Parameter Name     |  |  |  |  |  |
| 15:0   | 065535       | IRQ0 enable                                                     | irq0_en(15:0)      |  |  |  |  |  |

Submit Documentation Feedback



www.ti.com SBAS434-DECEMBER 2008

|              |                       | Table 21: Some of Registers (continued               | · ·                                     |  |  |  |  |
|--------------|-----------------------|------------------------------------------------------|-----------------------------------------|--|--|--|--|
|              | Address:              |                                                      |                                         |  |  |  |  |
| Dita         | Description:          |                                                      | Doromotov Nov                           |  |  |  |  |
| Bits         | Range                 | Action                                               | Parameter Name                          |  |  |  |  |
| 15:0 065535  |                       | Register read: returns IRQ0 status                   | irq0_status(15:0)                       |  |  |  |  |
|              | A 4 4 4 4 4 5 5 5 5 5 | Register write: clears interrupt bit if 1 is written |                                         |  |  |  |  |
|              | Address:              |                                                      |                                         |  |  |  |  |
| <b>5</b> 14  | •                     | IRQ0 GPIO Status                                     |                                         |  |  |  |  |
| Bits         | Range                 | Action                                               | Parameter Name                          |  |  |  |  |
| 11:0 04095   |                       | Register read: returns IRQ0 status                   | irq0_gpio_status(11:0)                  |  |  |  |  |
| Address:     |                       | Register write: clears interrupt bit if 1 is written |                                         |  |  |  |  |
|              |                       |                                                      |                                         |  |  |  |  |
| <b>5</b>     |                       | IRQ1 Configuration                                   |                                         |  |  |  |  |
| Bits         | Range                 | Action                                               | Parameter Name                          |  |  |  |  |
| 11:0         | 04095                 | GPIO input edge select for IRQ1                      | irq1_gpio_edge(11:0)                    |  |  |  |  |
|              | Address:              |                                                      |                                         |  |  |  |  |
|              |                       | IRQ1 Configuration                                   |                                         |  |  |  |  |
| Bits         | Range                 | Action                                               | Parameter Name                          |  |  |  |  |
| 11:0         | 04095                 | IRQ1 GPIO enable                                     | irq1_gpio_en(11:0)                      |  |  |  |  |
| Address:     |                       |                                                      |                                         |  |  |  |  |
|              | -                     | IRQ1 Configuration                                   | 12                                      |  |  |  |  |
| Bits Range   |                       | Action                                               | Parameter Name                          |  |  |  |  |
| 15:0         | 065535                | IRQ1 enable                                          | irq1_en(15:0)                           |  |  |  |  |
|              | Address:              |                                                      |                                         |  |  |  |  |
| Description: |                       |                                                      |                                         |  |  |  |  |
| Bits         | Range                 | Action                                               | Parameter Name                          |  |  |  |  |
| 15:0         | 065535                | Register read: returns IRQ1 status                   | irq1_status(15:0)                       |  |  |  |  |
|              |                       | Register write: clears interrupt bit if 1 is written |                                         |  |  |  |  |
|              | Address:              |                                                      |                                         |  |  |  |  |
|              | -                     | IRQ1 GPIO Status (continued)                         |                                         |  |  |  |  |
| Bits         | Range                 | Action                                               | Parameter Name                          |  |  |  |  |
| 11:0         | 04095                 | Register read: returns IRQ1 status                   | irq1_gpio_status(11:0)                  |  |  |  |  |
|              |                       | Register write: clears interrupt bit if 1 is written | 1 –31 – – – – – – – – – – – – – – – – – |  |  |  |  |
|              | Address:              |                                                      |                                         |  |  |  |  |
| ı            |                       | IRQ2 Configuration                                   |                                         |  |  |  |  |
| Bits         | Range                 | Action                                               | Parameter Name                          |  |  |  |  |
| 11:0         | 04095                 | GPIO input edge select for IRQ2                      | irq2_gpio_edge(11:0)                    |  |  |  |  |
|              | Address:              |                                                      |                                         |  |  |  |  |
|              | -                     | IRQ2 Configuration                                   |                                         |  |  |  |  |
| Bits         | Range                 | Action                                               | Parameter Name                          |  |  |  |  |
| 11:0         | 04095                 | IRQ2 GPIO enable                                     | irq2_gpio_en(11:0)                      |  |  |  |  |
|              | Address:              | 60                                                   |                                         |  |  |  |  |
|              | Description:          | IRQ2 Configuration                                   |                                         |  |  |  |  |
| Bits         | Range                 | Action                                               | Parameter Name                          |  |  |  |  |
| 15:0         | 065535                | IRQ2 enable                                          | irq2_en(15:0)                           |  |  |  |  |



|          |              | Table 27. Control Registers (continued)                                       |                                              |  |  |  |  |  |
|----------|--------------|-------------------------------------------------------------------------------|----------------------------------------------|--|--|--|--|--|
|          | Address:     |                                                                               |                                              |  |  |  |  |  |
|          | Description: |                                                                               |                                              |  |  |  |  |  |
| Bits     | Range        | Action                                                                        | Parameter Name                               |  |  |  |  |  |
| 15:0     |              | Register read: returns IRQ2 status                                            | irq2_status(15:0)                            |  |  |  |  |  |
|          |              | Register write: clears interrupt bit if 1 is written                          | 1 =====                                      |  |  |  |  |  |
|          | Address:     |                                                                               |                                              |  |  |  |  |  |
|          |              | IRQ2 GPIO Status                                                              |                                              |  |  |  |  |  |
| Bits     | Range        | Action                                                                        | Parameter Name                               |  |  |  |  |  |
| 11:0     | 04095        | Register read: returns IRQ2 status irq2_gpio_status(11:0                      |                                              |  |  |  |  |  |
|          |              | Register write: clears interrupt bit if 1 is written                          | 1 = 31 = \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ |  |  |  |  |  |
|          | Address:     |                                                                               |                                              |  |  |  |  |  |
|          | Description: | Not Used                                                                      |                                              |  |  |  |  |  |
| Bits     | Range        | Action                                                                        | Parameter Name                               |  |  |  |  |  |
| _        |              | _                                                                             | _                                            |  |  |  |  |  |
|          | Address:     |                                                                               |                                              |  |  |  |  |  |
|          | Description: | Real-Time Clock Configuration                                                 | 1                                            |  |  |  |  |  |
| Bits     | Range        | Action                                                                        | Parameter Name                               |  |  |  |  |  |
| 0        | 0/1          | 0 = Freeze real-time clock                                                    | rtc_en                                       |  |  |  |  |  |
| ŭ        |              | 1 = Enable real-time clock operation                                          | 110_0.1                                      |  |  |  |  |  |
| 1 0/1    |              | 0:12 hour mode                                                                | rtc_mode                                     |  |  |  |  |  |
| •        | 0/1          | 1:24 hour mode                                                                | no_mode                                      |  |  |  |  |  |
| 2        | 0/1          | Enable clock compensation                                                     | rtc_comp_en                                  |  |  |  |  |  |
| 3        | 0/1          | Enable clock test mode                                                        | rtc_test_en                                  |  |  |  |  |  |
| 6:4      | 04           | Clock test mode selection                                                     | rtc_test_mode(2:0)                           |  |  |  |  |  |
| 12:7     | 031          | Compensation count                                                            | rtc_comp_cnt(5:0)                            |  |  |  |  |  |
| 15:13    | 07           | Frequency select for GPIO debounce                                            | gpio_debounce_freq(2:0)                      |  |  |  |  |  |
|          | Address:     | 65                                                                            |                                              |  |  |  |  |  |
|          | Description: | Real-Time Clock Configuration                                                 |                                              |  |  |  |  |  |
| Bits     | Range        | Action                                                                        | Parameter Name                               |  |  |  |  |  |
| 15:0     | 032767       | Real-time one second terminal count. Default = 16384 (for 32.768-kHz crystal) | rtc_max_count(15:0)                          |  |  |  |  |  |
|          | Address:     | 66                                                                            |                                              |  |  |  |  |  |
|          | Description: | Real-Time Clock Configuration (continued)                                     |                                              |  |  |  |  |  |
| Bits     | Range        | Action                                                                        | Parameter Name                               |  |  |  |  |  |
| 15:0     | -3276832767  | Real-time clock compensation value. Default = 16384                           | rtc_comp_val(15:0)                           |  |  |  |  |  |
| Address: |              | 67                                                                            |                                              |  |  |  |  |  |
|          | Description: | Real-Time Clock Alarm                                                         |                                              |  |  |  |  |  |
| Bits     | Range        | Action                                                                        | Parameter Name                               |  |  |  |  |  |
| 6:0      | 059          | Seconds alarm setting                                                         | rtc_seconds_alarm(6:0)                       |  |  |  |  |  |
| <u> </u> | Address:     | 68                                                                            |                                              |  |  |  |  |  |
|          | Description: | Real-Time Clock Alarm                                                         |                                              |  |  |  |  |  |
| Bits     | Range        | Action                                                                        | Parameter Name                               |  |  |  |  |  |
| 6:0      | 059          | Minutes alarm setting                                                         | rtc_minutes_alarm(6:0)                       |  |  |  |  |  |



|                                              | A d d = 0.0. | 60                                       |                       |
|----------------------------------------------|--------------|------------------------------------------|-----------------------|
|                                              | Address:     |                                          |                       |
| <b>5</b> ''                                  | -            | Realtime Clock Alarm                     |                       |
| Bits                                         | Range        | Action                                   | Parameter Name        |
| 5:0                                          | 112          | Hour alarm setting, 12-hour mode         | rtc_hours_alarm(5:0)  |
| -                                            | 023          | Hour alarm setting, 24-hour mode         |                       |
| 6                                            | _            | Not used                                 | _                     |
| 7                                            | 0/1          | 12-hour mode: 0 = AM, 1 = PM             | rtc_ampm_alarm        |
|                                              |              | 24-hour mode: not used                   |                       |
|                                              | Address:     |                                          |                       |
| D'II-                                        | •            | Real-Time Clock Alarm                    | D                     |
| Bits         Range           5:0         131 |              | Action                                   | Parameter Name        |
| 5:0                                          | _            | Day of the month alarm setting           | rtc_day_alarm(5:0)    |
|                                              | Address:     |                                          |                       |
| Dito                                         | •            | Real-Time Clock Alarm Action             | Parameter Name        |
| Bits         Range           4:0         112 |              | Month alarm setting                      | rtc_months_alarm(4:0) |
| 4.0                                          | Address:     |                                          | rtc_months_alam(4.0)  |
|                                              |              | Real-Time Clock Alarm                    |                       |
| Bits                                         |              | Action                                   | Parameter Name        |
| Bits         Range           7:0         099 |              | Year alarm setting                       | rtc_year_alarm(7:0)   |
| 7.0                                          | Address:     |                                          | no_year_alam(7.0)     |
|                                              |              | Real-Time Clock Current Time             |                       |
| Bits Range                                   |              | Action                                   | Parameter Name        |
| 6:0                                          | 059          | Seconds register                         | rtc_seconds(6:0)      |
| 14:7                                         | _            | Not used                                 | —                     |
| 15 0/1                                       |              | Real-time clock busy (read only)         | rtc_busy              |
|                                              | Address:     |                                          | ·,                    |
|                                              | Description: | Real-Time Clock Current Time             |                       |
| Bits                                         | Range        | Action                                   | Parameter Name        |
| 6:0                                          | 059          | Minutes register                         | rtc_minutes(6:0)      |
| 14:7                                         | _            | Not used                                 | _                     |
| 15                                           | 0/1          | Real-time clock busy (read only)         | rtc_busy              |
|                                              | Address:     | 75                                       | ,                     |
|                                              | Description: | Real-Time Clock Current Time (continued) |                       |
| Bits                                         | Range        | Action                                   | Parameter Name        |
| F:0                                          | 112          | Hour register, 12-hour mode              | rto hours/FrO)        |
| 5:0                                          | 023          | Hour register, 24-hour mode              | rtc_hours(5:0)        |
| 6                                            |              | Not used                                 | _                     |
| 7                                            | 0/1          | 12-hour mode: 0 = AM, 1 = PM             | rtc. ampm             |
| 7                                            | 0/1          | 24-hour mode: not used                   | rtc_ampm              |
| 14:8                                         |              | Not used                                 | _                     |
| 15                                           | 0/1          | Real-time clock busy (read only)         | rtc_busy              |
|                                              | Address:     | 76                                       |                       |
|                                              | Description: | Real-Time Clock Current Time             |                       |
| Bits                                         | Range        | Action                                   | Parameter Name        |
| 5:0                                          | 131          | Day of month register                    | rtc_day(5:0)          |
| 14:6                                         | _            | Not used                                 | _                     |
| 15                                           | 0/1          | Real-time clock busy (read only)         | rtc_busy              |



|          | A .1.1       | Table 27. Control Registers (Continue                | ~,                       |
|----------|--------------|------------------------------------------------------|--------------------------|
|          | Address:     |                                                      |                          |
|          | •            | Real-Time Clock Current Time                         |                          |
| Bits     | Range        | Action                                               | Parameter Name           |
| 4:0      | 112          | Month register                                       | rtc_month(4:0)           |
| 14:5     | <del>-</del> | Not used                                             | _                        |
| 15       | 0/1          | Real-time clock busy (read only)                     | rtc_busy                 |
|          | Address:     |                                                      |                          |
|          | •            | Real-Time Clock Current Time                         |                          |
| Bits     | Range        | Action                                               | Parameter Name           |
| 7:0      | 099          | Year register                                        | rtc_year(7:0)            |
| 14:8     |              | Not used                                             | _                        |
| 15       | 0/1          | Real-time clock busy (read only)                     | rtc_busy                 |
|          | Address:     | 79                                                   |                          |
|          | Description: | Real-Time Clock Current Time                         |                          |
| Bits     | Range        | Action                                               | Parameter Name           |
| 2:0      | 06           | Day of week                                          | rtc_day_of_week(2:0)     |
| 14:3     | _            | Not used                                             | _                        |
| 15       | 0/1          | Real-time clock busy (read only)                     | rtc_busy                 |
|          | Address:     | 80                                                   |                          |
|          | Description: | WAKEUP Configuration                                 |                          |
| Bits     | Range        | Action                                               | Parameter Name           |
| 11:0     | 04095        | GPIO input edge select for WAKEUP                    | wakeup_gpio_edge(11:0)   |
|          | Address:     | 81                                                   |                          |
|          | Description: | WAKEUP Configuration                                 |                          |
| Bits     | Range        | Action                                               | Parameter Name           |
| 11:0     | 04095        | WAKEUP GPIO enable                                   | wakeup_gpio_en(11:0)     |
|          | Address:     | 82                                                   |                          |
|          | Description: | WAKEUP Configuration                                 |                          |
| Bits     | Range        | Action                                               | Parameter Name           |
| 15:0     | 065535       | WAKEUP enable                                        | wakeup_en(15:0)          |
|          | Address:     | 83                                                   |                          |
|          | Description: | WAKEUP Status                                        |                          |
| Bits     | Range        | Action                                               | Parameter Name           |
|          |              | Register read: returns WAKEUP status                 |                          |
| 15:0     | 065535       | Register write: clears interrupt bit if 1 is written | wakeup_status(15:0)      |
|          | Address:     | 84                                                   |                          |
|          | Description: | WAKEUP GPIO Status                                   |                          |
| Bits     | Range        | Action                                               | Parameter Name           |
|          | <u> </u>     | Register read: returns WAKEUP status                 |                          |
| 11:0     | 04095        | Register write: clears interrupt bit if 1 is written | wakeup_gpio_status(11:0) |
| <u> </u> | Address:     |                                                      |                          |
|          | Description: |                                                      |                          |
|          | <b></b>      |                                                      |                          |
| Bits     | Range        | Action                                               | Parameter Name           |



|             | Address:     | 120                                                                                                                                  |                               |  |  |
|-------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|--|--|
|             |              | I <sup>2</sup> C Master—Slave Address                                                                                                |                               |  |  |
| Bits        | Range        | Action                                                                                                                               | Parameter Name                |  |  |
|             |              | Slave address used for master transactions. Also starts transaction.                                                                 |                               |  |  |
| 14.0 032767 |              | 7-bit addressing: bits 6:0 are the slave address. Bits 14:7 are ignored.                                                             | 10 11 (44.0)                  |  |  |
|             |              | 10-bit addressing: bits 9:0 are the slave address. Bits 14:10 are the upper five bits for the slave address first byte               | i2cm_slave_addr(14:0)         |  |  |
| 15          | _            | Not used                                                                                                                             | _                             |  |  |
| 1           | Address:     | 121                                                                                                                                  | 1                             |  |  |
|             | Description: | I <sup>2</sup> C Master—Slave Burst length                                                                                           |                               |  |  |
| Bits        | Range        | Action                                                                                                                               | Parameter Name                |  |  |
| 4:0         | 116          | Number of bytes to transfer for the first data burst                                                                                 | i2cm_start_data_length(4:0)   |  |  |
| 5           | 0/1          | Selects the Read/Write bit value used with the slave address following START.                                                        | i2cm_start_rw                 |  |  |
| 5 0/1       |              | 0 selects Write                                                                                                                      | izem_start_rw                 |  |  |
|             |              | 1 selects Read                                                                                                                       |                               |  |  |
| 7:6         | _            | Not used                                                                                                                             | _                             |  |  |
| 12:8        | 116          | Number of bytes to transfer for the second data burst in a combined format transfer. This parameter is used only if i2cm_use_sr = 1. | i2cm_restart_data_length(4:0) |  |  |
| 13          | 0/1          | Selects the Read/Write bit value used with the slave address following RESTART.                                                      | i2cm restart rw               |  |  |
| 13          |              | 0 selects Write                                                                                                                      | IZCIII_Testatt_TW             |  |  |
|             |              | 1 selects Read                                                                                                                       |                               |  |  |
| 14          | 0/1          | 0 = SDA0/SCL0 interface                                                                                                              | i2xm_if_sel                   |  |  |
|             |              | 1 = SDA1/SCL1 interface                                                                                                              | 12/11_11_001                  |  |  |
| 15          | 0/1          | 0 selects I <sup>2</sup> C transactions without a repeated start.                                                                    | i2cm_use_sr                   |  |  |
|             |              | 1 selects combined transactions with a repeated start.                                                                               |                               |  |  |
|             | Address:     |                                                                                                                                      |                               |  |  |
|             | •            | I <sup>2</sup> C Master—Write Buffer Control                                                                                         | T                             |  |  |
| Bits        | Range        | Action                                                                                                                               | Parameter Name                |  |  |
| 7:0         | 0255         | Stores data in the write buffer at the location specified by i2cm_write_byte_ptr(3:0)                                                | i2cm_write_byte(7:0)          |  |  |
| 11:8        | 015          | Buffer location where the i2cm_write_byte should be placed                                                                           | i2cm_write_byte_ptr(3:0)      |  |  |
| 14:12       | <del>-</del> | Not used                                                                                                                             | _                             |  |  |
|             |              | Auto increment                                                                                                                       |                               |  |  |
| 15          | 0/1          | 0 = i2cm_write_byte_ptr is used for storing the i2cm_write_byte value in the write buffer memory                                     | i2cm_write_auto_inc           |  |  |
|             |              | 1 = i2cm_write_byte_ptr is ignored from the host and it is auto-incremented for writing the i2cm_write_byte to the buffer            |                               |  |  |
|             | Address:     |                                                                                                                                      |                               |  |  |
|             | Description: |                                                                                                                                      | 12                            |  |  |
| Bits        | Range        | Action                                                                                                                               | Parameter Name                |  |  |
| 7:0         | 0255         | Read only - retrieves data read by the I <sup>2</sup> C master from the read buffer                                                  | i2cm_read_byte(7:0)           |  |  |
| 11:8        | 015          | Buffer location where the i2cm_read_byte should be retrieved                                                                         | i2cm_read_byte_ptr(3:0)       |  |  |
| 14:12       | _            | Not used                                                                                                                             | _                             |  |  |
|             |              | Auto increment                                                                                                                       |                               |  |  |
| 15          | 0/1          | 0 = i2cm_read_byte_ptr is used for retrieving the i2cm_write_byte value in the read buffer memory                                    | i2cm_read_auto_inc            |  |  |
|             |              | 1 = i2cm_read_byte_ptr is ignored from the host and it is auto-incremented for retrieving the i2cm_read_byte from the buffer         |                               |  |  |



|      | Address:     | 124                                                                                                                                                                                                                                             |                       |  |
|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--|
|      | Description: | I <sup>2</sup> C Master—Read Buffer Control                                                                                                                                                                                                     |                       |  |
| Bits | Range        | Action                                                                                                                                                                                                                                          | Parameter Name        |  |
| 7:0  | 5 to 200     | Controls the I <sup>2</sup> C SCL clock rate                                                                                                                                                                                                    | i2cm_clk_cycles(7:0)  |  |
|      |              | Multi-master                                                                                                                                                                                                                                    |                       |  |
| 8    | 0/1          | 0 = single I <sup>2</sup> C master on SDA and SCL signals                                                                                                                                                                                       | i2cm_multimaster      |  |
|      |              | 1 = multiple I <sup>2</sup> C masters present on SDA and SCL signals                                                                                                                                                                            |                       |  |
|      |              | SCL sync enable                                                                                                                                                                                                                                 |                       |  |
| 9    | 0/1          | 0 = prohibit SCL stretching by slave                                                                                                                                                                                                            | i2cm_scl_sync_en      |  |
|      |              | 1 = permit SCL stretching by slave                                                                                                                                                                                                              |                       |  |
|      | 0/1          | Allow slave NACK                                                                                                                                                                                                                                |                       |  |
| 10   |              | 0 = require slave to ACK transfers                                                                                                                                                                                                              | i2cm_allow_slave_nack |  |
|      |              | 1 = permit slave to not-acknowledge (NACK)                                                                                                                                                                                                      |                       |  |
| 11   | 0/1          | Clear slave NACK. if i2cm_allow_slave_nack is zero and the slave fails to acknowledge, this bit when read will be set. No further I <sup>2</sup> C transactions are allowed until this bit is written as a 1 to clear the slave NACK condition. | i2cm_clear_slave_nack |  |
| 40   | 0.14         | 0 = Use 7 bit addressing                                                                                                                                                                                                                        |                       |  |
| 12   | 0/1          | 1 = Use 10 bit addressing                                                                                                                                                                                                                       | i2cm_10b_addressing   |  |
|      |              | End transfer with stop                                                                                                                                                                                                                          |                       |  |
| 13   | 0/1          | 0 = do not issue a stop after last byte transferred and pause transaction                                                                                                                                                                       | i2cm_use_stop         |  |
|      |              | 1 = issue a stop after the last byte transferred                                                                                                                                                                                                |                       |  |
| 14   | 0/1          | Holding. Read-only. Used when i2cm_use_stop is set to zero.                                                                                                                                                                                     | i2cm_holding          |  |
| 15   | 0/1          | Done. Read-only. When set, the I <sup>2</sup> C master has completed any pending transactions.                                                                                                                                                  | i2cm_done             |  |

www.ti.com SBAS434-DECEMBER 2008

#### **MECHANICAL DATA**

# RFP (S-PQFP-G144)

### PowerPAD™ PLASTIC QUAD FLATPACK



NOTES:

- A. All linear dimensions are in millimeters.
- B. This drawing is subject to change without notice.
- C. Body dimensions do not include mold flash or protrusion
- This package is designed to be soldered to a thermal pad on the board. Refer to Technical Brief, PowerPad Thermally Enhanced Package, Texas Instruments Literature No. SLMA002 for information regarding recommended board layout. This document is available at www.ti.com <a href="https://www.ti.com">http://www.ti.com</a>.
- E. Falls within JEDEC MS-026



#### **MECHANICAL DATA**

#### THERMAL INFORMATION

This PowerPAD  $^{\text{TM}}$  package incorporates an exposed thermal pad that is designed to be attached directly to an external heatsink. The thermal pad must be soldered directly to the printed circuit board (PCB). After soldering, the PCB can be used as a heatsink. In addition, through the use of thermal vias, the thermal pad can be attached directly to the appropriate copper plane shown in the electrical schematic for the device, or alternatively, can be attached to a special heatsink structure designed into the PCB. This design optimizes the heat transfer from the integrated circuit (IC).

For additional information on the PowerPAD package and how to take advantage of its heat dissipating abilities, refer to Technical Brief, PowerPAD Thermally Enhanced Package, Texas Instruments Literature No. SLMA002 and Application Brief, PowerPAD Made Easy, Texas Instruments Literature No. SLMA004. Both documents are available at www.ti.com.

The exposed thermal pad dimensions for this package are shown in the following illustration.



Top View

NOTE: All linear dimensions are in millimeters

Exposed Thermal Pad Dimensions

4206900/B 10/07

www.ti.com 11-Nov-2025

#### PACKAGING INFORMATION

| Orderable part number | Status | Material type | Package   Pins    | Package qty   Carrier     | RoHS | Lead finish/<br>Ball material | MSL rating/<br>Peak reflow | Op temp (°C) | Part marking (6) |
|-----------------------|--------|---------------|-------------------|---------------------------|------|-------------------------------|----------------------------|--------------|------------------|
|                       |        |               |                   |                           |      | (4)                           | (5)                        |              |                  |
| AFE8221IRFPQ1         | Active | Production    | HTQFP (RFP)   144 | 60   JEDEC<br>TRAY (10+1) | Yes  | NIPDAU                        | Level-3-260C-168 HR        | -40 to 85    | AFE8221Q         |
| AFE8221IRFPQ1.A       | Active | Production    | HTQFP (RFP)   144 | 60   JEDEC<br>TRAY (10+1) | Yes  | NIPDAU                        | Level-3-260C-168 HR        | -40 to 85    | AFE8221Q         |

<sup>(1)</sup> Status: For more details on status, see our product life cycle.

Multiple part markings will be inside parentheses. Only one part marking contained in parentheses and separated by a "~" will appear on a part. If a line is indented then it is a continuation of the previous line and the two combined represent the entire part marking for that device.

Important Information and Disclaimer: The information provided on this page represents TI's knowledge and belief as of the date that it is provided. TI bases its knowledge and belief on information provided by third parties, and makes no representation or warranty as to the accuracy of such information. Efforts are underway to better integrate information from third parties. TI has taken and continues to take reasonable steps to provide representative and accurate information but may not have conducted destructive testing or chemical analysis on incoming materials and chemicals. TI and TI suppliers consider certain information to be proprietary, and thus CAS numbers and other limited information may not be available for release.

In no event shall TI's liability arising out of such information exceed the total purchase price of the TI part(s) at issue in this document sold by TI to Customer on an annual basis.

<sup>(2)</sup> Material type: When designated, preproduction parts are prototypes/experimental devices, and are not yet approved or released for full production. Testing and final process, including without limitation quality assurance, reliability performance testing, and/or process qualification, may not yet be complete, and this item is subject to further changes or possible discontinuation. If available for ordering, purchases will be subject to an additional waiver at checkout, and are intended for early internal evaluation purposes only. These items are sold without warranties of any kind.

<sup>(3)</sup> RoHS values: Yes, No, RoHS Exempt. See the TI RoHS Statement for additional information and value definition.

<sup>(4)</sup> Lead finish/Ball material: Parts may have multiple material finish options. Finish options are separated by a vertical ruled line. Lead finish/Ball material values may wrap to two lines if the finish value exceeds the maximum column width.

<sup>(5)</sup> MSL rating/Peak reflow: The moisture sensitivity level ratings and peak solder (reflow) temperatures. In the event that a part has multiple moisture sensitivity ratings, only the lowest level per JEDEC standards is shown. Refer to the shipping label for the actual reflow temperature that will be used to mount the part to the printed circuit board.

<sup>(6)</sup> Part marking: There may be an additional marking, which relates to the logo, the lot trace code information, or the environmental category of the part.



www.ti.com 23-May-2025

#### **TRAY**



Chamfer on Tray corner indicates Pin 1 orientation of packed units.

#### \*All dimensions are nominal

| Device          | Package<br>Name | Package<br>Type | Pins | SPQ | Unit array<br>matrix | Max<br>temperature<br>(°C) | L (mm) | W<br>(mm) | Κ0<br>(μm) | P1<br>(mm) | CL<br>(mm) | CW<br>(mm) |
|-----------------|-----------------|-----------------|------|-----|----------------------|----------------------------|--------|-----------|------------|------------|------------|------------|
| AFE8221IRFPQ1   | RFP             | HTQFP           | 144  | 60  | 5 x 12               | 150                        | 315    | 135.9     | 7620       | 25.4       | 17.8       | 17.55      |
| AFE8221IRFPQ1.A | RFP             | HTQFP           | 144  | 60  | 5 x 12               | 150                        | 315    | 135.9     | 7620       | 25.4       | 17.8       | 17.55      |

RFP (S-PQFP-G144)

PowerPAD™ PLASTIC QUAD FLATPACK



NOTES:

- A. All linear dimensions are in millimeters.
- B. This drawing is subject to change without notice.
- C. Body dimensions do not include mold flash or protrusion
- D. This package is designed to be soldered to a thermal pad on the board. Refer to Technical Brief, PowerPad Thermally Enhanced Package, Texas Instruments Literature No. SLMA002 for information regarding recommended board layout. This document is available at www.ti.com <a href="https://www.ti.com">www.ti.com</a>.
- E. See the additional figure in the Product Data Sheet for details regarding the exposed thermal pad features and dimensions.
- F. Falls within JEDEC MS-026



# RFP (S-PQFP-G144)

# PowerPAD™ PLASTIC QUAD FLATPACK

#### THERMAL INFORMATION

This PowerPAD  $^{\text{M}}$  package incorporates an exposed thermal pad that is designed to be attached to a printed circuit board (PCB). The thermal pad must be soldered directly to the PCB. After soldering, the PCB can be used as a heatsink. In addition, through the use of thermal vias, the thermal pad can be attached directly to the appropriate copper plane shown in the electrical schematic for the device, or alternatively, can be attached to a special heatsink structure designed into the PCB. This design optimizes the heat transfer from the integrated circuit (IC).

For additional information on the PowerPAD package and how to take advantage of its heat dissipating abilities, refer to Technical Brief, PowerPAD Thermally Enhanced Package, Texas Instruments Literature No. SLMA002 and Application Brief, PowerPAD Made Easy, Texas Instruments Literature No. SLMA004. Both documents are available at www.ti.com.

The exposed thermal pad dimensions for this package are shown in the following illustration.



Top View

Exposed Thermal Pad Dimensions

4206900-2/E 01/12

NOTES: A. All linear dimensions are in millimeters

A Tie strap features may not be present



# RFP (S-PQFP-G144)

### PowerPAD™ PLASTIC QUAD FLATPACK



NOTES:

- A. All linear dimensions are in millimeters.
- B. This drawing is subject to change without notice.
- C. Customers should place a note on the circuit board fabrication drawing not to alter the center solder mask defined pad.
- D. This package is designed to be soldered to a thermal pad on the board. Refer to Technical Brief, PowerPad Thermally Enhanced Package, Texas Instruments Literature No. SLMA002, SLMA004, and also the Product Data Sheets for specific thermal information, via requirements, and recommended board layout. These documents are available at www.ti.com <a href="https://www.ti.com">https://www.ti.com</a>. Publication IPC-7351 is recommended for alternate designs.
- E. Laser cutting apertures with trapezoidal walls and also rounding corners will offer better paste release. Customers should contact their board assembly site for stencil design recommendations. Example stencil design based on a 50% volumetric metal load solder paste. Refer to IPC-7525 for other stencil recommendations.
- F. Customers should contact their board fabrication site for solder mask tolerances between and around signal pads.



#### IMPORTANT NOTICE AND DISCLAIMER

TI PROVIDES TECHNICAL AND RELIABILITY DATA (INCLUDING DATASHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS AND IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT OF THIRD PARTY INTELLECTUAL PROPERTY RIGHTS.

These resources are intended for skilled developers designing with TI products. You are solely responsible for (1) selecting the appropriate TI products for your application, (2) designing, validating and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, regulatory or other requirements.

These resources are subject to change without notice. TI grants you permission to use these resources only for development of an application that uses the TI products described in the resource. Other reproduction and display of these resources is prohibited. No license is granted to any other TI intellectual property right or to any third party intellectual property right. TI disclaims responsibility for, and you fully indemnify TI and its representatives against any claims, damages, costs, losses, and liabilities arising out of your use of these resources.

TI's products are provided subject to TI's Terms of Sale, TI's General Quality Guidelines, or other applicable terms available either on ti.com or provided in conjunction with such TI products. TI's provision of these resources does not expand or otherwise alter TI's applicable warranties or warranty disclaimers for TI products. Unless TI explicitly designates a product as custom or customer-specified, TI products are standard, catalog, general purpose devices.

TI objects to and rejects any additional or different terms you may propose.

Copyright © 2025, Texas Instruments Incorporated

Last updated 10/2025