# **Dual, 16-Bit, 12.6 GSPS RF DAC with Channelizers** AD9172 **Data Sheet** #### **FEATURES** **Supports multiband wireless applications** 3 bypassable, complex data input channels per RF DAC 1.54 GSPS maximum complex input data rate per input 1 independent NCO per input channel Proprietary, low spurious and distortion design 2-tone intermodulation distortion (IMD) = -83 dBc at 1.8 GHz, -7 dBFS/tone RF output Spurious free dynamic range (SFDR) <-80 dBc at 1.8 GHz, -7 dBFS RF output Flexible 8-lane, 15.4 Gbps JESD204B interface Supports single-band and multiband use cases Supports 12-bit high density mode for increased data throughput Multiple chip synchronization **Supports JESD204B Subclass 1** Selectable interpolation filter for a complete set of input data rates 1x, 2x, 3x, 4x, 6x, and 8x configurable data channel interpolation $1\times$ , $2\times$ , $4\times$ , $6\times$ , $8\times$ , and $12\times$ configurable final interpolation Final 48-bit NCO that operates at the DAC rate to support frequency synthesis up to 6 GHz Transmit enable function allows extra power saving and downstream circuitry protection High performance, low noise PLL clock multiplier Supports 12.6 GSPS DAC update rate Observation ADC clock driver with selectable divide ratios Low power 2.55 W at 12 GSPS, dual channel mode 10 mm × 10 mm, 144-ball BGA\_ED with metal enhanced thermal lid, 0.80 mm pitch #### **APPLICATIONS** Wireless communications infrastructure **Multiband base station radios** Microwave/E-band backhaul systems Instrumentation, automatic test equipment (ATE) Radars and jammers #### **GENERAL DESCRIPTION** The AD9172 is a high performance, dual, 16-bit digital-to-analog converter (DAC) that supports DAC sample rates to 12.6 GSPS. The device features an 8-lane, 15 Gbps JESD204B data input port, a high performance, on-chip DAC clock multiplier, and digital signal processing capabilities targeted at single-band and multiband direct to radio frequency (RF) wireless applications. The AD9172 features three complex data input channels per RF DAC that are bypassable. Each data input channel includes a configurable gain stage, an interpolation filter, and a channel numerically controlled oscillator (NCO) for flexible, multiband frequency planning. The device supports up to a 1.5 GSPS complex data rate per input channel and is capable of aggregating multiple complex input data streams up to a maximum complex data rate of 1.5 GSPS. Additionally, the AD9172 supports ultrawide bandwidth modes bypassing the channelizers to provide maximum data rates of up to 3.08 GSPS (with 16-bit resolution) and 4.1 GSPS (with 12-bit resolution). The AD9172 is available in a 144-ball BGA\_ED package. #### PRODUCT HIGHLIGHTS - Supports single-band and multiband wireless applications with three bypassable complex data input channels per RF DAC at a maximum complex input data rate of 1.5 GSPS. One independent NCO per input channel. - Ultrawide bandwidth channel bypass modes supporting up to 3 GSPS data rates with 16-bit resolution and 4 GSPS with 12-bit resolution. - 3. Low power dual converter decreases the amount of power consumption needed in high bandwidth and multichannel applications. Trade marks and registered trade marks are the property of their respective owners. **Data Sheet** ## **AD9172** # **TABLE OF CONTENTS** | Features | |-----------------------------------------------------------| | Applications | | General Description | | Product Highlights | | Revision History | | Functional Block Diagram 4 | | Specifications | | DC Specifications5 | | Digital Specifications6 | | Maximum DAC Sampling Rate Specifications6 | | Power Supply DC Specifications | | Serial Port and CMOS Pin Specifications10 | | Digital Input Data Timing Specifications11 | | JESD204B Interface Electrical and Speed Specifications 12 | | Input Data Rates and Signal Bandwidth Specifications 13 | | AC Specifications14 | | Absolute Maximum Ratings | | Reflow Profile16 | | Thermal Characteristics | | ESD Caution | | Pin Configuration and Function Descriptions17 | | Typical Performance Characteristics | | Terminology | | Theory of Operation | | Serial Port Operation | | Data Format | | Serial Port Pin Descriptions30 | | JESD204B Serial Data Interface | |---------------------------------| | JESD204B Overview | | Physical Layer33 | | Data Link Layer38 | | Syncing LMFC Signals40 | | Transport Layer | | JESD204B Test Modes42 | | JESD204B Error Monitoring48 | | Digital Datapath5 | | Total Datapath Interpolation | | Channel Digital Datapath53 | | Main Digital Datapath56 | | Interrupt Request Operation | | Interrupt Service Routine | | Applications Information | | Hardware Considerations | | Analog Interface Considerations | | DAC Input Clock Configurations | | Clock Output Driver | | Analog Outputs68 | | Start-Up Sequence | | Register Summary | | Register Details | | Outline Dimensions | | Ordering Guide145 | #### **REVISION HISTORY** # 5/2019—Rev. 0 to Rev. A | Changes to Noise Spectral Density Parameters, Table 9 | 14 | |-------------------------------------------------------|-----| | Changes to L12 Pin Description, Table 12 | 18 | | Changes to Table 17 | 32 | | Changes to SYSREF± Sampling Section | 40 | | Changes to Subclass 1 Section | 41 | | Change to SPI_CHIPGRADE Register, Table 59 | 75 | | Change to DATAPATH_NCO_SYNC_CFG Register, | | | Table 59 | 78 | | Change to SPI_CHIPGRADE Register, Table 60 | 83 | | Change to DATAPATH_NCO_SYNC_CFG Register, | | | Table 60 | 103 | | Changes to Ordering Guide | 144 | | | | #### 6/2017—Revision 0: Initial Version ### **FUNCTIONAL BLOCK DIAGRAM** ### **SPECIFICATIONS** ### **DC SPECIFICATIONS** AVDD1.0 = 1.0 V, AVDD1.8 = 1.8 V, DVDD1.0 = 1.0 V, DVDD1.8 = 1.8 V, SVDD1.0 = 1.0 V, and DAC output full-scale current ( $I_{OUTFS}$ ) = 20 mA, unless otherwise noted. For the minimum and maximum values, $T_J = -40$ °C to +118°C. For the typical values, $T_A = 25$ °C, which corresponds to $T_J = 51$ °C. Table 1. | Parameter | Test Conditions/Comments | Min | Тур | Max | Unit | |--------------------------------------------------|----------------------------------------------|-------|-------|------|--------| | RESOLUTION | | 16 | | | Bit | | ACCURACY | | | | | | | Integral Nonlinearity (INL) | | | ±7 | | LSB | | Differential Nonlinearity (DNL) | | | ±7 | | LSB | | ANALOG OUTPUTS (DAC0+, DAC0-, DAC1+, DAC1-) | | | | | | | Gain Error (with Internal ISET Reference) | | | ±15 | | % | | Full-Scale Output Current | | | | | | | Minimum | $R_{SET} = 5 k\Omega$ | 14.2 | 16 | 17.8 | mA | | Maximum | $R_{SET} = 5 k\Omega$ | 23.6 | 26 | 28.8 | mA | | Common-Mode Voltage | | | 0 | | V | | Differential Impedance | | | 100 | | Ω | | DAC DEVICE CLOCK INPUT (CLKIN+, CLKIN-) | | | | | | | Differential Input Power | $R_{LOAD} = 100 \Omega$ differential on-chip | | | | | | Minimum | | | 0 | | dBm | | Maximum | | | 6 | | dBm | | Differential Input Impedance <sup>1</sup> | | | 100 | | Ω | | Common-Mode Voltage | AC-coupled | | 0.5 | | V | | CLOCK OUTPUT DRIVER (CLKOUT+, CLKOUT-) | | | | | | | Differential Output Power | | | | | | | Minimum | | | -9 | | dBm | | Maximum | | | 0 | | dBm | | Differential Output Impedance | | | 100 | | Ω | | Common-Mode Voltage | AC-coupled | | 0.5 | | V | | Output Frequency | | 727.5 | | 3000 | MHz | | TEMPERATURE DRIFT | | | | | | | Gain | | | 10 | | ppm/°C | | REFERENCE | | | | | | | Internal Reference Voltage | | | 0.495 | | V | | ANALOG SUPPLY VOLTAGES | | | | | | | AVDD1.0 | | 0.95 | 1.0 | 1.05 | V | | AVDD1.8 | | 1.71 | 1.8 | 1.89 | V | | DIGITAL SUPPLY VOLTAGES | | | | | | | DVDD1.0 | | 0.95 | 1.0 | 1.05 | V | | DAVDD1.0 | | 0.95 | 1.0 | 1.05 | V | | DVDD1.8 | | 1.71 | 1.8 | 1.89 | V | | SERIALIZER/DESERIALIZER (SERDES) SUPPLY VOLTAGES | | | | | | | SVDD1.0 | | 0.95 | 1.0 | 1.05 | V | $<sup>^{\</sup>rm 1}$ See the DAC Input Clock Configurations section for more details. #### **DIGITAL SPECIFICATIONS** AVDD1.0 = 1.0 V, AVDD1.8 = 1.8 V, DVDD1.0 = 1.0 V, DVDD1.8 = 1.8 V, SVDD1.0 = 1.0 V, and DAC output full-scale current ( $I_{OUTFS}$ ) = 20 mA, unless otherwise noted. For the minimum and maximum values, $T_J = -40$ °C to +118°C. For the typical values, $T_A = +25$ °C, which corresponds to $T_J = 51$ °C. Table 2. | Parameter | Test Conditions/Comments | Min Typ | Max | Unit | |----------------------------------------------------------------------------------|---------------------------------------|---------|-------|------| | DAC UPDATE RATE | | | | | | Minimum | | | 2.91 | GSPS | | Maximum <sup>1</sup> | 16-bit resolution, with interpolation | 12.6 | | GSPS | | | 16-bit resolution, no interpolation | 6.16 | | GSPS | | Adjusted <sup>2</sup> | 16-bit resolution, with interpolation | 1.575 | | GSPS | | | 16-bit resolution, no interpolation | 6.16 | | GSPS | | DAC PHASE-LOCKED LOOP (PLL) VOLTAGE CONTROLLED OSCILLATOR (VCO) FREQUENCY RANGES | | | | | | VCO Output Divide by 1 | | 8.74 | 12.42 | GSPS | | VCO Output Divide by 2 | | 4.37 | 6.21 | GSPS | | VCO Output Divide by 3 | | 2.91 | 4.14 | GSPS | | PHASE FREQUENCY DETECT INPUT FREQUENCY RANGES | | | | | | 9.96 GHz ≤ VCO Frequency ≤<br>10.87 GHz | | 25 | 225 | MHz | | VCO Frequency < 9.96 GHz or<br>VCO Frequency > 10.87 GHz | | 25 | 770 | MHz | | DAC DEVICE CLOCK INPUT (CLKIN+,<br>CLKIN–) FREQUENCY RANGES | | | | | | PLL Off | | 2.91 | 12.6 | GHz | | PLL On | M divider set to divide by 1 | 25 | 770 | MHz | | | M divider set to divide by 2 | 50 | 1540 | MHz | | | M divider set to divide by 3 | 75 | 2310 | MHz | | | M divider set to divide by 4 | 100 | 3080 | MHz | <sup>&</sup>lt;sup>1</sup> The maximum DAC update rate varies depending on the selected JESD204B mode and the lane rate for the given configuration used. The maximum DAC rate according to lane rate and voltage supply levels is listed in Table 3. #### **MAXIMUM DAC SAMPLING RATE SPECIFICATIONS** AVDD1.0 = 1.0 V, AVDD1.8 = 1.8 V, DVDD1.0 = 1.0 V, DVDD1.8 = 1.8 V, SVDD1.0 = 1.0 V, and DAC output full-scale current ( $I_{OUTFS}$ ) = 20 mA, unless otherwise noted. For the minimum and maximum values, $T_J = -40^{\circ}$ C to +118°C. For the typical values, $T_A = 25^{\circ}$ C, which corresponds to $T_J = 51^{\circ}$ C. Table 3. | Parameter | Test Conditions/Comments | Min | Тур М | ax | Unit | |-----------------------------|--------------------------|-------|-------|----|------| | MAXIMUM DAC UPDATE RATE | | | | | | | $SVDD1.0 = 1.0 V \pm 5\%$ | | | | | | | | Lane rate > 11 Gbps | 11.67 | | | GSPS | | | Lane rate ≤ 11 Gbps | 12.37 | | | GSPS | | $SVDD1.0 = 1.0 V \pm 2.5\%$ | | | | | | | | Lane rate > 11 Gbps | 11.79 | | | GSPS | | | Lane rate ≤ 11 Gbps¹ | 12.6 | | | GSPS | <sup>&</sup>lt;sup>1</sup> If using the on-chip PLL, the maximum DAC speed is limited to the maximum PLL speed of 12.42 GSPS, as listed in Table 2. <sup>&</sup>lt;sup>2</sup> The adjusted DAC update rate is calculated as f<sub>DAC</sub>, divided by the minimum required interpolation factor for a given mode or the maximum channel data rate for a given mode. Different modes have different maximum DAC update rates, minimum interpolation factors, and maximum channel data rates, as shown in Table 13. #### **POWER SUPPLY DC SPECIFICATIONS** AVDD1.0 = 1.0 V, AVDD1.8 = 1.8 V, DVDD1.0 = 1.0 V, DVDD1.8 = 1.8 V, SVDD1.0 = 1.0 V, and DAC output full-scale current ( $I_{OUTFS}$ ) = 20 mA, unless otherwise noted. For the minimum and maximum values, $T_J = -40$ °C to +118°C. For the typical values, $T_A = 25$ °C, which corresponds to $T_J = 51$ °C. Table 4. | Parameter | Test Conditions/Comments | Min | Тур | Max | Unit | |-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------|------|------| | DUAL-LINK MODES | | | | | | | Mode 1 (L = 2, M = 4,<br>NP = 16, N = 16) | 11.7965 GSPS DAC rate, 184.32 MHz PLL reference clock, $32 \times$ total interpolation (4×, 8×), 40 MHz tone at $-3$ dBFS, channel gain = $-6$ dB, channel NCOs = $\pm 150$ MHz, main NCO = 2 GHz, SYNCOUTx $\pm$ in LVDS mode | | | | | | AVDD1.0 | All supply levels set to nominal values | | 725 | 1020 | mA | | | All supply levels set to 5% tolerance | | 775 | 1120 | mA | | AVDD1.8 | | | 110 | 130 | mA | | DVDD1.0 | Combined current consumption with the DAVDD1.0 supply | | | | | | | All supply levels set to nominal values | | 1270 | 1670 | mA | | | All supplies at 5% tolerance | | 1350 | 1850 | mA | | DVDD1.8 | | | 35 | 50 | mA | | SVDD1.0 | | | | | | | | All supply levels set to nominal values | | 290 | 510 | mA | | | All supplies at 5% tolerance | | 305 | 560 | mA | | Total Power<br>Dissipation | | | 2.55 | 3.38 | W | | Mode 4 (L = 4, M = 4,<br>NP = 16, N = 16) | 11.7965 GSPS DAC rate, 491.52 MHz PLL reference clock, $24 \times$ total interpolation (3×, 8×), 40 MHz tone at $-3$ dBFS, channel gain = $-6$ dB, channel NCOs = $\pm$ 150 MHz, main NCO = 2 GHz, SYNCOUTx $\pm$ in LVDS mode | | | | | | AVDD1.0 | | | 725 | | mA | | AVDD1.8 | | | 110 | | mA | | DVDD1.0 | Combined current consumption with the DAVDD1.0 supply | | 1340 | | mA | | DVDD1.8 | | | 35 | | mA | | SVDD1.0 | | | 425 | | mA | | Total Power<br>Dissipation | | | 2.75 | | W | | Mode 0 (L = 1, M = 2,<br>NP = 16, N = 16) | 5.89824 GSPS DAC rate, 184.32 MHz PLL reference clock, 16× total interpolation (2×, 8×), 40 MHz tone at –3 dBFS, channel NCO disabled, main NCO = 1.8425 GHz, SYNCOUTx± in LVDS mode | | | | | | AVDD1.0 | All supply levels set to nominal values | | 400 | 670 | mA | | | All supplies at 5% tolerance | | 425 | 745 | mA | | AVDD1.8 | | | 110 | 130 | mA | | DVDD1.0 | Combined current consumption with the DAVDD1.0 supply | | | | | | | All supply levels set to nominal values | | 625 | 960 | mA | | | All supplies at 5% tolerance | | 670 | 1070 | mA | | DVDD1.8 | | | 35 | 50 | mA | | SVDD1.0 | | | 175 | 340 | mA | | Total Power<br>Dissipation | | | 1.45 | 2.15 | W | | Mode 3 (L = 2, M = 2,<br>NP = 16, N = 16) | 11.7965 GSPS DAC rate, 184.32 MHz PLL reference clock, 24× total interpolation (3×, 8×), 40 MHz tone at $-3$ dBFS, channel NCO disabled, main NCO = 2.655 GHz, SYNCOUTx± in LVDS mode | | | | | | AVDD1.0 | All supply levels set to nominal values | | 725 | | mA | | | All supplies at 5% tolerance | | 775 | | mA | | AVDD1.8 | · · · | | 110 | | mA | | DVDD1.0 | Combined current consumption with the DAVDD1.0 supply | | | | | | | All supply levels set to nominal values | | 1175 | | mA | | | All supplies at 5% tolerance | | 1250 | | mA | | Parameter | Test Conditions/Comments | Min | Тур | Max | Unit | |--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------|--------------|----------| | DVDD1.8 | | | 35 | | mA | | SVDD1.0 | All supply levels set to nominal values | | 245 | | mA | | | All supplies at 5% tolerance | | 250 | | mA | | Total Power<br>Dissipation | | | 2.4 | | W | | Mode 9 (L = 4, M = 2,<br>NP = 16, N = 16) | 12 GSPS DAC rate, 187.5 MHz PLL reference clock, $8 \times$ total interpolation $(1 \times, 8 \times)$ , 10 MHz tone at $-3$ dBFS, channel NCO disabled, main NCO = $3.072$ GHz, $\overline{\text{SYNCOUTx}}$ in LVDS mode | | | | | | AVDD1.0 | All supply levels set to nominal values All supplies at 5% tolerance | | 740<br>785 | 1030<br>1135 | mA<br>mA | | AVDD1.8 | | | 110 | 130 | mA | | DVDD1.0 | Combined current consumption with the DAVDD1.0 supply | | | | | | 2.22 | All supply levels set to nominal values | | 1170 | 1580 | mA | | | All supplies at 5% tolerance | | 1250 | 1740 | mA | | DVDD1.8 | 7 th supplies at 5 % tolerance | | 35 | 50 | mA | | SVDD1.0 | All supply levels set to nominal values | | 530 | 840 | mA | | 30001.0 | All supplies at 5% tolerance | | 550 | 910 | mA | | Total Power Dissipation | All supplies at 5% tolerance | | 2.7 | 3.63 | W | | Mode 2 (L = 3, M = 6,<br>NP = 16, N = 16) | 12 GSPS DAC rate, 375 MHz PLL reference clock, $48 \times$ total interpolation $(6 \times, 8 \times)$ , 30 MHz tone at $-3$ dBFS, channel gain = $-11$ dB, channel NCOs = 20 MHz, main NCO = 2.1 GHz | | | | | | AVDD1.0 | All supply levels set to nominal values | | 735 | 1030 | mA | | AVDD1.0 | All supplies at 5% tolerance | | 735<br>785 | 1135 | mA | | AVDD1.8 | All supplies at 5% tolerance | | 110 | 130 | | | DVDD1.0 | Combined current consumption with the DAVDD1 0 supply | | 110 | 130 | mA<br>mA | | ווטטעט.0 | Combined current consumption with the DAVDD1.0 supply | | 1270 | 1000 | | | | All supply levels set to nominal values | | 1370 | 1800 | mA | | DVDD1.0 | All supplies at 5% tolerance | | 1460 | 1980 | mA | | DVDD1.8 | | | 35 | 50 | mA | | SVDD1.0 | All supply levels set to nominal values | | 410 | 680 | mA | | | All supplies at 5% tolerance | | 430 | 755 | mA | | Total Power Dissipation | | | 2.77 | 3.69 | W | | SINGLE-LINK MODES | | | | | | | Mode 20 (L = 8, M = 1,<br>NP = 16, N = 16) | 6 GSPS DAC rate, 187.5 MHz PLL reference clock, 1× total interpolation (1×, 1×), 1.8 GHz tone at –3 dBFS, channel and main NCOs disabled | | | | | | AVDD1.0 | All supply levels set to nominal values | | 400 | 670 | mA | | | All supplies at 5% tolerance | | 430 | 745 | mA | | AVDD1.8 | | | 75 | 100 | mA | | DVDD1.0 | Combined current consumption with the DAVDD1.0 supply | | | | | | | All supply levels set to nominal values | | 400 | 700 | mA | | | All supplies at 5% tolerance | | 420 | 810 | mA | | DVDD1.8 | | | 35 | 50 | mA | | SVDD1.0 | All supply levels set to nominal values | | 525 | 820 | mA | | | All supplies at 5% tolerance | | 550 | 880 | mA | | Total Power<br>Dissipation | / supplies at 5 /s to let at 100 | | 1.5 | 2.34 | W | | Mode 12 (L = 8, M = 2, | 4 GSPS DAC rate, 187.5 MHz PLL reference clock, 1× total interpolation | | | | | | NP = 12, N = 12 | (1×, 1×), 1 GHz tone at –3 dBFS, channel and main NCOs disabled | | 200 | 550 | | | AVDD1.0 | All supply levels set to nominal values | | 300 | 550 | mA | | N/DD4 5 | All supplies at 5% tolerance | | 315 | 620 | mA | | AVDD1.8 | | | 75 | 100 | mA | | Parameter | Test Conditions/Comments | Min | Тур | Max | Unit | |----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------|----------|----------| | DVDD1.0 | Combined current consumption with the DAVDD1.0 supply | | | | | | | All supply levels set to nominal values | | 325 | 630 | mA | | | All supplies at 5% tolerance | | 340 | 725 | mA | | DVDD1.8 | | | 35 | 50 | mA | | SVDD1.0 | All supply levels set to nominal values | | 525 | 820 | mA | | | All supplies at 5% tolerance | | 550 | 880 | mA | | Total Power<br>Dissipation | | | 1.32 | 2.15 | W | | DUAL-LINK, MODE 3 (NCO<br>ONLY, SINGLE-CHANNEL<br>MODE, NO SERDES) | 6 GSPS DAC rate, 300 MHz PLL reference clock, $8\times$ total interpolation (1×, $8\times$ ), no input tone (dc internal level = 0x50FF), channel NCO = 40 MHz, main NCO = 1.8425 GHz | | | | | | Mode 3<br>AVDD1.0 | | | | | | | AVDD1.0 | All supply lovels set to pominal values | | 410 | 660 | A | | | All supply levels set to nominal values All supplies at 5% tolerance | | 435 | 750 | mA<br>mA | | AVDD1.8 | All supplies at 5% tolerance | | 433<br>110 | 130 | mA | | DVDD1.0 | Combined current concumption with the DAVDD1 0 cumply | | 110 | 130 | IIIA | | ט.וטטעט.ט | Combined current consumption with the DAVDD1.0 supply All supply levels set to nominal values | | 500 | 780 | mA | | | All supplies at 5% tolerance | | 515 | 950 | mA | | DVDD1.8 | All supplies at 5% tolerance | | 0.3 | 950<br>1 | mA | | SVDD1.0 | All supply levels set to nominal values | | 5 | 100 | mA | | 34001.0 | All supplies at 5% tolerance | | 3 | 120 | mA | | Total Power | All supplies at 5% tolerance | | 3<br>1.1 | 1.671 | W | | Dissipation | | | 1.1 | 1.071 | VV | | DUAL-LINK, MODE 4 (NCO<br>ONLY, DUAL-CHANNEL<br>MODE, NO SERDES)<br>Mode 4 | 12 GSPS DAC rate, 500 MHz PLL reference clock, 32× total interpolation (4×, 8×), no input tone (dc internal level = 0x2AFF), channel NCOs = $\pm 150$ MHz, main NCO = 2 GHz | | | | | | AVDD1.0 | All supply levels set to nominal values | | 750 | 1030 | mA | | 7,0001.0 | All supplies at 5% tolerance | | 790 | 1130 | mA | | AVDD1.8 | 741 Supplies at 570 tolerance | | 110 | 130 | mA | | DVDD1.0 | Combined current consumption with the DAVDD1.0 supply | | 110 | 150 | '''' | | DVDD1.0 | All supply levels set to nominal values | | 1200 | 1590 | mA | | | All supplies at 5% tolerance | | 1300 | 1750 | mA | | DVDD1.8 | sapplies at 570 total affect | | 0.3 | 1/30 | mA | | SVDD1.0 | | | 5 | 100 | mA | | Total Power | | | 2.2 | 2.851 | W | | Dissipation | | | | | | #### **SERIAL PORT AND CMOS PIN SPECIFICATIONS** AVDD1.0 = 1.0 V, AVDD1.8 = 1.8 V, DVDD1.0 = 1.0 V, DVDD1.8 = 1.8 V, SVDD1.0 = 1.0 V, and DAC output full-scale current ( $I_{OUTFS}$ ) = 20 mA, unless otherwise noted. For the minimum and maximum values, $T_J = -40$ °C to +118°C. For the typical values, $T_A = 25$ °C, which corresponds to $T_J = 51$ °C. Table 5. | Parameter | Symbol | Test Comments/Conditions | Min | Тур | Max | Unit | |--------------------------------------------------|-----------------------------------------|----------------------------------------|-------|-----|-------|------| | WRITE OPERATION | | See Figure 45 | | | | | | Maximum SCLK Clock Rate | fsclk, 1/tsclk | | 80 | | | MHz | | SCLK Clock High | t <sub>РWH</sub> | SCLK = 20 MHz | 5.03 | | | ns | | SCLK Clock Low | t <sub>PWL</sub> | SCLK = 20 MHz | 1.6 | | | ns | | SDIO to SCLK Setup Time | t <sub>DS</sub> | | 1.154 | | | ns | | SCLK to SDIO Hold Time | t <sub>DH</sub> | | 0.577 | | | ns | | CS to SCLK Setup Time | ts | | 1.036 | | | ns | | SCLK to CS Hold Time | tн | | -5.3 | | | ps | | READ OPERATION | | See Figure 44 | | | | | | SCLK Clock Rate | f <sub>sclк</sub> , 1/t <sub>sclк</sub> | | | | 48.58 | MHz | | SCLK Clock High | t <sub>РWH</sub> | | 5.03 | | | ns | | SCLK Clock Low | t <sub>PWL</sub> | | 1.6 | | | ns | | SDIO to SCLK Setup Time | t <sub>DS</sub> | | 1.158 | | | ns | | SCLK to SDIO Hold Time | t <sub>DH</sub> | | 0.537 | | | ns | | CS to SCLK Setup Time | ts | | 1.036 | | | ns | | SCLK to SDIO Data Valid Time | t <sub>DV</sub> | | 9.6 | | | ns | | SCLK to SDO Data Valid Time | t <sub>DV</sub> | | 13.7 | | | ns | | CS to SDIO Output Valid to High-Z | | Not shown in Figure 44 or Figure 45 | 5.4 | | | ns | | CS to SDO Output Valid to High-Z | | Not shown in Figure 44 or<br>Figure 45 | 9.59 | | | ns | | INPUTS (SDIO, SCLK, CS, RESET, TXEN0, and TXEN1) | | | | | | | | Voltage Input | | | | | | | | High | V <sub>IH</sub> | | 1.48 | | | ٧ | | Low | VIL | | | | 0.425 | ٧ | | Current Input | | | | | | | | High | Iн | | | | ±100 | nA | | Low | I <sub>IL</sub> | | ±100 | | | nΑ | | OUTPUTS (SDIO, SDO) | | | | | | | | Voltage Output | | | | | | | | High | V <sub>OH</sub> | | | | | | | 0 mA load | | | 1.69 | | | ٧ | | 4 mA load | | | 1.52 | | | V | | Low | V <sub>OL</sub> | | | | | | | 0 mA load | | | | | 0.045 | ٧ | | 4 mA load | | | | | 0.175 | ٧ | | Current Output | | | | | | | | High | I <sub>OH</sub> | | | 4 | | mA | | Low | loL | | | 4 | | mA | | INTERRUPT OUTPUTS (IRQ0, IRQ1) | | | | | | | | Voltage Output | | | | | | | | High | V <sub>OH</sub> | | 1.71 | | | V | | Low | V <sub>OL</sub> | | | | 0.075 | V | #### **DIGITAL INPUT DATA TIMING SPECIFICATIONS** AVDD1.0 = 1.0 V, AVDD1.8 = 1.8 V, DVDD1.0 = 1.0 V, DVDD1.8 = 1.8 V, SVDD1.0 = 1.0 V, and DAC output full-scale current ( $I_{OUTFS}$ ) = 20 mA, unless otherwise noted. For the minimum and maximum values, $T_J = -40^{\circ}$ C to +118°C. For the typical values, $T_A = 25^{\circ}$ C, which corresponds to $T_J = 51^{\circ}$ C. Table 6. | Parameter | Test Conditions/Comments | Min | Тур | Max | Unit | |---------------------------------------------------------------------|------------------------------------------------------------|-----|------|-----|------------------| | LATENCY <sup>1</sup> | | | | | | | Channel Interpolation Factor, Main<br>Datapath Interpolation Factor | LMFC_VAR_x = 12, LMFC_DELAY_x = 12, unless otherwise noted | | | | | | 1×, 1ײ | JESD204B Mode 10,3 Mode 183 | | 420 | | DAC clock cycle | | | JESD204B Mode 11, Mode 19 | | 440 | | DAC clock cycle | | | JESD204B Mode 12, Mode 19 | | 590 | | DAC clock cycle | | | JESD204B Mode 20 <sup>3</sup> | | 700 | | DAC clock cycle | | | JESD204B Mode 21 | | 750 | | DAC clock cycle | | 1×, 2ײ | JESD204B Mode 8 <sup>3</sup> | | 670 | | DAC clock cycle | | | JESD204B Mode 9 | | 700 | | DAC clock cycle | | $1\times$ , $4\times^2$ | JESD204B Mode 8 <sup>3</sup> | | 1090 | | DAC clock cycle | | | JESD204B Mode 9 | | 1140 | | DAC clock cycle | | 1×, 6ײ | JESD204B Mode 8 <sup>3</sup> | | 1460 | | DAC clock cycle | | | JESD204B Mode 9 | | 1530 | | DAC clock cycle | | 1×, 8ײ | JESD204B Mode 3 | | 1390 | | DAC clock cycle | | . , . | JESD204B Mode 8 <sup>3</sup> | | 1820 | | DAC clock cycle | | | JESD204B Mode 9 | | 1920 | | DAC clock cycle | | 1×, 12ײ | JESD204B Mode 8 <sup>3</sup> | | 2700 | | DAC clock cycle | | | JESD204B Mode 9 | | 2840 | | DAC clock cycle | | 2×, 6ײ | JESD204B Mode 3, Mode 4 | | 1970 | | DAC clock cycle | | | JESD204B Mode 5 | | 1770 | | DAC clock cycle | | 2×, 8ײ | JESD204B Mode 0 | | 2020 | | DAC clock cycle | | · | JESD204B Mode 3, Mode 4 | | 2500 | | DAC clock cycle | | 3×, 6× <sup>2</sup> | JESD204B Mode 3, Mode 4 | | 2880 | | DAC clock cycle | | · | JESD204B Mode 5, Mode 6 | | 2630 | | DAC clock cycle | | 3×, 8ײ | JESD204B Mode 3, Mode 4 | | 3310 | | DAC clock cycle | | · | JESD204B Mode 5, Mode 6 | | 2980 | | DAC clock cycle | | 4×, 6ײ | JESD204B Mode 0, Mode 1, Mode 2 | | 2410 | | DAC clock cycle | | 4×, 8ײ | JESD204B Mode 0, Mode 1, Mode 2 | | 3090 | | DAC clock cycle | | 6×, 6× <sup>2</sup> | JESD204B Mode 0, Mode 1, Mode 2 | | 3190 | | DAC clock cycle | | 6×, 8ײ | JESD204B Mode 0, Mode 1, Mode 2 | | 4130 | | DAC clock cycle | | 8×, 6× <sup>2</sup> | JESD204B Mode 7 | | 3300 | | DAC clock cycle | | 8×, 8× <sup>2</sup> | JESD204B Mode 7 | | 4270 | | DAC clock cycle | | DETERMINISTIC LATENCY | JEJDZOTD MIOGE / | | 72/0 | | Drie clock cycle | | Fixed | | | | 13 | PCLK⁴ | | Variable | | | | 2 | PCLK cycles | | SYSREF± TO LMFC DELAY | | | 0 | | DAC clock cycles | | 313NLI ± 10 LIVIFC DELAT | | | U | | DAC CIOCK CYCIES | <sup>&</sup>lt;sup>1</sup> Total latency (or pipeline delay) through the device is calculated as follows: total latency = interface latency + fixed latency + variable latency + pipeline delay. <sup>&</sup>lt;sup>2</sup> The first value listed in this specification is the channel interpolation factor, and the second value is the main datapath interpolation factor. $<sup>^3</sup>$ LMFC\_VAR\_x = 7 and LMFC\_DELAY\_x = 4 $<sup>^4</sup>$ PCLK is the internal processing clock for the AD9172 and equals the lane rate $\div$ 40. #### **JESD204B INTERFACE ELECTRICAL AND SPEED SPECIFICATIONS** AVDD1.0 = 1.0 V, AVDD1.8 = 1.8 V, DVDD1.0 = 1.0 V, DVDD1.8 = 1.8 V, SVDD1.0 = 1.0 V, and DAC output full-scale current ( $I_{OUTFS}$ ) = 20 mA, unless otherwise noted. For the minimum and maximum values, $T_J = -40^{\circ}$ C to +118°C. For the typical values, $T_A = 25^{\circ}$ C, which corresponds to $T_J = 51^{\circ}$ C. Table 7. | Parameter | Symbol | Test Conditions/Comments | Min | Тур | Max | Unit | |----------------------------------------------------------|--------------------|--------------------------------------------------|-------|------|-------|------| | JESD204B SERIAL INTERFACE RATE (SERIAL LANE RATE) | | | 3 | | 15.4 | Gbps | | JESD204B DATA INPUTS | | | | | | | | Input Leakage Current | | $T_A = 25$ °C | | | | | | Logic High | | Input level = $1.0 \text{ V} \pm 0.25 \text{ V}$ | | 10 | | μΑ | | Logic Low | | Input level = 0 V | | -4 | | μΑ | | Unit Interval | UI | | 333 | | 66.7 | ps | | Common-Mode Voltage | $V_{RCM}$ | AC-coupled | -0.05 | | +1.1 | V | | Differential Voltage | $R_V_{DIFF}$ | | 110 | | 1050 | mV | | Differential Impedance | Z <sub>RDIFF</sub> | At dc | 80 | 100 | 120 | Ω | | SYSREF± INPUT | | | | | | | | Differential Impedance | | | | 100 | | Ω | | DIFFERENTIAL OUTPUTS (SYNCOUT0±, SYNCOUT1±) <sup>1</sup> | | Driving 100 Ω differential load | | | | | | Output Differential Voltage | V <sub>OD</sub> | | 320 | 390 | 460 | mV | | Output Offset Voltage | Vos | | 1.08 | 1.12 | 1.15 | V | | SINGLE-ENDED OUTPUTS (SYNCOUT0±, SYNCOUT1±) | | Driving 100 Ω differential load | | | | | | Output Voltage | | | | | | | | High | V <sub>OH</sub> | | 1.69 | | | V | | Low | V <sub>OL</sub> | | | | 0.045 | V | | Current Output | | | | | | | | High | I <sub>ОН</sub> | | | 0 | | mA | | Low | I <sub>OL</sub> | | | 0 | | mA | $<sup>^{\</sup>scriptscriptstyle 1}$ IEEE Standard 1596.3 LVDS compatible. #### INPUT DATA RATES AND SIGNAL BANDWIDTH SPECIFICATIONS AVDD1.0 = 1.0 V, AVDD1.8 = 1.8 V, DVDD1.0 = 1.0 V, DVDD1.8 = 1.8 V, SVDD1.0 = 1.0 V, and DAC output full-scale current ( $I_{OUTFS}$ ) = 20 mA, unless otherwise noted. For the minimum and maximum values, $T_J = -40$ °C to +118°C. For the typical values, $T_A = 25$ °C, which corresponds to $T_J = 51$ °C. Table 8. | Parameter <sup>1</sup> | Test Conditions/Comments | Min | Тур | Max | Unit | |----------------------------------------------------|-----------------------------------------------------------------------------------|------|-----|------|------| | INPUT DATA RATE PER INPUT CHANNEL | | | · | | | | | Channel datapaths bypassed (1× interpolation), single-DAC mode, 16-bit resolution | | | 6160 | MSPS | | | Channel datapaths bypassed (1× interpolation), dual DAC mode, 16-bit resolution | | | 3080 | MSPS | | | Channel datapaths bypassed (1× interpolation), dual DAC mode, 12-bit resolution | | | 4100 | MSPS | | | 1 complex channel enabled | | | 1540 | MSPS | | | 2 complex channels enabled | | | 770 | MSPS | | | 3 complex channels enabled | | | 385 | MSPS | | COMPLEX SIGNAL BANDWIDTH PER INPUT<br>CHANNEL | | | | | | | | 1 complex channel enabled (0.8 × f <sub>DATA</sub> ) | | | 1232 | MHz | | | 2 complex channels enabled (0.8 $\times$ f <sub>DATA</sub> ) | | | 616 | MHz | | | 3 complex channels enabled $(0.8 \times f_{DATA})$ | | | 308 | MHz | | MAXIMUM NCO CLOCK RATE | | | | | | | Channel NCO | | | | 1540 | MHz | | Main NCO | | | | 12.6 | GHz | | MAXIMUM NCO SHIFT FREQUENCY RANGE | | | | | | | Channel NCO | Channel summing node = 1.575 GHz, channel interpolation rate > $1 \times$ | -770 | | +770 | MHz | | Main NCO | $f_{DAC} = 12.6$ GHz, main interpolation rate $> 1 \times$ | -6.3 | | +6.3 | GHz | | MAXIMUM FREQUENCY SPACING<br>ACROSS INPUT CHANNELS | Maximum NCO output frequency × 0.8 | | | 1232 | MHz | <sup>&</sup>lt;sup>1</sup> Values listed for these parameters are the maximum possible when considering all JESD204B modes of operation. Some modes are more limiting, based on other parameters. #### **AC SPECIFICATIONS** AVDD1.0 = 1.0 V, AVDD1.8 = 1.8 V, DVDD1.0 = 1.0 V, DVDD1.8 = 1.8 V, SVDD1.0 = 1.0 V, and DAC output full-scale current ( $I_{OUTFS}$ ) = 20 mA, unless otherwise noted. For the minimum and maximum, $T_J = -40$ °C to +118°C. For the typical values, $T_A = 25$ °C, which corresponds to $T_J = 51$ °C. Table 9. | Parameter | Test Conditions/Comments | Min | Тур | Max | Unit | |-----------------------------------------------------------------------|--------------------------------------------------------------------------------------|-----|-----|-----|------| | SPURIOUS-FREE DYNAMIC RANGE (SFDR) | | | | | | | Single Tone, $f_{DAC} = 12000$ MSPS, Mode 1 (L = 2, M = 4) | –7 dBFS, shuffle enabled | | | | | | $f_{OUT} = 100 \text{ MHz}$ | | | -81 | | dBc | | $f_{OUT} = 500 \text{ MHz}$ | | | -80 | | dBc | | $f_{OUT} = 950 \text{ MHz}$ | | | -75 | | dBc | | f <sub>OUT</sub> = 1840 MHz | | | -80 | | dBc | | $f_{OUT} = 2650 \text{ MHz}$ | | | -75 | | dBc | | f <sub>OUT</sub> = 3700 MHz | | | -67 | | dBc | | Single Tone, $f_{DAC} = 6000$ MSPS, Mode 0 (L = 1, M = 2) | –7 dBFS, shuffle enabled | | | | | | $f_{OUT} = 100 \text{ MHz}$ | | | -85 | | dBc | | $f_{OUT} = 500 \text{ MHz}$ | | | -85 | | dBc | | $f_{OUT} = 950 \text{ MHz}$ | | | -78 | | dBc | | $f_{OUT} = 1840 \text{ MHz}$ | | | -75 | | dBc | | f <sub>OUT</sub> = 2650 MHz | | | -69 | | dBc | | Single Tone, $f_{DAC} = 3000$ MSPS, Mode 10 (L = 8, M = 2) | –7 dBFS, shuffle enabled | | | | | | $f_{OUT} = 100 \text{ MHz}$ | | | -87 | | dBc | | $f_{OUT} = 500 \text{ MHz}$ | | | -84 | | dBc | | $f_{OUT} = 950 \text{ MHz}$ | | | -81 | | dBc | | Single-Band Application—Band 3 (1805 MHz to 1880 MHz) | Mode 0, $2 \times$ to $8 \times$ , $f_{DAC} = 6000$ MSPS, 368.64 MHz reference clock | | | | | | SFDR Harmonics | –7 dBFS, shuffle enabled | | | | | | In-Band | | | -82 | | dBc | | Digital Predistortion (DPD) Band | DPD bandwidth = data rate $\times$ 0.8 | | -80 | | dBc | | Second Harmonic | | | -82 | | dBc | | Third Harmonic | | | -80 | | dBc | | Fourth and Fifth Harmonic | | | -95 | | dBc | | SFDR Nonharmonics | –7 dBFS, shuffle enabled | | | | | | In-Band | | | -74 | | dBc | | DPD Band | | | -74 | | dBc | | ADJACENT CHANNEL LEAKAGE RATIO | | | | | | | 4C-WCDMA | –1 dBFS digital backoff | | | | | | $f_{DAC} = 1200 \text{ MSPS}, \text{ Mode } 1 \text{ (L} = 2, M = 4)$ | f <sub>OUT</sub> = 1840 MHz | | -70 | | dBc | | | fouт = 2650 MHz | | -68 | | dBc | | | f <sub>OUT</sub> = 3500 MHz | | -66 | | dBc | | $f_{DAC} = 6000 \text{ MSPS}, \text{ Mode } 0 \text{ (L} = 1, M = 2)$ | fout = 1840 MHz | | -71 | | dBc | | | f <sub>OUT</sub> = 2650 MHz | | -66 | | dBc | | THIRD-ORDER INTERMODULATION DISTORTION | Two-tone test, –7 dBFS/tone, 1 MHz spacing | | | | | | $f_{DAC} = 12000 \text{ MSPS}, \text{ Mode 1 (L = 2, M = 4)}$ | f <sub>OUT</sub> = 1840 MHz | | -83 | | dBc | | | f <sub>OUT</sub> = 2650 MHz | | -85 | | dBc | | | f <sub>OUT</sub> = 3700 MHz | | -77 | | dBc | | $f_{DAC} = 6000 \text{ MSPS}, \text{ Mode 0 (L = 1, M = 2)}$ | f <sub>OUT</sub> = 1840 MHz | | -74 | | dBc | | | f <sub>OUT</sub> = 2650 MHz | | -72 | | dBc | | Parameter | Test Conditions/Comments | Min | Тур | Max | Unit | |----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------|-----|--------| | NOISE SPECTRAL DENSITY (NSD) | 0 dBFS, NSD measurement taken at 10% away from fout, shuffle on | | • | | | | Single Tone, f <sub>DAC</sub> = 12000 MSPS | | | | | | | f <sub>OUT</sub> = 200 MHz | | | -163 | | dBc/Hz | | $f_{OUT} = 500 \text{ MHz}$ | | | -163 | | dBc/Hz | | $f_{OUT} = 950 \text{ MHz}$ | | | -162 | | dBc/Hz | | $f_{OUT} = 1850 MHz$ | | | -160 | | dBc/Hz | | $f_{OUT} = 2150 \text{ MHz}$ | | | -158 | | dBc/Hz | | Single Tone, f <sub>DAC</sub> = 6000 MSPS | | | | | | | $f_{OUT} = 200 MHz$ | | | -164 | | dBc/Hz | | $f_{OUT} = 500 \text{ MHz}$ | | | -163 | | dBc/Hz | | $f_{OUT} = 950 \text{ MHz}$ | | | -161 | | dBc/Hz | | $f_{OUT} = 1850 \text{ MHz}$ | | | -157 | | dBc/Hz | | $f_{OUT} = 2150 \text{ MHz}$ | | | -155 | | dBc/Hz | | Single Tone, f <sub>DAC</sub> = 3000 MSPS | | | | | | | $f_{OUT} = 200 MHz$ | | | -163 | | dBc/Hz | | $f_{OUT} = 500 \text{ MHz}$ | | | -159 | | dBc/Hz | | $f_{OUT} = 950 \text{ MHz}$ | | | -155 | | dBc/Hz | | SINGLE-SIDEBAND PHASE NOISE OFFSET | Loop filter component values according to Figure 86 are as follows: C1 = 22 nF, R1 = 232 $\Omega$ , C2 = 2.4 nF, C3 = 33 nF; PFD frequency = 500 MHz, $f_{OUT}$ = 1.8 GHz, $f_{DAC}$ = 12 GHz | | | | | | 1 kHz | | | -97 | | dBc/Hz | | 10 kHz | | | -105 | | dBc/Hz | | 100 kHz | | | -114 | | dBc/Hz | | 600 kHz | | | -126 | | dBc/Hz | | 1.2 MHz | | | -133 | | dBc/Hz | | 1.8 MHz | | | -137 | | dBc/Hz | | 6 MHz | | | -148 | | dBc/Hz | | DAC TO DAC OUTPUT ISOLATION | Taken using the AD9172-FMC-EBZ evaluation board | | | | | | Dual Band— $f_{DAC} = 12000$ MSPS, Mode 1 (L = 2, M = 4) | | | | | | | | f <sub>OUT</sub> = 1840 MHz | | -77 | | dB | | | f <sub>OUT</sub> = 2650 MHz | | -70 | | dB | | | f <sub>OUT</sub> = 3700 MHz | | -68 | | dB | ### **ABSOLUTE MAXIMUM RATINGS** Table 10. | Parameter | Rating | |-------------------------------------------------------------------------|---------------------------| | ISET, FILT_COARSE, FILT_BYP, FILT_VCM | -0.3 V to AVDD1.8 + 0.3 V | | SERDINx± | -0.2 V to SVDD1.0 + 0.2 V | | SYNCOUT0±, SYNCOUT1±, RESET, | -0.3 V to DVDD1.8 + 0.3 V | | TXEN0, TXEN1, $\overline{IRQ0}$ , $\overline{IRQ1}$ , $\overline{CS}$ , | | | SCLK, SDIO, SDO | | | DAC0±, DAC1±, CLKIN±, CLKOUT±, | -0.2 V to AVDD1.0 + 0.2 V | | FILT_FINE | | | SYSREF± | -0.2 V to DVDD1.0 + 0.2 V | | AVDD1.0, DVDD1.0, SVDD1.0 to GND | -0.2 V to +1.2 V | | AVDD1.8, DVDD1.8 to GND | -0.3 V to 2.2 V | | Maximum Junction Temperature (T <sub>J</sub> ) <sup>1</sup> | 118°C | | Storage Temperature Range | −65°C to +150°C | | Reflow | 260°C | <sup>&</sup>lt;sup>1</sup> Some operating modes of the device may cause the device to approach or exceed the maximum junction temperature during operation at supported ambient temperatures. Removal of heat from the device may require additional measures such as active airflow, heat sinks, or other measures. Stresses at or above those listed under Absolute Maximum Ratings may cause permanent damage to the product. This is a stress rating only; functional operation of the product at these or any other conditions above those indicated in the operational section of this specification is not implied. Operation beyond the maximum operating conditions for extended periods may affect product reliability. #### **REFLOW PROFILE** The AD9172 reflow profile is in accordance with the JEDEC JESD20 criteria for Pb-free devices. The maximum reflow temperature is 260°C. #### THERMAL CHARACTERISTICS Thermal performance is directly linked to printed circuit board (PCB) design and operating environment. Careful attention to PCB thermal design is required. $\theta_{JA}$ is the natural convection junction to ambient thermal resistance measured in a one cubic foot sealed enclosure. $\theta_{JC}$ is the junction to case thermal resistance. Thermal resistances and thermal characterization parameters are specified vs. the number of PCB layers in different airflow velocities (in m/sec). The use of appropriate thermal management techniques is recommended to ensure that the maximum junction temperature does not exceed the limits shown in Table 10. Use the values in Table 11 in compliance with JEDEC 51-12. Table 11. Simulated Thermal Resistance vs. PCB Layers<sup>1</sup> | PCB Type | Airflow<br>Velocity<br>(m/sec) | θJA | <b>Ө</b> ЈС_ТОР | <b>Ө</b> JС_ВОТ | Unit | |------------------|--------------------------------|------|-----------------|-----------------|------| | JEDEC | 0.0 | 25.3 | 2.43 | 3.04 | °C/W | | 2s2p | 1.0 | 22.6 | N/A | N/A | °C/W | | Board | 2.5 | 21.0 | N/A | N/A | °C/W | | 12-Layer | 0.0 | 15.4 | 2.4 | 2.6 | °C/W | | PCB <sup>2</sup> | 1.0 | 13.1 | N/A | N/A | °C/W | | | 2.5 | 11.6 | N/A | N/A | °C/W | <sup>&</sup>lt;sup>1</sup> N/A means not applicable. #### **ESD CAUTION** ESD (electrostatic discharge) sensitive device. Charged devices and circuit boards can discharge without detection. Although this product features patented or proprietary protection circuitry, damage may occur on devices subjected to high energy ESD. Therefore, proper ESD precautions should be taken to avoid performance degradation or loss of functionality. <sup>&</sup>lt;sup>2</sup> Non JEDEC thermal resistance. <sup>&</sup>lt;sup>3</sup> 1SOP PCB with no vias in PCB. $<sup>^4</sup>$ 1SOP PCB with 7 $\times$ 7 standard JEDEC vias. ### PIN CONFIGURATION AND FUNCTION DESCRIPTIONS Figure 2. Pin Configuration 15453-002 **Table 12. Pin Function Descriptions** | Pin No. | Mnemonic | Description | |------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1.0 V Supply | | | | H3, H4, H5, H8 to H10, J6, M2, M11 | AVDD1.0 | 1.0 V Clock and Analog Supplies. These pins supply the clock receivers, clock distribution, the on-chip DAC clock multiplier, and the DAC analog core. Clear power supply rail sources are required on these pins. | | F5 to F8 | DVDD1.0 | 1.0 V Digital Supplies. These pins supply power to the DAC digital circuitry. Clean power supply rail sources are required on these pins. | | F4, F9 | DAVDD1.0 | 1.0 V Digital to Analog Supplies. These pins can share a supply rail with the DVDD1.0 supply (electrically connected) but must have separate supply plane and decoupling capacitors for the PCB layout to improve isolation for these two pins. Clean power supply rail sources are required on these pins. | | C1, C2, C5, C7, C8, C11, C12, D6 | SVDD1.0 | 1.0 V SERDES Supplies to the JESD204B Data Interface. Clean power supply ra sources are required on these pins. | | 1.8 V Supply | | | | K3, K5, K7, K10, L3, L6, L7, L10 | AVDD1.8 | 1.8 V Analog Supplies to the On-Chip DAC Clock Multiplier and the DAC Analog Core. Clean power supply rail sources are required on these pins. | | C6, D3, D10, E3, E10 | DVDD1.8 | 1.8 V Digital Supplies to the JESD204B Data Interface and the Other Input/Output Circuitry, Such as the Serial Port Interface (SPI). Clean power supply rail sources are required on these pins. | | Pin No. | Mnemonic | Description | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Ground | | | | A1, A6, A7, A12, B1, B6, B7, B12, C3, C4,<br>C9, C10, D5, D7, F1 to F3, F10 to F12,<br>G1 to G12, H11, J1, J3 to J5, J8 to J11,<br>K2, K8, K9, K11, K12, L2, L4, L5, L8, L9,<br>L11, M1, M3, M6, M7, M10, M12 | GND | Device Common Ground. | | RF Clock | | | | J12 | CLKIN+ | Positive Device Clock Input. This pin is the clock input for the on-chip DAC clock multiplier, REFCLK, when the DAC PLL is on. This pin is also the clock input for the DAC sample clock or device clock (DACCLK) when the DAC PLL is off. AC couple this input. There is an internal $100~\Omega$ resistor between this pin and CLKIN—. | | H12 | CLKIN- | Negative Device Clock Input. | | K1 | CLKOUT+ | Positive Device Clock Output. This pin is the clock output of a divided down DACCLK and is available with the DAC PLL on and off. The divide down ratios are by 1, 2, or 4. | | L1 | CLKOUT- | Negative Device Clock Output. | | System Reference | | | | H1 | SYSREF+ | Positive System Reference Input. It is recommended to ac couple this pin, but dc coupling is also acceptable. See the SYSREF± specifications for the dc common-mode voltage. | | H2 | SYSREF- | Negative System Reference Input. It is recommended to ac couple this pin, but dc coupling is also acceptable. See the SYSREF± specifications for the dc common-mode voltage. | | On-Chip DAC PLL Loop Filter | | | | H6 | FILT_FINE | On-Chip DAC Clock Multiplier and PLL Fine Loop Filter Input. | | H7 | FILT_COARSE | On-Chip DAC Clock Multiplier and PLL Coarse Loop Filter Input. | | J7 | FILT_BYP | On-Chip DAC Clock Multiplier and LDO Bypass. | | K6 | FILT_VCM | On-Chip DAC Clock Multiplier and VCO Common-Mode Input. | | SERDES Data Bits | 1121_1 2111 | - Chip 5770 Closk maniphor and 100 Common mode input | | A2 | SERDIN7+ | SERDES Data Bit 7, Positive. | | B2 | SERDIN7- | SERDES Data Bit 7, Negative. | | A3 | SERDIN6+ | SERDES Data Bit 6, Positive. | | B3 | SERDIN6- | SERDES Data Bit 6, Negative. | | A4 | SERDIN5+ | SERDES Data Bit 5, Positive. | | B4 | SERDIN5- | SERDES Data Bit 5, Negative. | | A5 | SERDIN4+ | SERDES Data Bit 4, Positive. | | B5 | SERDIN4- | SERDES Data Bit 4, Negative. | | A8 | SERDIN3+ | SERDES Data Bit 3, Positive. | | B8 | SERDIN3- | SERDES Data Bit 3, Negative. | | A9 | SERDIN2+ | SERDES Data Bit 2, Positive. | | B9 | SERDIN2- | SERDES Data Bit 2, Negative. | | A10 | SERDIN1+ | SERDES Data Bit 1, Positive. | | B10 | SERDIN1- | SERDES Data Bit 1, Negative. | | A11 | SERDINO+ | SERDES Data Bit 0, Positive. | | B11 | SERDINO- | SERDES Data Bit 0, Negative. | | Sync Output | 32.12.170 | | | D12 | SYNCOUT0+ | Positive Sync (Active Low) Output Signal, Channel Link 0. This pin is LVDS or CMOS selectable. | | D11 | SYNCOUT0- | Negative Sync (Active Low) Output Signal, Channel Link 0. This pin is LVDS or CMOS selectable. | | D1 | SYNCOUT1+ | Positive Sync (Active Low) Output Signal, Channel Link 1. This pin is LVDS or CMOS selectable. | | D2 | SYNCOUT1- | Negative Sync (Active Low) Output Signal, Channel Link 1. This pin is LVDS or CMOS selectable. | | Pin No. | Mnemonic | Description | |--------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Serial Port Interface | | | | E4 | SDO | Serial Port Data Output (CMOS Levels with Respect to DVDD1.8). | | E7 | SDIO | Serial Port Data Input/Output (CMOS Levels with Respect to DVDD1.8). | | E5 | SCLK | Serial Port Clock Input (CMOS Levels with Respect to DVDD1.8). | | E6 | <u>cs</u> | Serial Port Chip Select, Active Low (CMOS Levels with Respect to DVDD1.8). | | E8 | RESET | Reset, Active Low (CMOS Levels with Respect to DVDD1.8). | | Interrupt Request | | | | D9 | ĪRQ0 | Interrupt Request 0. This pin is an open-drain, active low output (CMOS levels with respect to DVDD1.8). Connect a pull-up resistor to DVDD1.8 to prevent this pin from floating when inactive. | | E9 | ĪRQ1 | Interrupt Request 1. This pin is an open-drain, active low output (CMOS levels with respect to DVDD1.8). Connect a pull-up resistor to DVDD1.8 to prevent this pin from floating when inactive. | | CMOS Input/Outputs | | | | D8 | TXEN0 | Transmit Enable for DAC0. The CMOS levels are determined with respect to DVDD1.8. | | D4 | TXEN1 | Transmit Enable for DAC1. The CMOS levels are determined with respect to DVDD1.8. | | DAC Analog Outputs | | | | M9 | DAC0+ | DACO Positive Current Output. | | M8 | DAC0- | DAC0 Negative Current Output. | | M4 | DAC1+ | DAC1 Positive Current Output. | | M5 | DAC1- | DAC1 Negative Current Output. | | Reference | | | | L12 | ISET | Device Bias Current Setting Pin. Connect a 5 k $\Omega$ resistor from this pin to GND, preferably with <0.1% tolerance and <±25 ppm/°C temperature coefficient. | | Do Not Connect | | | | E1, E2, E11, E12, J2, K4 | DNC | Do Not Connect. Do not connect to these pins. | ### TYPICAL PERFORMANCE CHARACTERISTICS Figure 3. Second Harmonic (SFDR) vs. f<sub>OUT</sub> over Digital Scale (Mode 0), 6 GHz DAC Sample Rate, Channel Interpolation 2×, Main Interpolation 8× Figure 4. Third Harmonic (SFDR) vs. f<sub>OUT</sub> over Digital Scale (Mode 0), 6 GHz DAC Sample Rate, Channel Interpolation 2×, Main Interpolation 8× Figure 5. Worst Harmonic (SFDR) vs. f<sub>OUT</sub> over Digital Scale (Mode 0), 6 GHz DAC Sample Rate, Channel Interpolation 2×, Main Interpolation 8× Figure 6. Second Harmonic (SFDR) vs. f<sub>OUT</sub> over Digital Scale (Mode 1), 12 GHz DAC Sample Rate, Channel Interpolation 4×, Main Interpolation 8× Figure 7. Third Harmonic (SFDR) vs. f<sub>OUT</sub> over Digital Scale (Mode 1), 12 GHz DAC Sample Rate, Channel Interpolation 4×, Main Interpolation 8× Figure 8. Worst Spur vs. f<sub>OUT</sub> over f<sub>DAC</sub> (All Modes), 0 dB Digital Scale Figure 9. Second Harmonic (SFDR) vs. $f_{OUT}$ over Digital Scale (Mode 2), 12 GHz DAC Sample Rate, Channel Interpolation 4×, Main Interpolation 8× Figure 10. Third Harmonic (SFDR) vs. $f_{OUT}$ over Digital Scale (Mode 2), 12 GHz DAC Sample Rate, Channel Interpolation 4×, Main Interpolation 8× Figure 11. Worst Harmonic (SFDR) vs. f<sub>OUT</sub> over Digital Scale (Mode 2), 12 GHz DAC Sample Rate, Channel Interpolation 4×, Main Interpolation 8× Figure 12. Second Harmonic (SFDR) vs. f<sub>OUT</sub> over Digital Scale (Mode 12), 4 GHz DAC Sample Rate, Channel Interpolation 1×, Main Interpolation 1×, 12-Bit Resolution Figure 13. Third Harmonic (SFDR) vs. f<sub>OUT</sub> over Digital Scale (Mode 12), 4 GHz DAC Sample Rate, Channel Interpolation 1×, Main Interpolation 1×, 12-Bit Resolution Figure 14. Worst Harmonic (SFDR) vs. f<sub>OUT</sub> over Digital Scale (Mode 12), 4 GHz DAC Sample Rate, Channel Interpolation 1×, Main Interpolation 1×, 12-Bit Resolution Figure 15. Second Harmonic (SFDR) vs. f<sub>OUT</sub> over Digital Scale (Mode 9), 12 GHz DAC Sample Rate, Channel Interpolation 1×, Main Interpolation 8× Figure 16. Third Harmonic (SFDR) vs. $f_{OUT}$ over Digital Scale (Mode 9), 12 GHz DAC Sample Rate, Channel Interpolation 1×, Main Interpolation 8× Figure 17. IMD3 vs. f<sub>OUT</sub> over Digital Scale (Mode 0) 6 GHz DAC Sample Rate, Channel Interpolation 2×, Main Interpolation 8×, 1 MHz Tone Spacing Figure 18. IMD3 vs. f<sub>OUT</sub> over f<sub>DAC</sub> (Mode 0), Channel Interpolation 2×, Main Interpolation 8×, 1 MHz Tone Spacing Figure 19. IMD3 vs. f<sub>OUT</sub> over Digital Scale (Mode 1), 12 GHz DAC Sample Rate, Channel Interpolation 4×, Main Interpolation 8×, 1 MHz Tone Spacing Figure 20. IMD3 vs. f<sub>OUT</sub> over f<sub>DAC</sub> (Mode 1), Channel Interpolation 4×, Main Interpolation 8×, 1 MHz Tone Spacing, –7 dB Digital Scale Figure 21. IMD3 vs. f<sub>OUT</sub> over Digital Scale (Mode 2), 12 GHz DAC Sample Rate, Channel Interpolation 4×, Main Interpolation 8×, 1 MHz Tone Spacing Figure 22. IMD3 vs. $f_{OUT}$ over $f_{DAC}$ (Mode 2), Channel Interpolation 4×, Main Interpolation 8×, 1 MHz Tone Spacing Figure 23. IMD3 vs. f<sub>OUT</sub> over Digital Scale (Mode 12), 4 GHz DAC Sample Rate, Channel Interpolation 1×, Main Interpolation 1×, 1 MHz Tone Spacing, 12-Bit Resolution Figure 24. IMD3 vs. f<sub>OUT</sub> over Digital Scale (Mode 9), 12 GHz DAC Sample Rate, Channel Interpolation 1×, Main Interpolation 8×, 1 MHz Tone Spacing Figure 25. Single-Tone NSD Measured at 70 MHz vs. f<sub>OUT</sub>, 11796.48 MHz f<sub>DAG</sub>, 16-Bit Resolution, Shuffle Off vs. Shuffle On Figure 26. Single-Tone NSD Measured at 70 MHz vs. f<sub>OUT</sub> over f<sub>DAG</sub> 16-Bit Resolution, Shuffle On Figure 27. Single-Tone NSD Measured at 10% Offset from f<sub>OUT</sub> vs. f<sub>OUT</sub> over f<sub>DAG</sub> 16-Bit Resolution, Shuffle On Figure 28. Single-Tone NSD Measured at 70 MHz vs f<sub>OUT</sub>, 11796.48 MHz f<sub>DAC</sub>, 12-Bit Resolution, Shuffle Off vs. Shuffle On Figure 29. Single-Tone NSD Measured at 70 MHz vs. f<sub>OUT</sub> over f<sub>DAC</sub>, 12-Bit Resolution, Shuffle On Figure 30. Single-Tone NSD Measured at 10% Offset from f<sub>OUT</sub> vs. f<sub>OUT</sub> over f<sub>DAG</sub> 12-Bit Resolution, Shuffle On Figure 31. Single-Sideband (SSB) Phase Noise vs. Offset over $f_{OUT}$ , over PFD Frequency, $f_{DAC} = 12$ GHz, $f_{OUT} = 1.8$ GHz, PLL On, PLL Reference Clock = 500 MHz Figure 32. SSB Phase Noise vs. Frequency Offset over $f_{OUT}$ , $f_{DAC} = 12$ GHz, Direct Clock (PLL Off) Figure 33. DNL, I<sub>OUTFS</sub> = 26 mA, 16-Bit Resolution Figure 34. INL, I<sub>OUTFS</sub> = 26 mA, 16-Bit Resolution Figure 35. DNL, Ioutes = 20 mA, 16-Bit Resolution Figure 36. INL, I<sub>OUTFS</sub> = 20 mA, 16-Bit Resolution Figure 37. DNL, IOUTES = 15.6 mA, 16-Bit Resolution Figure 38. INL, I<sub>OUTFS</sub> = 15.6 mA, 16-Bit Resolution Figure 39. DNL, I<sub>OUTFS</sub> = 20 mA, 12-Bit Resolution Figure 40. INL, IOUTFS = 20 mA, 12-Bit Resolution ### **TERMINOLOGY** #### Integral Nonlinearity (INL) INL is the maximum deviation of the actual analog output from the ideal output, determined by a straight line drawn from zero scale to full scale. #### Differential Nonlinearity (DNL) DNL is the measure of the variation in analog value, normalized to full scale, associated with a 1 LSB change in digital input code. #### Offset Error Offset error is the deviation of the output current from the ideal value of 0 mA. For DACx+, a 0 mA output is expected when all inputs are set to 0. For DACx-, a 0 mA output is expected when all inputs are set to 1. #### **Gain Error** Gain error is the difference between the actual and ideal output span. The actual span is determined by the difference between the output when the input is at its minimum code and the output when the input is at its maximum code. #### **Output Compliance Range** The output compliance range is the range of allowable voltages at the output of a current output DAC. Operation beyond the maximum compliance limits can cause either output stage saturation or breakdown, resulting in nonlinear performance. #### **Temperature Drift** Temperature drift is specified as the maximum change from the ambient (25°C) value to the value at either $T_{\text{MIN}}$ or $T_{\text{MAX}}$ . For offset and gain drift, the drift is reported in ppm of full-scale range (FSR) per degree Celsius. For reference drift, the drift is reported in ppm per degree Celsius. #### **Settling Time** Settling time is the time required for the output to reach and remain within a specified error band around its final value, measured from the start of the output transition. #### Spurious-Free Dynamic Range (SFDR) SFDR is the difference, in decibels, between the peak amplitude of the output signal and the peak spurious signal within the dc to Nyquist frequency of the DAC. Typically, energy in this band is rejected by the interpolation filters. This specification, therefore, defines how well the interpolation filters work and the effect of other parasitic coupling paths on the DAC output. #### Signal-to-Noise Ratio (SNR) SNR is the ratio of the rms value of the measured output signal to the rms sum of all other spectral components below the Nyquist frequency, excluding the first six harmonics and dc. The value for SNR is expressed in decibels. #### **Interpolation Filter** If the digital inputs to the DAC are sampled at a multiple rate of the interpolation rate ( $f_{DATA}$ ), a digital filter can be constructed that has a sharp transition band near $f_{DATA}/2$ . Images that typically appear around the output data rate ( $f_{DAC}$ ) can be greatly suppressed. #### **Channel Datapath** The channel datapath, sometimes referred to as channelizers, are the complex data channel datapaths, before the summing node in the chip, that can be used or bypassed depending on the mode of operation chosen. When these channelizers are in use, complex data input is required. The channel datapaths include independently controlled optional gain stages and channel NCOs per channel. There is also a selectable channel interpolation block that is configurable (same setting for all channel interpolation blocks) depending on the mode of operation chosen. #### Main Datapath The main datapath refers to the portion of the digital datapath after the summing node in the chip, up to each of the main DAC analog cores. Each of these main datapaths includes an optional PA protection block with a feed forward to the ramp up/down gain stage block for muting the DAC outputs before damaging a power amplifier in the transmit path. There is a selectable main interpolation block that is configurable (same setting for both main interpolation blocks) depending on the mode of operation chosen. Each main datapath also contains an individually programmable main NCO per main DAC datapath that can be optionally used depending on the mode of operation. #### Adjacent Channel Leakage Ratio (ACLR) ACLR is the ratio in decibels relative to the carrier (dBc) between the measured power within a channel relative to its adjacent channel. #### Adjusted DAC Update Rate The adjusted DAC update rate is the DAC update rate divided by the smallest interpolating factor. For clarity on DACs with multiple interpolating factors, the adjusted DAC update rate for each interpolating factor may be given. #### Physical (PHY) Lane Physical Lane x refers to SERDINx±. #### **Logical Lane** Logical Lane x refers to physical lanes after optionally being remapped by the crossbar block (Register 0x308 to Register 0x30B). #### Link Lane Link Lane x refers to logical lanes considered per link. When paging Link 0 (Register 0x300[2] = 0), Link Lane x = Logical Lane x. When paging Link 1 (Register 0x300[2] = 1, dual link only), Link Lane x = Logical Lane x + 4. ### THEORY OF OPERATION The AD9172 is a 16-bit, dual RF DAC with a high speed JESD204B SERDES interface, compliant with Subclass 0 and Subclass 1 operation. Figure 1 shows a functional block diagram of the AD9172. Each DAC core has three individually bypassable channelizers that support up to 1.5 GSPS of complex data rate input per channel. Eight high speed serial lanes carry data at a maximum of 15 Gbps to the channel datapaths. The JESD204B interface supports both single-link and dual-link modes of operation, depending on the selected mode configuration. Compared to either LVDS or CMOS interfaces, the SERDES interface simplifies pin count, board layout, and input clock requirements to the device. The clock for the input data is derived from the DAC clock, or device clock (required by the JESD204B specification). This device clock can be sourced with a PLL reference clock used by the on-chip PLL to generate a DAC clock, or a high fidelity, direct external DAC sampling clock. The device can be configured to operate in one-, two-, three-, four-, or eight-lane per link modes, depending on the required input data rate. The digital datapath of the AD9172 offers bypassable (1×) interpolation modes for both the channel datapaths and the main datapaths. Additionally, depending on the selected mode, there are also $2\times$ , $3\times$ , $4\times$ , $6\times$ , and $8\times$ interpolation options for the channel datapaths, and $2\times$ , $4\times$ , $6\times$ , $8\times$ , and $12\times$ interpolation options for the main datapaths. See Table 13 for a summary of the various JESD204B modes available, as well as the respective interpolation options. For each of the channel digital datapaths (when not using $1\times$ interpolation for the channel), there are individually programmable gain stages and NCO blocks available. The NCO blocks have a 48-bit modulus NCO option to enable digital frequency shifts of signals with near infinite precision. The NCO can operate alone in NCO only mode using a programmable dc value input via the SPI or with digital data from the SERDES interface and digital datapath. At the end of the three channelizer datapaths, there is a summation node that combines the three channel datapaths together at a maximum of 1.5 GSPS to then pass along to each of the main DAC datapaths for further digital feature options. Each of the main DAC datapaths contain an optional power amplifier (PA) protection block, a main datapath interpolation block, a main NCO with an optional modulus feature, and a ramp-up/ramp-down gain block that is fed by the PA protection block. Additionally, there is an optional calibration tone feature, as well as four modulator switch modes that are part of the main NCO block. The AD9172 is capable of multichip synchronization that can both synchronize multiple DACs and establish a constant and deterministic latency (latency locking) path for the DACs. The latency for each of the DACs remains constant to within several DAC clock cycles from link establishment to link establishment. An external alignment signal (SYSREF±) makes the AD9172 JESD204B Subclass 1 compliant. Several modes of SYSREF± signal handling are available for use in the system. An SPI configures the various functional blocks and monitors their statuses. The various functional blocks and the data interface must be set up in a specific sequence for proper operation (see the Start-Up Sequence section). Simple SPI initialization routines set up the JESD204B link and are included in the evaluation board package. This data sheet describes the various blocks of the AD9172 in detail. Descriptions of the JESD204B interface, control parameters, and various registers to set up and monitor the device are provided. The recommended start-up routine reliably sets up the data link. Table 13. JESD204B Supported Operating Modes and Interpolation Combinations | | JESD20 | 4B Operation | Modes | | C Datapath | | | | | |-------------------------------------------------------------|-----------------|--------------|---------------------------|---------------------------------|-----------------------------------------|--------------|------------------------|--------------|--| | Application | | | Channel<br>Interpolations | Main Datapath<br>Interpolations | Maximum DAC<br>Rate (GSPS) <sup>2</sup> | | | | | | Single-Channel,<br>375 MHz (N =<br>16 Bits) | Single,<br>dual | 0 | 1 | 1 | 385 | 2×<br>4×, 6× | 8×<br>6×, 8× | 6.16<br>12.6 | | | Dual-Channel,<br>375 MHz (N =<br>16 Bits) | Single,<br>dual | 1 | 2 | 2 | 385 | 4×, 6× | 6×, 8× | 12.6 | | | Triple-Channel,<br>375 MHz (N =<br>16 Bits) | Single,<br>dual | 2 | 3 | 3 | 385 4×, 6× | | 6×, 8× | 12.6 | | | Single Channel,<br>500 MHz (N = 12<br>Bits, NP = 12 Bits) | Single,<br>dual | 5 | 1 | 1 | 513 | 2×<br>3× | 6×<br>6×, 8× | 6.16<br>12.6 | | | Dual Channel, 500 MHz<br>(N = 12 Bits, NP =<br>12 Bits) | Single,<br>dual | 6 | 2 | 2 | 513 3x | | 6×, 8× | 12.6 | | | Single Channel,<br>750 MHz (N =<br>16 Bits) | Single,<br>dual | 3 | 2 | 1 | 770 | 1×<br>2×, 3× | 8×<br>6×, 8× | 6.16<br>12.6 | | | Dual Channel, 750 MHz<br>(N = 16 Bits) | Single,<br>dual | 4 | 4 | 2 | 770<br>385 | 2×, 3×<br>4× | 6×, 8×<br>8× | 12.6<br>12.6 | | | Dual Channel, 187 MHz<br>(N = 16 Bits) | Single,<br>dual | 7 | 1 | 2 | 192.5 | 8× | 6×, 8× | 12.6 | | | Single Channel,<br>1500 MHz, Dual Tx<br>Cable (N = 16 Bits) | Single,<br>dual | 8, 9 | 4 | 1 | 1540 | 1× | 2×, 4×, 6×, 8×,<br>12× | 12.6 | | | Wideband, 3 GHz<br>(N = 16 Bits, NP =<br>16 Bits) | Single | 10, 11 | 8 | 1 | 3080 | 1× | 1× | 3.08 | | | Wideband, 4 GHz<br>(N = 12 Bits, NP =<br>12 Bits) | Single | 12 | 8 | 1 | 4100 | 1× | 1× | 4.1 | | | 3 GHz, Real DAC (N = 16 Bits, NP = 16 Bits) | Single,<br>dual | 18, 19 | 4 | 1 | 3080 | 1x | 1× | 3.08 | | | 6 GHz, Real DAC (N = 16 Bits, NP = 16 Bits) | Single | 20, 21 | 8 | 1 | 6160 | 1× | 1× | 6.16 | | <sup>&</sup>lt;sup>1</sup> The maximum data rate is calculated based on a maximum lane rate as listed in Table 7. The data rate is calculated based on the formula lane rate = $(10/8) \times NP \times data$ rate × (M/L), where the NP, M, and L values depend on the selected mode. The maximum DAC rate per mode depends on the voltage tolerance as well as the lane rate for a given configuration, as listed in Table 3. The maximum possible lane rate is according to Table 7. ### **SERIAL PORT OPERATION** The serial port is a flexible, synchronous serial communications port that allows easy interfacing with many industry-standard microcontrollers and microprocessors. The serial input/output is compatible with most synchronous transfer formats, including both the Motorola, Inc., SPI and Intel® SSR protocols. The interface allows read and write access to all registers that configure the AD9172. MSB first or LSB first transfer formats are supported. The serial port interface can be configured as a 4-wire interface or a 3-wire interface in which the input and output share a single pin input/output (SDIO). Figure 41. Serial Port Interface Pins (144-Ball BGA\_ED) There are two phases to a communication cycle with the AD9172. Phase 1 is the instruction cycle (the writing of an instruction byte into the device), coincident with the first 16 SCLK rising edges. The instruction word provides the serial port controller with information regarding the data transfer cycle, Phase 2 of the communication cycle. The Phase 1 instruction word defines whether the upcoming data transfer is a read or write, along with the starting register address for the following data transfer. A logic high on the $\overline{\text{CS}}$ pin followed by a logic low resets the serial port timing to the initial state of the instruction cycle. From this state, the next 16 rising SCLK edges represent the instruction bits of the current input/output operation. The remaining SCLK edges are for Phase 2 of the communication cycle. Phase 2 is the actual data transfer between the device and the system controller. Phase 2 of the communication cycle is a transfer of one or more data bytes. Eight $\times$ N SCLK cycles are required to transfer N bytes during the transfer cycle. Registers change immediately upon writing to the last bit of each transfer byte, except for the FTW and NCO phase offsets, which change only when the frequency tuning word load request bit (DDSM\_FTW\_LOAD\_REQ) or DDSC\_FTW\_LOAD\_REQ) is set. #### **DATA FORMAT** The instruction byte contains the information shown in Table 14. **Table 14. Serial Port Instruction Word** | I15 (MSB) | I[14:0] | |-----------|---------| | R/W | A[14:0] | $R/\overline{W}$ , Bit 15 of the instruction word, determines whether a read or a write data transfer occurs after the instruction word write. Logic 1 indicates a read operation, and Logic 0 indicates a write operation. A14 to A0, Bit I14 to Bit I0 of the instruction word, determine the register that is accessed during the data transfer portion of the communication cycle. For multibyte transfers, A[14:0] is the starting address. The remaining register addresses are generated by the device based on the address increment bit. If the address increment bits are set high (Register 0x000, Bit 5 and Bit 2), multibyte SPI writes start on A[14:0] and increment by 1 every eight bits sent/received. If the address increment bits are set to 0, the address decrements by 1 every eight bits. #### **SERIAL PORT PIN DESCRIPTIONS** #### Serial Clock (SCLK) The serial clock pin synchronizes data to and from the device and runs the internal state machines. The maximum frequency of SCLK is 80 MHz. All data input is registered on the rising edge of SCLK. All data is driven out on the falling edge of SCLK. ### Chip Select (CS) $\overline{\text{CS}}$ allows more than one device to be used on the same serial communications lines. The SDIO pin goes to a high impedance state when this input is high. During the communication cycle, the chip select must stay low. #### Serial Data Input/Output (SDIO) This pin is a bidirectional data line. In 4-wire mode, this pin acts as the data input and SDO acts as the data output. #### **SERIAL PORT OPTIONS** The serial port can support both MSB first and LSB first data formats. This functionality is controlled by the LSB first bit (Register 0x000, Bit 6 and Bit 1). The default is MSB first (LSBFIRST bit = 0). When the LSB first bits = 0 (MSB first), the instruction and data bits must be written from MSB to LSB. R/ $\overline{W}$ is followed by A[14:0] as the instruction word, and D[7:0] is the data-word. When the LSB first bits = 1 (LSB first), the opposite is true. A[0:14] is followed by R/ $\overline{W}$ , which is subsequently followed by D[0:7]. The serial port supports a 3-wire or 4-wire interface. When the SDO active bits = 1 (Register 0x000, Bit 4 and Bit 3), a 4-wire interface with a separate input pin (SDIO) and output pin (SDO) is used. When the SDO active bits = 0, the SDO pin is unused and the SDIO pin is used for both the input and the output. Multibyte data transfers can be performed as well by holding the $\overline{\text{CS}}$ pin low for multiple data transfer cycles (eight SCLKs) after the first data transfer word following the instruction cycle. The first eight SCLKs following the instruction cycle read from or write to the register provided in the instruction cycle. For each additional eight SCLK cycles, the address is either incremented or decremented and the read/write occurs on the new register. The direction of the address can be set using ADDRINC or ADDRINC\_M (Register 0x000, Bit 5 and Bit 2). When ADDRINC or ADDRINC\_M is 1, the multicycle addresses are incremented. When ADDRINC or ADDRINC\_M is 0, the addresses are decremented. A new write cycle can always be initiated by bringing $\overline{\text{CS}}$ high and then low again. To prevent confusion and to ensure consistency between devices, the chip tests the first nibble following the address phase, ignoring the second nibble. This test is completed independently from the LSB first bits and ensures that there are extra clock cycles following the soft reset bits (Register 0x000, Bit 0 and Bit 7). This test of the first nibble only applies when writing to Register 0x000. Figure 43. Serial Register Interface Timing, LSB First, Register 0x000, Bit 6 and Bit 1 = 1 Figure 44. Timing Diagram for Serial Port Register Read Figure 45. Timing Diagram for Serial Port Register Write # JESD204B SERIAL DATA INTERFACE JESD204B OVERVIEW The AD9172 has eight JESD204B data ports that receive data. The eight JESD204B ports can be configured as part of a single or dual JESD204B link that uses a single system reference (SYSREF±) and device clock (CLKIN±). The JESD204B serial interface hardware consists of three layers: the physical layer, the data link layer, and the transport layer. These sections of the hardware are described in subsequent sections, including information for configuring every aspect of the interface. Figure 46 shows the communication layers implemented in the AD9172 serial data interface to recover the clock and deserialize, descramble, and deframe the data before it is sent to each of the digital signal processing channelizers of the device. The physical layer establishes a reliable channel between the transmitter (Tx) and the receiver (Rx), and the data link layer is responsible for unpacking the data into octets and descrambling the data. The transport layer receives the descrambled JESD204B frames and converts them to DAC samples. A number of JESD204B parameters (L, F, K, M, N, NP, S, HD) define how the data is packed and tell the device how to turn the serial data into samples. These parameters are defined in detail in the Transport Layer section. The AD9172 also has a descrambling option (see the Descrambler section for more information). The AD9172 has the ability to use 12-bit packing mode (NP = 12, N = 11 or 12) to increase the maximum data rate achievable by this device for applications that do not require 16-bit resolution capabilities. The AD9172 has multiple single-link and dual-link mode options available for various application purposes. These modes and their respective JESD204B link parameters are described in Table 15 and Table 16. There are different interpolation combinations available for the channel and main datapaths, as well as whether single-link and dual-link options are available depending on which JESD204B mode is chosen. Table 13 lists the possible link and interpolation combinations available. The AD9172 has two DAC outputs; however, for the purposes of complex signal processing on chip, the converter count, represented by the M JESD204B parameter, reflects the number of complex subchannels of data required per link when using a total interpolation greater than 1×. The number of complex subchannels of data per link required to be sent to the device also depends on the number of channelizers being used, based on the mode of operation chosen. If the channelizer datapaths are bypassed (channel interpolation is set to 1×) and the main datapath interpolation is set to 1×, the converter count (M) reflects the number of real converters per link being used in the mode of operation; in this case, complex data is not required. For a particular JESD204B mode of operation, the following relationships exist: $Total\ Interpolation = Channel\ Interpolation \times \\ Main\ Interpolation$ Data Rate = DAC Rate/Total Interpolation Lane Rate = $(M/L) \times NP \times (10/8) \times Data$ Rate #### where: *Lane Rate* must be between 3 Gbps and 15 Gbps. *M*, *L*, and *NP* are JESD204B link parameters for the chosen JESD204B operating mode. Achieving and recovering synchronization of the lanes is important. To simplify the interface to the transmitter, the AD9172 designates a master synchronization signal for each JESD204B link. The SYNCOUT0± and SYNCOUT1± pins are used as the master signal for all lanes on each link. If any lane in a link loses synchronization, a resynchronization request is sent to the transmitter via the synchronization signal of the link. The transmitter stops sending data and instead sends synchronization characters to all lanes in that link until resynchronization is achieved. Figure 46. Functional Block Diagram of Serial Link Receiver Table 15. Single-Link JESD204B Operating Modes | | Single-Link JESD204B Modes | | | | | | | | | | | | | | | | | |--------------------------------------|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----| | Parameter | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 18 | 19 | 20 | 21 | | L (Lane Count) | 1 | 2 | 3 | 2 | 4 | 1 | 2 | 1 | 4 | 4 | 8 | 8 | 8 | 4 | 4 | 8 | 8 | | M (Converter Count) | 2 | 4 | 6 | 2 | 4 | 2 | 4 | 4 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | | F (Octets per Frame per Lane) | 4 | 4 | 4 | 2 | 2 | 3 | 3 | 8 | 1 | 2 | 1 | 2 | 3 | 1 | 2 | 1 | 2 | | S (Samples per Converter per Frame) | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 2 | 2 | 4 | 8 | 2 | 4 | 4 | 8 | | NP (Total Number of Bits per Sample) | 16 | 16 | 16 | 16 | 16 | 12 | 12 | 16 | 16 | 16 | 16 | 16 | 12 | 16 | 16 | 16 | 16 | | N (Converter Resolution) | 16 | 16 | 16 | 16 | 16 | 12 | 12 | 16 | 16 | 16 | 16 | 16 | 12 | 16 | 16 | 16 | 16 | | K (Frames per Multiframe) | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | | HD (High Density User Data Format) | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Table 16. Dual-Link JESD204B Operating Modes | | Dual-Link JESD204B Modes | | | | | | | | | | | | |--------------------------------------|--------------------------|----|----|----|----|----|----|----|----|----|----|----| | Parameter | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 18 | 19 | | L (Lane Count) | 1 | 2 | 3 | 2 | 4 | 1 | 2 | 1 | 4 | 4 | 4 | 4 | | M (Converter Count) | 2 | 4 | 6 | 2 | 4 | 2 | 4 | 4 | 2 | 2 | 1 | 1 | | F (Octets per Frame per Lane) | 4 | 4 | 4 | 2 | 2 | 3 | 3 | 8 | 1 | 2 | 1 | 2 | | S (Samples per Converter per Frame) | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 2 | 2 | 4 | | NP (Total Number of Bits per Sample) | 16 | 16 | 16 | 16 | 16 | 12 | 12 | 16 | 16 | 16 | 16 | 16 | | N (Converter Resolution) | 16 | 16 | 16 | 16 | 16 | 12 | 12 | 16 | 16 | 16 | 16 | 16 | | K (Frames per Multiframe) | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | 32 | | HD (High Density User Data Format) | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Table 17. Data Structure per Lane for F = 1 JESD204B Operating Modes<sup>1</sup> | JESD204B Mode and Parameters | Link Logical Lane | Frame 0, Octet 0 | Frame 1, Octet 0 | |------------------------------------------------|-------------------|------------------|------------------| | L = 4, M = 4, S = 1, NP = 16, N = 16 | Lane 0 | M0S0[15:8] | M0S1[15:8] | | Mode 8: N = 16 | Lane 1 | M0S0[7:0] | M0S1[7:0] | | Mode 13: $N = 11^2$ | Lane 2 | M1S0[15:8] | M1S1[15:8] | | | Lane 3 | M1S0[7:0] | M1S1[7:0] | | Mode 10 (L = 8, M = 2, S = 2, NP = 16, N = 16) | Lane 0 | M0S0[15:8] | M0S2[15:8] | | | Lane 1 | M0S0[7:0] | M0S2[7:0] | | | Lane 2 | M0S1[15:8] | M0S3[15:8] | | | Lane 3 | M0S1[7:0] | M0S3[7:0] | | | Lane 4 | M1S0[15:8] | M1S2[15:8] | | | Lane 5 | M1S0[7:0] | M1S2[7:0] | | | Lane 6 | M1S1[15:8] | M1S3[15:8] | | | Lane 7 | M1S1[7:0] | M1S3[7:0] | | Mode 18 (L = 4, M = 1, S = 2, NP = 16, N = 16) | Lane 0 | M0S0[15:8] | M0S2[15:8] | | | Lane 1 | M0S0[7:0] | M0S2[7:0] | | | Lane 2 | M0S1[15:8] | M0S3[15:8] | | | Lane 3 | M0S1[7:0] | M0S3[7:0] | | Mode 20 (L = 8, M = 1, S = 4, NP = 16, N = 16) | Lane 0 | M0S0[15:8] | M0S4[15:8] | | | Lane 1 | M0S0[7:0] | M0S4[7:0] | | | Lane 2 | M0S1[15:8] | M0S5[15:8] | | | Lane 3 | M0S1[7:0] | M0S5[7:0] | | | Lane 4 | M0S2[15:8] | M0S6[15:8] | | | Lane 5 | M0S2[7:0] | M0S6[7:0] | | | Lane 6 | M0S3[15:8] | M0S7[15:8] | | | Lane 7 | M0S3[7:0] | M0S7[7:0] | $<sup>^1</sup>$ Mx is the converter number and Sy is the sample number. For example, M0S0 means Converter 0, Sample 0. $^2$ Generate 11 bit resolution data and set Bits[4:0] to 0 for the full 16-bit data packing (NP). Table 18. Data Structure per Lane for F = 2 JESD204B Operating Modes<sup>1</sup> | | | Frame 0 | | Fran | ne 1 | |------------------------------------------------|-------------------|------------|-----------|-------------|------------| | JESD204B Mode and Parameters | Link Logical Lane | Octet 0 | Octet 1 | Octet 0 | Octet 2 | | Mode 3 (L = 2, M = 2, S = 1, NP = 16, N = 16) | Lane 0 | M0S0[15:8] | M0S0[7:0] | M0S1[15:8] | M0S1[7:0] | | | Lane 1 | M1S0[15:8] | M1S0[7:0] | M1S1[15:8] | M1S1[7:0] | | Mode 4 (L = 4, M = 4, S = 1, NP = 16, N = 16) | Lane 0 | M0S0[15:8] | M0S0[7:0] | M0S1[15:8] | M0S1[7:0] | | | Lane 1 | M1S0[15:8] | M1S0[7:0] | M1S1[15:8] | M1S1[7:0] | | | Lane 2 | M2S0[15:8] | M2S0[7:0] | M2S1[15:8] | M2S1[7:0] | | | Lane 3 | M3S0[15:8] | M3S0[7:0] | M3S1[15:8] | M3S1[7:0] | | Mode 9 (L = 4, M = 2, S = 2, NP = 16, N = 16) | Lane 0 | M0S0[15:8] | M0S0[7:0] | M0S2[15:8] | M0S2[7:0] | | | Lane 1 | M0S1[15:8] | M0S1[7:0] | M0S3[15:8] | M0S3[7:0] | | | Lane 2 | M1S0[15:8] | M1S0[7:0] | M1S2[15:8] | M1S2[7:0] | | | Lane 3 | M1S1[15:8] | M1S1[7:0] | M1S3[15:8] | M1S3[7:0] | | Mode 11 (L = 8, M = 2, S = 4, NP = 16, N = 16) | Lane 0 | M0S0[15:8] | M0S0[7:0] | M0S4[15:8] | M0S4[7:0] | | | Lane 1 | M0S1[15:8] | M0S1[7:0] | M0S5[15:8] | M0S5[7:0] | | | Lane 2 | M0S2[15:8] | M0S2[7:0] | M0S6[15:8] | M0S6[7:0] | | | Lane 3 | M0S3[15:8] | M0S3[7:0] | M0S7[15:8] | M0S7[7:0] | | | Lane 4 | M1S0[15:8] | M1S0[7:0] | M1S4[15:8] | M1S4[7:0] | | | Lane 5 | M1S1[15:8] | M1S1[7:0] | M1S5[15:8] | M1S5[7:0] | | | Lane 6 | M1S2[15:8] | M1S2[7:0] | M1S6[15:8] | M1S6[7:0] | | | Lane 7 | M1S3[15:8] | M1S3[7:0] | M1S7[15:8] | M1S7[7:0] | | Mode 19 (L = 4, M = 1, S = 4, NP = 16, N = 16) | Lane 0 | M0S0[15:8] | M0S0[7:0] | M0S4[15:8] | M0S4[7:0] | | | Lane 1 | M0S1[15:8] | M0S1[7:0] | M0S5[15:8] | M0S5[7:0] | | | Lane 2 | M0S2[15:8] | M0S2[7:0] | M0S6[15:8] | M0S6[7:0] | | | Lane 3 | M0S3[15:8] | M0S3[7:0] | M0S7[15:8] | M0S7[7:0] | | Mode 21 (L = 8, M = 1, S = 8, NP = 16, N = 16) | Lane 0 | M0S0[15:8] | M0S0[7:0] | M0S8[15:8] | M0S8[7:0] | | | Lane 1 | M0S1[15:8] | M0S1[7:0] | M0S9[15:8] | M0S9[7:0] | | | Lane 2 | M0S2[15:8] | M0S2[7:0] | M0S10[15:8] | M0S10[7:0] | | | Lane 3 | M0S3[15:8] | M0S3[7:0] | M0S11[15:8] | M0S11[7:0] | | | Lane 4 | M0S4[15:8] | M0S4[7:0] | M0S12[15:8] | M0S12[7:0] | | | Lane 5 | M0S5[15:8] | M0S5[7:0] | M0S13[15:8] | M0S13[7:0] | | | Lane 6 | M0S6[15:8] | M0S6[7:0] | M0S14[15:8] | M0S14[7:0] | | | Lane 7 | M0S7[15:8] | M0S7[7:0] | M0S15[15:8] | M0S15[7:0] | <sup>&</sup>lt;sup>1</sup> Mx is the converter number and Sy is the sample number. For example, M0S0 means Converter 0, Sample 0. Table 19. Data Structure per Lane for F = 3 JESD204B Operating Modes<sup>1</sup> | | Link | Frame 0 | | | | | | | | | |--------------------------------------------------|---------|------------|-----------|-----------|------------|-----------|-----------|--|--|--| | | Logical | Octe | et O | Oc | tet 1 | Octet 2 | | | | | | JESD204B Mode and Parameters | Lane | Nibble 0 | Nibble1 | Nibble 0 | Nibble1 | Nibble 0 | Nibble1 | | | | | Mode 5 (L = 1, M = 2, S = 1, NP = 12,<br>N = 12) | Lane 0 | M0S0[11:8] | M0S0[7:4] | M0S0[3:0] | M1S0[11:8] | M1S0[7:4] | M1S0[3:0] | | | | | Mode 6 (L = 2, M = 4, S = 1, NP = 12,<br>N = 12) | Lane 0 | M0S0[11:8] | M0S0[7:4] | M0S0[3:0] | M1S0[11:8] | M1S0[7:4] | M1S0[3:0] | | | | | | Lane 1 | M2S0[11:8] | M2S0[7:4] | M2S0[3:0] | M3S0[11:8] | M3S0[7:4] | M3S0[3:0] | | | | | Mode 12 (L = 8, M = 2, S = 8, NP = 12, | Lane 0 | M0S0[11:8] | M0S0[7:4] | M0S0[3:0] | M0S1[11:8] | M0S1[7:4] | M0S1[3:0] | | | | | N = 12) | Lane 1 | M0S2[11:8] | M0S2[7:4] | M0S2[3:0] | M0S3[11:8] | M0S3[7:4] | M0S3[3:0] | | | | | | Lane 2 | M0S4[11:8] | M0S4[7:4] | M0S4[3:0] | M0S5[11:8] | M0S5[7:4] | M0S5[3:0] | | | | | | Lane 3 | M0S6[11:8] | M0S6[7:4] | M0S6[3:0] | M0S7[11:8] | M0S7[7:4] | M0S7[3:0] | | | | | | Lane 4 | M1S0[11:8] | M1S0[7:4] | M1S0[3:0] | M1S1[11:8] | M1S1[7:4] | M1S1[3:0] | | | | | | Lane 5 | M1S2[11:8] | M1S2[7:4] | M1S2[3:0] | M1S3[11:8] | M1S3[7:4] | M1S3[3:0] | | | | | | Lane 6 | M1S4[11:8] | M1S4[7:4] | M1S4[3:0] | M1S5[11:8] | M1S5[7:4] | M1S5[3:0] | | | | | | Lane 7 | M1S6[11:8] | M1S6[7:4] | M1S6[3:0] | M1S7[11:8] | M1S7[7:4] | M1S7[3:0] | | | | <sup>&</sup>lt;sup>1</sup> Mx is the converter number and Sy is the sample number. For example, M0S0 means Converter 0, Sample 0. Table 20. Data Structure per Lane for F = 4 JESD204B Operating Modes<sup>1</sup> | JESD204B Mode and | Link Logical | | ne 0 | | Frame 1 | | | | | |--------------------------------------------------|--------------|------------|-----------|------------|-----------|------------|-----------|------------|-----------| | Parameters | Lane | Octet 0 | Octet 1 | Octet 2 | Octet 3 | Octet 0 | Octet 1 | Octet 2 | Octet 3 | | Mode 0 (L = 1, M = 2, S = 1,<br>NP = 16, N = 16) | Lane 0 | M0S0[15:8] | M0S0[7:0] | M1S0[15:8] | M1S0[7:0] | M0S1[15:8] | M0S1[7:0] | M1S1[15:8] | M1S1[7:0] | | Mode 1 (L = 2, M = 4, S = 1, | Lane 0 | M0S0[15:8] | M0S0[7:0] | M1S0[15:8] | M1S0[7:0] | M0S1[15:8] | M0S1[7:0] | M1S1[15:8] | M1S1[7:0] | | NP = 16, N = 16 | Lane 1 | M2S0[15:8] | M2S0[7:0] | M3S0[15:8] | M3S0[7:0] | M2S1[15:8] | M2S1[7:0] | M3S1[15:8] | M3S1[7:0] | | Mode 2 (L = 3, M = 6, S = 1, | Lane 0 | M0S0[15:8] | M0S0[7:0] | M1S0[15:8] | M1S0[7:0] | M0S1[15:8] | M0S1[7:0] | M1S1[15:8] | M1S1[7:0] | | NP = 16, N = 16 | Lane 1 | M2S0[15:8] | M2S0[7:0] | M3S0[15:8] | M3S0[7:0] | M2S1[15:8] | M2S1[7:0] | M3S1[15:8] | M3S1[7:0] | | | Lane 2 | M4S0[15:8] | M4S0[7:0] | M5S0[15:8] | M5S0[7:0] | M4S1[15:8] | M4S1[7:0] | M5S1[15:8] | M5S1[7:0] | <sup>&</sup>lt;sup>1</sup> Mx is the converter number and Sy is the sample number. For example, MOSO means Converter 0, Sample 0. Table 21. Data Structure per Lane for F = 8 JESD204B Operating Modes<sup>1</sup> | JESD204B Mode and | Link Logical | | | | | | | | | |--------------------------------------------------|--------------|------------|-----------|------------|-----------|------------|-----------|------------|-----------| | Parameters | Lane | Octet 0 | Octet 1 | Octet 2 | Octet 3 | Octet 4 | Octet 5 | Octet 6 | Octet 7 | | Mode 7 (L = 1, M = 4, S = 1,<br>NP = 16, N = 16) | Lane 0 | M0S0[15:8] | M0S0[7:0] | M1S0[15:8] | M1S0[7:0] | M2S0[15:8] | M2S0[7:0] | M3S0[15:8] | M3S0[7:0] | <sup>&</sup>lt;sup>1</sup> Mx is the converter number and Sy is the sample number. For example, M0S0 means Converter 0, Sample 0. #### PHYSICAL LAYER The physical layer of the JESD204B interface, hereafter referred to as the deserializer, has eight identical channels. Each channel consists of the termination, an equalizer, a clock and data recovery (CDR) circuit, and the 1:40 demux function (see Figure 47). Figure 47. Deserializer Block Diagram JESD204B data is input to the AD9172 via the SERDINx± differential input pins, per the JESD204B specification. #### **Interface Power-Up and Input Termination** Before using the JESD204B interface, it must be powered up by setting Register 0x200, Bit 0 = 0. In addition, each physical lane (PHY) that is not being used (SERDINx±) must be powered down. To do so, set the corresponding Bit x for Physical Lane x in Register 0x201 to 0 if the physical lane is being used, and to 1 if it is not being used. The AD9172 autocalibrates the input termination to 50 $\Omega$ . This calibration routine is performed automatically when the JESD204B interface blocks are configured and does not require any additional SPI register writes. #### Receiver Eye Mask The AD9172 is compatible with the JESD204B specification regarding the receiver eye mask and is capable of capturing data that complies with the mask in Figure 48. Figure 48 shows the receiver eye normalized to the data rate interval. The AD9172 also supports an increased insertion loss limit, as defined in the Equalization section. Figure 48. Receiver Eye Mask #### **Clock Relationships** The following clocks rates are used throughout the rest of the JESD204B section. The relationship between any of the clocks can be derived from the following equations: Data Rate = DAC Rate/Total Interpolation Lane Rate = $(M/L) \times NP \times (10/8) \times Data$ Rate Byte Rate = Lane Rate/10 This relationship comes from 8-bit/10-bit encoding, where each byte is represented by 10 bits. PCLK Rate = Byte Rate/4 The processing clock is used for a quad-byte decoder. Frame Rate = Byte Rate/F where *F* is defined as octets per frame per lane. PCLK Factor = Frame Rate/PCLK Rate = 4/F #### where: M is the JESD204B parameter for converters per link. L is the JESD204B parameter for lanes per link. F is the JESD204B parameter for octets per frame per lane. NP is the JESD204B parameter for the total number of bits per sample. #### **SERDES PLL** #### **Functional Overview of the SERDES PLL** The independent SERDES PLL uses integer N techniques to achieve clock synthesis. The entire SERDES PLL is integrated on chip, including the VCO and the loop filter. The SERDES PLL is capable of providing quadrature clocks to allow a wide range of data rates (3 Gbps to 15 Gbps) with no gaps. These clocks are the input to the CDR block that is described in the Clock and Data Recovery section. The reference clock to the SERDES PLL is always running at a frequency, $f_{REF}$ , that is equal to 1/40 of the lane rate (PCLK rate). For more information about the SERDES circuitry setup and relevant register writes, see the Start-Up Sequence section. The SERDES PLL block automatically tunes to the appropriate divider range for the lane rate based on the SERDES mode being used. It takes the DAC clock generated by either the DAC PLL, if in use, or from the direct clock being sourced at the CLKIN $\pm$ pins, divides the DAC clock frequency by 4, and uses the JESD204B parameters corresponding to the mode and interpolation values programmed in Register 0x110 and Register 0x111 to determine the proper dividers for generating the PCLK frequency (lane rate $\div$ 40), as shown in Figure 49. Confirm that the SERDES PLL is working by reading Register 0x281. If Register 0x281, Bit 0 = 1, the SERDES PLL has locked. Figure 49. SERDES PLL Synthesizer Block Diagram Including VCO Divider Block ## **Clock and Data Recovery** The deserializer is equipped with a CDR circuit. Instead of recovering the clock from the JESD204B serial lanes, the CDR recovers the clocks from the SERDES PLL. The CDR circuit synchronizes the phase used to sample the data on each serial lane independently. This independent phase adjustment per serial interface ensures accurate data sampling and eases the implementation of multiple serial interfaces on a PCB. ## **Power-Down Unused PHYs** Note that any unused physical and enabled lanes consume extra power unnecessarily. Each lane that is not being used (SERDINx±) must be powered off by writing a 1 to the corresponding bit of PHY\_PD (Register 0x201). ## **Equalization** To compensate for signal integrity distortions for each PHY channel due to PCB trace length and impedance, the AD9172 employs an easy to use, low power equalizer on each JESD204B channel. The AD9172 equalizers operating at the maximum lane rate of 15 Gbps can compensate for up to 16 dB of insertion loss. This equalizer performance is shown in Figure 50 for 15 Gbps, near the maximum baud rate for the AD9172. The channel must also meet the insertion loss deviation requirement of the JESD204B specification (less than 1.5 dB from 50 MHz to 0.75 times the baud rate). Figure 50. Insertion Loss Allowed To ensure the AD9172 compensates for the amount of insertion loss in the system, set the equalizer block appropriately. Table 22 shows the settings for the equalizer boost, equalizer gain, and feedback controls, depending on the level of insertion loss in the system. The equalizer boost setting is programmed for each PHY lane (2-bit control for each) being used in Register 0x240 and Register 0x241. Similarly, the equalizer gain settings are programmed for each PHY lane (2-bit control for each) used in Register 0x242 and Register 0x243. The feedback control is programmed per PHY lane (5-bit control for each, one control per register) in Register 0x244 to Register 0x24B. Table 22. Equalizer Register Control Settings per PHY Control | Insertion Loss | ≤11 dB | >11 dB | |-----------------|--------|--------| | Equalizer Boost | 0x02 | 0x03 | | Equalizer Gain | 0x01 | 0x03 | | Feedback | 0x1F | 0x1F | Figure 51 and Figure 52 are provided as points of reference for hardware designers and show the insertion loss for various lengths of well laid out stripline and microstrip transmission lines, respectively. See the Hardware Considerations section for specific layout recommendations for the JESD204B channel. Figure 51. Insertion Loss of 50 $\Omega$ Striplines on FR4 Figure 52. Insertion Loss of 50 $\Omega$ Microstrips on FR4 #### **DATA LINK LAYER** The data link layer of the AD9172 JESD204B interface accepts the descrialized data from the PHYs and deframes and descrambles them so that data octets are presented to the transport layer to be put into DAC samples. The architecture of the data link layer is shown in Figure 53. The data link layer consists of a synchronization FIFO for each lane, a crossbar switch, a deframer, and a descrambler. The AD9172 can operate as a single-link or dual-link high speed JESD204B serial data interface. All eight lanes of the JESD204B interface handle link layer communications such as code group synchronization (CGS), frame alignment, and frame synchronization. The AD9172 decodes 8-bit/10-bit control characters, allowing marking of the start and end of the frame and alignment between serial lanes. Each AD9172 serial interface link can issue a synchronization request by setting its SYNCOUTx± signals low. The synchronization protocol follows Section 4.9 of the JESD204B standard. When a stream of four consecutive /K/ symbols is received, the AD9172 deactivates the synchronization request by setting the SYNCOUTx± signals high at the next internal LMFC rising edge. Then, the AD9172 waits for the transmitter to issue an initial lane alignment sequence (ILAS). During the ILAS, all lanes are aligned using the /A/ to /R/ character transition as described in the JESD 204B Serial Link Establishment section. Elastic buffers hold early arriving lane data until the alignment character of the latest lane arrives. At this point, the buffers for all lanes are released and all lanes are aligned (see Figure 54). Figure 54. Lane Alignment During ILAS #### JESD204B Serial Link Establishment A brief summary of the high speed serial link establishment process for Subclass 1 is provided. See Section 5.3.3 of the JESD204B specification document for complete details. ## Step 1—Code Group Synchronization Each receiver must locate /K/ (K28.5) characters in its input data stream. After four consecutive /K/ characters are detected on all link lanes, the receiver block deasserts the SYNCOUTx± signals to the transmitter block at the receiver LMFC edge. The transmitter captures the change in the SYNCOUTx± signals and at a future transmitter LMFC rising edge, starts the ILAS. ## Step 2—Initial Lane Alignment Sequence The main purposes of this phase are to align all the lanes of the link and to verify the parameters of the link. Before the link is established, write each of the link parameters to the receiver device to designate how data is sent to the receiver block. The ILAS consists of four or more multiframes. The last character of each multiframe is a multiframe alignment character, /A/. The first, third, and fourth multiframes are populated with predetermined data values. Note that Section 8.2 of the JESD204B specifications document describes the data ramp that is expected during the ILAS. The deframer uses the final /A/ of each lane to align the ends of the multiframes within the receiver. The second multiframe contains an /R/ (K.28.0), /Q/ (K.28.4), and then data corresponding to the link parameters. Additional multiframes can be added to the ILAS if needed by the receiver. By default, the AD9172 uses four multiframes in the ILAS (this can be changed in Register 0x478). If using Subclass 1, exactly four multiframes must be used. After the last /A/ character of the last ILAS, multiframe data begins streaming. The receiver adjusts the position of the /A/ character such that it aligns with the internal LMFC of the receiver at this point. ## Step 3—Data Streaming In this phase, data is streamed from the transmitter block to the receiver block. Optionally, data can be scrambled. Scrambling does not start until the first octet following the ILAS. The receiver block processes and monitors the data it receives for errors, including the following: - Bad running disparity (8-bit/10-bit error) - Not in table (8-bit/10-bit error) - Unexpected control character - Bad ILAS - Interlane skew error (through character replacement) If any of these errors exist, they are reported back to the transmitter in one of the following ways (see the JESD204B Error Monitoring section for details): - SYNCOUTx± signal assertion: resynchronization (SYNCOUTx± signals pulled low) is requested at each error for the last two errors. For the first three errors, an optional resynchronization request can be asserted when the error counter reaches a set error threshold. - For the first three errors, each multiframe with an error in it causes a small pulse on the respective SYNCOUTx± pins. - Errors can optionally trigger an interrupt request (IRQ) event, which can be sent to the transmitter. For more information about the various test modes for verifying the link integrity, see the JESD204B Test Modes section. #### Lane First In/First Out (FIFO) The FIFOs in front of the crossbar switch and deframer synchronize the samples sent on the high speed serial data interface with the deframer clock by adjusting the phase of the incoming data. The FIFO absorbs timing variations between the data source and the deframer; this allows up to two PCLK cycles of drift from the transmitter. The FIFO\_STATUS\_REG\_0 register and FIFO\_STATUS\_REG\_1 register (Register 0x30C and Register 0x30D, respectively) can be monitored to identify whether the FIFOs are full or empty. ## Lane FIFO IRQ An aggregate lane FIFO error bit is also available as an IRQ event. Use Register 0x020, Bit 2 to enable the lane FIFO error bit, and then use Register 0x024, Bit 2 to read back its status and reset the IRQ signal. See the Interrupt Request Operation section for more information. #### **Crossbar Switch** Register 0x308 to Register 0x30B allow arbitrary mapping of physical lanes (SERDINx±) to logical lanes used by the SERDES deframers. **Table 23. Crossbar Registers** | 1 10 10 20 10 00 00 10 10 10 10 10 10 10 10 10 10 | | | | | | | | |---------------------------------------------------|-------|--------------|--|--|--|--|--| | Address | Bits | Logical Lane | | | | | | | 0x308 | [2:0] | SRC_LANE0 | | | | | | | 0x308 | [5:3] | SRC_LANE1 | | | | | | | 0x309 | [2:0] | SRC_LANE2 | | | | | | | 0x309 | [5:3] | SRC_LANE3 | | | | | | | 0x30A | [2:0] | SRC_LANE4 | | | | | | | 0x30A | [5:3] | SRC_LANE5 | | | | | | | 0x30B | [2:0] | SRC_LANE6 | | | | | | | 0x30B | [5:3] | SRC_LANE7 | | | | | | Write each SRC\_LANEy with the number (x) of the desired physical lane (SERDINx±) from which to obtain data. By default, all logical lanes use the corresponding physical lane as their data source. For example, by default, SRC\_LANE0 = 0; therefore, Logical Lane 0 obtains data from Physical Lane 0 (SERDIN0 $\pm$ ). To use SERDIN4 $\pm$ as the source for Logical Lane 0 instead, the user must write SRC LANE0 = 4. #### **Lane Inversion** Register 0x334 allows inversion of desired logical lanes, which can be used to ease routing of the SERDINx± signals. For each Logical Lane x, set Bit x of Register 0x334 to 1 to invert it. #### Deframer The AD9172 consists of two quad-byte deframers (QBDs) paged by the LINK\_PAGE control in Register 0x300, Bit 2. The deframer accepts the 8-bit/10-bit encoded data from the deserializer (via the crossbar switch), decodes it, and descrambles it into JESD204B frames before passing it to the transport layer to be converted to DAC samples. The deframer processes four symbols (or octets) per processing clock (PCLK) cycle. The deframer uses the JESD204B parameters that the user has programmed into the register map to identify how the data is packed, and unpacks it. The JESD204B parameters are described in detail in the Transport Layer section; many of the parameters are also needed in the transport layer to convert JESD204B frames into samples. #### Descrambler The AD9172 provides an optional descrambler block using a self synchronous descrambler with the following polynomial: $1 + x^{14} + x^{15}$ . Enabling data scrambling reduces spectral peaks that are produced when the same data octets repeat from frame to frame. It also makes the spectrum data independent so that possible frequency selective effects on the electrical interface do not cause data dependent errors. Descrambling of the data is enabled by setting the SCR bit (Register 0x453, Bit 7) to 1. ## **SYNCING LMFC SIGNALS** The AD9172 requires a synchronization (sync) to align the LMFC and other internal clocks before the SERDES links are brought online. The synchronization is a one-shot sync, where the synchronization process begins on the next edge of the alignment signal following the assertion of the SYSREF\_MODE\_ONESHOT control in Register 0x03A, Bit 1. In Subclass 1, the SYSREF± rising edge acts as the alignment edge; in Subclass 0, an internal processing clock acts as the alignment edge. When a sync has completed, the SYNC\_ROTATION\_DONE (Register 0x03A, Bit 4) bit is asserted and remains asserted until another sync is requested. After a synchronization occurs, the JESD204B link can be enabled. In Subclass 1, the latency of the JESD204B system is deterministic and allows synchronization across multiple devices, if desired. #### SYSREF± Signal The SYSREF± signal is a differential source synchronous input that synchronizes the LMFC signals in both the transmitter and receiver in a JESD204B Subclass 1 system to achieve deterministic latency. The SYSREF± signal is a rising edge sensitive signal that is sampled by the device clock rising edge. It is best practice that the device clock and SYSREF± signals be generated by the same source, such as the HMC7044 clock generator, so that the phase alignment between the signals is fixed. When designing for optimum deterministic latency operation, consider the timing distribution skew of the SYSREF± signal in a multipoint link system (multichip). The AD9172 supports a periodic SYSREF± signal. The periodicity can be continuous, strobed, or gapped periodic. The SYSREF± signal can be dc-coupled with a common-mode voltage of 0.6 V to 2.2 V and differential swing of 200 mV p-p to 1 V p-p. When dc-coupled, a small amount of common-mode current (up to 0.3 mA) is drawn from the SYSREF± pins. See Figure 55 and Figure 56 for the SYSREF± internal circuit for dc-coupled and ac-coupled configurations. Ensure that the SYSREF\_INPUTMODE bit (Register 0x084, Bit 6) is set to 1, dc-coupled, to prevent overstress on the SYSREF± receiver pins. Figure 55. DC-Coupled SYSREF± Receiver Circuitry $\textit{Figure 56. AC-Coupled SYSREF} \pm \textit{Receiver Circuitry}$ To avoid this common-mode current draw, the SYSREF± receiver can be ac-coupled using a 50% duty cycle periodic SYSREF± signal with ac coupling capacitors. If ac-coupled, the ac coupling capacitors combine with the resistors shown in Figure 56 to make a high-pass filter with an RC time constant of $\tau$ = RC. Select C such that $\tau$ > 4/SYSREF± frequency. In addition, the edge rate must be sufficiently fast to allow SYSREF± sampling clocks to correctly sample the rising SYSREF± edge before the next sample clock. When ac coupling the SYSREF± inputs, ensure that the SYSREF\_INPUTMODE bit (Register 0x084, Bit 6) is set to 0, ac-coupled, to enable the internal receiver biasing circuitry and prevent overstress on the SYSREF± receiver pins. AC coupling allows a differential voltage swing from 200 mV to 1 V on the SYSREF± pins. ## SYSREF± Sampling The SYSREF± signal is sampled by a divide by 4 version of the DAC clock. Therefore, the minimum pulse width of the SYSREF± signal must exceed 4 DAC clock periods to ensure accurate sampling. The delay between the SYSREF± and DAC clock input signal does not need to be timing constrained. By default, the first SYSREF± rising edge at the SYSREF± inputs that is detected after asserting the SYSREF\_MODE\_ONESHOT bit (Register 0x03A, Bit 1) begins the synchronization and aligns the internal LMFC signal with the sampled SYSREF± edge. Register 0x036 (SYSREF\_COUNT) indicates how many captured SYSREF± edges are ignored after the SYSREF\_MODE\_ONESHOT bit is asserted before the synchronization takes place. For example, if SYSREF\_COUNT is set to 3, the AD9172 does not sync after the SYSREF\_MODE\_ONESHOT bit is asserted until the arrival of the 4th SYSREF± edge. #### SYSREF± Jitter IRO In Subclass 1, after the one-shot synchronization occurs, the SYSREF± signal is monitored to ensure that the subsequent SYSREF± edges do not deviate from the internal LMFC clock by more than a target amount. Register 0x039 (SYSREF\_ERR\_WINDOW) indicates the size of the error window allowed, in DAC clock units. If a SYSREF± edge varies from the internal LMFC clock by more than the number of DAC clock units set in SYSREF\_ERR\_WINDOW, the IRQ\_SYSREF\_JITTER is asserted. Table 24. SYSREF± Jitter Window Tolerance | SYSREF± Jitter Window<br>Tolerance (DAC Clock Cycles) | SYSREF_ERR_WINDOW<br>(Register 0x039, Bits[5:0]) <sup>1</sup> | |-------------------------------------------------------|---------------------------------------------------------------| | ±1/2 | 0x00 | | ±4 | 0x04 | | ±8 | 0x08 | | ±12 | 0x0C | | ±16 | 0x10 | | ±20 | 0x14 | | +24 | 0x18 | | ±28 | 0x1C | <sup>&</sup>lt;sup>1</sup> The two least significant digits are ignored because the SYSREF± signal is sampled with a divide by 4 version of the DAC clock. As a result, the jitter window is set by this divide by 4 clock rather than the DAC clock. It is recommended that at least a four-DAC clock SYSREF± jitter window be chosen. The IRQ\_SYSREF\_JITTER can be configured as described in the Interrupt Request Operation section to indicate the SYSREF± signal has varied, and to request the SPI sequence for a sync be performed again. ## Sync Procedure The procedure for enabling the sync is as follows: - 1. Set up the DAC and the SERDES PLL, and enable the CDR (see the Start-Up Sequence section). - 2. Set Register 0x03B to 0xF1 to enable the synchronization circuitry. If using the soft on/off feature, set Register 0x03B to 0xF3 to ramp the datapath data before and after the synchronization. - 3. If Subclass 1, configure the SYSREF± settings as follows: - Set Register 0x039 (SYSREF± jitter window). See Table 24 for settings. - b. Set Register 0x036 = SYSREF\_COUNT; leave as 0 to bypass. - 4. Perform a one-shot sync. - a. Set Register 0x03A = 0x00. Clear one-shot mode if already enabled. - b. Set Register 0x03A = 0x02. Enable one-shot sync mode. - If Subclass 1, send a SYSREF± edge. If pulse counting, multiple SYSREF± edges are required. Sending SYSREF± edges triggers the synchronization. - Read back the SYNC\_ROTATION\_DONE bit (Register 0x03A, Bit 4) to confirm the rotation occurred. ## **Resynchronizing LMFC Signals** If desired, the sync procedure can be repeated to realign the LMFC clock to the reference signal by repeating Step 2 to Step 6, described in the Sync Procedure section. When the one-shot sync is triggered (writing Register 0x03A = 0x02), the SYNCOUTx± signals deassert to drop the JESD204B links and reassert the links after the rotation completes. #### **Deterministic Latency** JESD204B systems contain various clock domains distributed throughout. Data traversing from one clock domain to a different clock domain can lead to ambiguous delays in the JESD204B link. These ambiguities lead to nonrepeatable latencies across the link from power cycle to power cycle with each new link establishment. Section 6 of the JESD204B specification addresses the issue of deterministic latency with mechanisms defined as Subclass 1 and Subclass 2. The AD9172 supports JESD204B Subclass 0 and Subclass 1 operation, but not Subclass 2. Write the subclass to Register 0x458, Bits[7:5]. #### Subclass 0 This mode gives deterministic latency to within several PCLK cycles. It does not require any signal on the SYSREF± pins, which can be left disconnected. Subclass 0 still requires that all lanes arrive within the same LMFC cycle and the dual DACs must be synchronized to each other. ## Subclass 1 This mode gives deterministic latency and allows the link to synchronize within a few DAC clock cycles. Across the full operating range, for both supply and temperature, it is within $\pm 2.5$ DAC clock periods for a 6 GHz DAC clock rate or $\pm 4$ DAC clock periods for a 12.6 GHz DAC clock rate. If the supply and the temperature stability are maintained, the link can be synchronized to within $\pm 1.5$ DAC clock periods for a 6 GHz DAC clock rate or $\pm 2.5$ DAC clock periods for a 12.6 GHz DAC clock rate. Achieving this latency requires an external, low jitter SYSREF $\pm$ signal that is accurately phase aligned to the DAC clock. ## **Deterministic Latency Requirements** Several key factors are required for achieving deterministic latency in a JESD204B Subclass 1 system, as follows: - The SYSREF± signal distribution skew within the system must be less than the desired uncertainty. - The total latency variation across all lanes, links, and devices must be ≤12 PCLK periods, which includes both variable delays and the variation in fixed delays from lane to lane, link to link, and device to device in the system. Figure 57. JESD204B Link Delay = Fixed Delay + Variable Delay ## **Link Delay** The link delay of a JESD204B system is the sum of the fixed and variable delays from the transmitter, channel, and receiver as shown in Figure 57. For proper functioning, all lanes on a link must be read during the same LMFC period. Section 6.1 of the JESD204B specification states that the LMFC period must be larger than the maximum link delay. For the AD9172, this is not necessarily the case; instead, the AD9172 use a local LMFC for each link (LMFCRx) that can be delayed from the SYSREF± aligned LMFC. Because the LMFC is periodic, this delay can account for any amount of fixed delay. As a result, the LMFC period must only be larger than the variation in the link delays, and the AD9172 can achieve proper performance with a smaller total latency. Figure 58 and Figure 59 show a case where the link delay is greater than an LMFC period. Note that it can be accommodated by delaying LMFCRx. Figure 58. Link Delay > LMFC Period Example Figure 59. LMFC\_DELAY\_x to Compensate for Link Delay > LMFC The method to select the LMFCDel (Register 0x304) and LMFCVar (Register 0x306) variables is described in the Link Delay Setup Example, with Known Delays section and the Link Delay Setup Example, Without Known Delay section. Note that the setting for LMFCDel must not equal or exceed the number of PCLK cycles per LMFC period in the current mode. Similarly, LMFCVar must not exceed the number of PCLK cycles per LMFC period in the current mode or be set to <12 (whichever value is smaller). Setting LMFCDel appropriately ensures that all the corresponding data samples arrive in the same LMFC period. Then, LMFCVar is written into the receive buffer delay (RBD) to absorb all link delay variation. This write ensures that all data samples arrived before reading. By setting these to fixed values across runs and devices, deterministic latency is achieved. The RBD described in the JESD204B specification takes values from one frame clock cycle to /K/ frame clock cycles, and the RBD of the AD9172 takes values from 0 PCLK cycle to 12 PCLK cycles. As a result, up to 12 PCLK cycles of total delay variation can be absorbed. LMFCVar and LMFCDel are both in PCLK cycles. The PCLK factor, or number of frame clock cycles per PCLK cycle, is equal to 4/f. For more information on this relationship, see the Clock Relationships section. Two examples follow that show how to determine LMFCVar and LMFCDel. After they are calculated, write LMFCDel into Register 0x304 for all devices in the system, and write LMFCVar to Register 0x306 for all devices in the system. ## Link Delay Setup Example, with Known Delays All the known system delays can be used to calculate LMFCVar and LMFCDel. The example shown in Figure 60 is demonstrated in the following steps. Note that this example is in Subclass 1 to achieve deterministic latency, and the example uses the case for F=2; therefore, the number of PCLK cycles per multiframe = 16. Because PCBFixed <<< PCLK Period, PCBFixed is negligible in this example and not included in the calculations. 1. Find the receiver delays using Table 6. $$RxFixed = 13$$ PCLK cycles $RxVar = 2$ PCLK cycles - Find the transmitter delays. The equivalent table in the example JESD204B core (implemented on a GTH or GTX gigabit transceiver on a Virtex-6 FPGA) states that the delay is 56 ± 2 byte clock cycles. - Because the PCLK rate = ByteRate/4 as described in the Clock Relationships section, the transmitter delays in PCLK cycles are calculated as follows: $$TxFixed = 54/4 = 13.5 \text{ PCLK cycles}$$ $TxVar = 4/4 = 1 \text{ PCLK cycle}$ 4. Calculate MinDelayLane as follows: $$MinDelayLane = floor(RxFixed + TxFixed + PCBFixed)$$ = $floor(13 + 13.5 + 0)$ = $floor(26.5)$ MinDelayLane = 26 5. Calculate MaxDelayLane as follows: MaxDelayLane = ceiling(RxFixed + RxVar + TxFixed + TxVar + PCBFixed)) = $$ceiling(13 + 2 + 13.5 + 1 + 0)$$ = $ceiling(29.5)$ MaxDelayLane = 30 6. Calculate LMFCVar as follows: $$LMFCVar = (MaxDelay + 1) - (MinDelay - 1)$$ = $(30 + 1) - (26 - 1) = 31 - 25$ LMFCVar = 6 PCLK cycles 7. Calculate LMFCDel as follows: $$LMFCDel = (MinDelay - 1) \% (PCLKsperMF)$$ = $((26 - 1)) \% 16$ = 25 % 16 LMFCDel = 9 PCLK cycles Write LMFCDel to Register 0x304 for all devices in the system. Write LMFCVar to Register 0x306 for all devices in the system. Figure 60. LMFC Delay Calculation Example ## Link Delay Setup Example, Without Known Delay If the system delays are not known, the AD9172 can read back the link latency between LMFC\_RX for each link (with the LMFCDel setting subtracted out) and the SYSREF $\pm$ aligned LMFC. This information is then used to calculate LMFCVar and LMFCDel. Figure 62 shows how DYN\_LINK\_LATENCY\_0 (Register 0x302) provides a readback showing the delay (in PCLK cycles) between LMFC\_RX minus the LMFC\_DELAY\_x (fixed delay) setting set in the SPI at that time and the transition from the ILAS to the first data sample. By repeatedly power cycling and taking this measurement, the minimum and maximum delays across power cycles can be determined and used to calculate LMFCVar and LMFCDel. In Figure 62, for Link A, Link B, and Link C, the system containing the AD9172 (including the transmitter) is power cycled and configured 20 times. The AD9172 is configured as described in the Sync Procedure section. Because the purpose of this exercise is to determine LMFCDel and LMFCVar, the LMFCDel value is programmed to 0 and the DYN\_LINK\_ LATENCY\_0 value is read from Register 0x302. The variation in the link latency over the 20 runs is shown in Figure 62, described as follows: • Link A gives readbacks of 6, 7, 0, and 1. Note that the set of recorded delay values rolls over the edge of a multiframe at the boundary of K/PCLK factor = 8. Add the number of PCLK cycles per multiframe = 8 to the readback values of 0 and 1 because they rolled over the edge of the multiframe. Delay values range from 6 to 9. - Link B gives delay values from 5 to 7. - Link C gives delay values from 4 to 7. The example shown in Figure 62 is demonstrated in the following steps. Note that this example is in Subclass 1 to achieve deterministic latency, and the example uses the case for F = 1; therefore, the number of PCLK cycles per multiframe = 8. - Calculate the minimum of all delay measurements across all power cycles, links, and devices as follows: *MinDelay* = min(all *Delay* values) = 4 - 2. Calculate the maximum of all delay measurements across all power cycles, links, and devices as follows: \*MaxDelay\* = max(all Delay values) = 9 - 3. Set LFMCVar to the maximum of 12 PCLK cycles. If latency is required to be minimized for a given application, calculate the total delay variation (with 2 PCLK cycles of guard band on each end) across all power cycles, links, and devices as follows: $$LMFCVar = (MaxDelay + 2) - (MinDelay - 2)$$ = $(9 + 2) - (4 - 2) = 11 - 2 = 9$ PCLK cycles Calculate the minimum delay in PCLK cycles (with 2 PCLK cycles of guard band) across all power cycles, links, and devices as follows: ``` LMFCDel = (MinDelay - 2) \% (PCLKsperMF) = (4 - 2) \% 8 = 2 \% 8 = 2 PCLK cycles ``` Write LMFCDel to Register 0x304 for all devices in the system. Write LMFCVar to Register 0x306 for all devices in the system. Figure 61. DYN\_LINK\_LATENCY\_x Illustration Figure 62. Multilink Synchronization Settings, Derived Method Example Figure 63. Transport Layer Block Diagram ## TRANSPORT LAYER The transport layer receives the descrambled JESD204B frames and converts them to DAC samples based on the programmed JESD204B parameters shown in Table 25. The device parameters are defined in Table 26. Table 25. JESD204B Transport Layer Parameters | Parameter | Description | |-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | F | Number of octets per frame per lane: 1, 2, 3, 4 or 8. | | K | Number of frames per multiframe: $K = 32$ . | | L | Number of lanes per converter device (per link), as follows: 1, 2, 3, 4 or 8. | | M | Number of converters per device (per link), as follows: | | | For real data modes, M is the number of real data converters (if total interpolation is 1×). For complex data modes, M is the number of complex data subchannels. | | S<br> | Number of samples per converter, per frame: 1, 2, 4 or 8. | Table 26. JESD204B Device Parameters | Parameter | Description | |------------|---------------------------------------------------------------------------------| | CF | Number of control words per device clock per link.<br>Not supported, must be 0. | | CS | Number of control bits per conversion sample. Not supported, must be 0. | | HD | High density user data format. This parameter is always set to 1. | | N | Converter resolution. | | N' (or NP) | Total number of bits per sample. | Certain combinations of these parameters are supported by the AD9172. See Table 28 and Table 29 for a list of supported single-link and dual-link modes, respectively. Table 28 and Table 29 lists the JESD204B parameters for each of the modes. Table 27 lists JESD204B parameters that have fixed values. Table 27. JESD204B Parameters with Fixed Values | Parameter | Value | |-----------|-------| | K | 32 | | CF | 0 | | HD | 1 | | CS | 0 | Table 28. Single-Link JESD204B Operating Modes | | | Single-Link JESD204B Modes | | | | | | | | | | | | | | | | |--------------------------------------|----|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----| | Parameter | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 18 | 19 | 20 | 21 | | L (Lane Count) | 1 | 2 | 3 | 2 | 4 | 1 | 2 | 1 | 4 | 4 | 8 | 8 | 8 | 4 | 4 | 8 | 8 | | M (Converter Count) | 2 | 4 | 6 | 2 | 4 | 2 | 4 | 4 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | | F (Octets per Frame per Lane) | 4 | 4 | 4 | 2 | 2 | 3 | 3 | 8 | 1 | 2 | 1 | 2 | 3 | 1 | 2 | 1 | 2 | | S (Samples per Converter per Frame) | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 2 | 2 | 4 | 8 | 2 | 4 | 4 | 8 | | NP (Total Number of Bits per Sample) | 16 | 16 | 16 | 16 | 16 | 12 | 12 | 16 | 16 | 16 | 16 | 16 | 12 | 16 | 16 | 16 | 16 | | N (Converter Resolution) | 16 | 16 | 16 | 16 | 16 | 12 | 12 | 16 | 16 | 16 | 16 | 16 | 12 | 16 | 16 | 16 | 16 | Table 29. Dual-Link JESD204B Operating Modes | | | Dual-Link JESD204B Modes | | | | | | | | | | | |--------------------------------------|----|--------------------------|----|----|----|----|----|----|----|----|----|----| | Parameter | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 18 | 19 | | L (Lane Count) | 1 | 2 | 3 | 2 | 4 | 1 | 2 | 1 | 4 | 4 | 4 | 4 | | M (Converter Count) | 2 | 4 | 6 | 2 | 4 | 2 | 4 | 4 | 2 | 2 | 1 | 1 | | F (Octets per Frame per Lane) | 4 | 4 | 4 | 2 | 2 | 3 | 3 | 8 | 1 | 2 | 1 | 2 | | S (Samples per Converter per Frame) | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 2 | 2 | 4 | | NP (Total number of Bits per Sample) | 16 | 16 | 16 | 16 | 16 | 12 | 12 | 16 | 16 | 16 | 16 | 16 | | N (Converter Resolution) | 16 | 16 | 16 | 16 | 16 | 12 | 12 | 16 | 16 | 16 | 16 | 16 | ## **Configuration Parameters** The AD9172 modes refer to the link configuration parameters for L, K, M, N, NP, S, and F. Table 30 provides the description and addresses for these settings. **Table 30. Configuration Parameters** | JESD204B | | | |----------|-----------------------------------------------------------------------------------------------|------------------------------| | Setting | Description | Address | | L – 1 | Number of lanes minus 1. | Register 0x453,<br>Bits[4:0] | | F – 1 | Number of ((octets per frame) per lane) minus 1. | Register 0x454,<br>Bits[7:0] | | K – 1 | Number of frames per multiframe minus 1. | Register 0x455,<br>Bits[4:0] | | M – 1 | Number of converters minus 1. | Register 0x456,<br>Bits[7:0] | | N – 1 | Converter bit resolution minus 1. | Register 0x457,<br>Bits[4:0] | | NP – 1 | Bit packing per sample minus 1. | Register 0x458,<br>Bits[4:0] | | S – 1 | Number of ((samples per converter) per frame) minus 1. | Register 0x459,<br>Bits[4:0] | | HD | High density format. Set to 1. | Register 0x45A,<br>Bit 7 | | DID | Device ID. Match the device ID sent by the transmitter. | Register 0x450,<br>Bits[7:0] | | BID | Bank ID. Match the bank ID sent by the transmitter. | Register 0x451,<br>Bits[7:0] | | LID0 | Lane ID for Lane 0. Match the Lane ID sent by the transmitter on Logical Lane 0. | Register 0x452,<br>Bits[4:0] | | JESDV | JESD204x version. Match the version sent by the transmitter (0x0 = JESD204A, 0x1 = JESD204B). | Register 0x459,<br>Bits[7:5] | The AD9172 truncates the output of the main digital datapath to the value of N bits for the selected mode, which is then sent to the DAC core. It is possible to send the value of NP number of bits worth of data with the lower NP – N LSBs padded as 0s, or to send the full NP number of bits data across the SERDES lanes. In either case, the lower NP – N LSBs are truncated prior to the DAC core. #### Data Flow Through the JESD204B Receiver The link configuration parameters determine how the serial bits on the JESD204B receiver interface are deframed and passed on to the DACs as data samples. ## **Deskewing and Enabling Logical Lanes** After proper configuration, the logical lanes are automatically deskewed. All logical lanes are enabled or not based on the number of lanes for the mode setting chosen in Register 0x110, Bits[4:0]. The physical lanes are all powered up by default. To disable power to physical lanes that are not being used, set Bit x in Register 0x201 to 1 to disable Physical Lane x, and keep it at 0 to enable it. The logical lanes must be enabled and deskewed on a per link basis using the LINK\_PAGE control (Register 0x300, Bit 2). Set Bit x in Register 0x46C to 1 to deskew Link Logical Lane x for the selected link page. #### JESD204B TEST MODES ## **PHY PRBS Testing** The JESD204B receiver on the AD9172 includes a PRBS pattern checker on the back end of its physical layer. This functionality enables bit error rate (BER) testing of each physical lane of the JESD204B link. The PHY PRBS pattern checker does not require that the JESD204B link be established. It can synchronize with a PRBS7, PRBS15, or PRBS31 data pattern. PRBS pattern verification can be performed on multiple lanes at once. The error counts for failing lanes are reported for one JESD204B lane at a time. The process for performing PRBS testing on the AD9172 is as follows: - 1. Start sending a PRBS7, PRBS15, or PRBS31 pattern from the JESD204B transmitter. - 2. Select and write the appropriate PRBS pattern to Register 0x316, Bits[3:2], as shown in Table 31. - 3. Enable the PHY test for all lanes being tested by writing to PHY\_TEST\_EN (Register 0x315). Each bit of Register 0x315 enables the PRBS test for the corresponding lane. For example, writing a 1 to Bit 0 enables the PRBS test for Physical Lane 0. - 4. Toggle PHY\_TEST\_RESET (Register 0x316, Bit 0) from 0 to 1 then back to 0. - 5. Set PHY\_PRBS\_TEST\_THRESHOLD\_xBITS (Bits[23:0], Register 0x319 to Register 0x317) as desired. - 6. Write a 0 and then a 1 to PHY\_TEST\_START (Register 0x316, Bit 1). The rising edge of PHY\_TEST\_START starts the test. - a. (Optional) In some cases, it may be necessary to repeat Step 4 at this point. Toggle PHY\_TEST\_RESET (Register 0x316, Bit 0) from 0 to 1, then back to 0. - 7. Wait 500 ms. - 8. Stop the test by writing PHY\_TEST\_START (Register 0x316, Bit 1) = 0. - 9. Read the PRBS test results. - Each bit of PHY\_PRBS\_PASS (Register 0x31D) corresponds to one SERDES lane (0 = fail, 1 = pass). - b. The number of PRBS errors seen on each failing lane can be read by writing the lane number to check (0 to 7) in PHY\_SRC\_ERR\_CNT (Register 0x316, Bits[6:4]) and reading the PHY\_PRBS\_ERR\_CNT\_xBITS (Register 0x31A to Register 0x31C). The maximum error count is 2<sup>24-1</sup>. If all bits of Register 0x31A to Register 0x31C are high, the maximum error count on the selected lane is exceeded. **Table 31. PHY PRBS Pattern Selection** | PHY_PRBS_PAT_SEL Setting (Register 0x316, | | |-------------------------------------------|--------------| | Bits[3:2]) | PRBS Pattern | | 0b00 (default) | PRBS7 | | 0b01 | PRBS15 | | 0b10 | PRBS31 | ## **Transport Layer Testing** The JESD204B receiver in the AD9172 supports the short transport layer (STPL) test as described in the JESD204B standard. Use this test to verify the data mapping between the JESD204B transmitter and receiver. To perform this test, this function must be implemented and enabled in the logic device. Before running the test on the receiver side, the link must be established and running without errors. The STPL test ensures that each sample from each converter is mapped appropriately according to the number of converters (M) and the number of samples per converter (S). As specified in the JESD204B standard, the converter manufacturer specifies the test samples that are transmitted. Each sample must have a unique value. For example, if M=2 and S=2, four unique samples are transmitted repeatedly until the test is stopped. The expected sample must be programmed into the device and the expected sample is compared to the received sample one sample at a time until all are tested. The process for performing this test on the AD9172 is described as follows: - 1. Synchronize the JESD204B link. - 2. Enable the STPL test at the JESD204B Tx. - 3. Depending on JESD204B case, there may be up to six complex subchannels (M = 6), and each frame may contain up to eight samples (S = 8). Configure the SHORT\_TPL\_ REF\_SP\_MSB bits (Register 0x32E) and the SHORT\_TPL\_ REF\_SP\_LSB bits (Register 0x32D) to match one of the samples for one converter within one frame. For N = 12 modes, the expected sample value is multiplied by 16. - 4. Set SHORT\_TPL\_M\_SEL (Register 0x32C, Bits[3:2]) to select the channel. - 5. Set SHORT\_TPL\_IQ\_SAMPLE\_SEL (Register 0x32F, Bit 6) to select the I or Q subchannel. - 6. Set SHORT\_TPL\_SP\_SEL (Register 0x32C, Bits[7:4]) to select the sample within one frame for the selected . - 7. Set SHORT\_TPL\_TEST\_EN (Register 0x32C, Bit 0) to 1. - 8. Set SHORT\_TPL\_TEST\_RESET (Register 0x32C, Bit 1) to 1, then back to 0. - 9. Wait for the desired time. The desired time is calculated as $1/(\text{sample rate} \times \text{BER})$ . For example, given a bit error rate of BER = $1 \times 10^{-10}$ and a sample rate = 1 GSPS, the desired time = 10 sec. Then, set SHORT\_TPL\_TEST\_EN to 0. - Read the test result at SHORT\_TPL\_FAIL (Register 0x32F, Bit 0). - 11. Choose another sample for the same or another M to continue with the test, until all samples for both converters from one frame are verified. #### **Internal Loop Back Test** The AD9172 integrates one internal PRBS generator that can be used to test the JESD204B PHYs without an external SERDES signal input. The process for performing internal loopback testing on the AD9172 is as follows: Set the EQ\_BOOST\_PHYx bits (Register 0x240, Bits[7:0] and Register 0x241, Bit[7:0]) to 0. - Set SEL\_IF\_PARDATAINV\_DES\_RC\_CH bits (Register 0x234, Bits[7:0]) to 0 to make sure lanes not inverted. - 3. Enable the loop back test for all lanes being tested by writing to EN\_LBT\_DES\_RC\_CH (Register 0x250). Each bit of Register 0x250 enables the loop back test for the corresponding lane. For example, writing a 1 to Bit 0 enables the test for Physical Lane 0. - 4. For halfrate, set EN\_LBT\_HALFRATE\_DES\_RC (Register 0x251, Bit 1) to 1; otherwise, set it to 0. - 5. Toggle INIT\_LBT\_SYNC\_DES\_RC (Register 0x251, Bit 0) from 0 to 1 then back to 0. - 6. Refer to the PHY PRBS Testing section for information on how to run a PRBS7 check. #### **Repeated CGS and ILAS Test** As per Section 5.3.3.8.2 of the JESD204B specification, the AD9172 can check that a constant stream of /K28.5/ characters is being received, or that CGS followed by a constant stream of ILAS is being received. To run a repeated CGS test, send a constant stream of /K28.5/ characters to the AD9172 SERDES inputs. Next, set up the device and enable the links. Ensure that the /K28.5/ characters are being received by verifying that $\overline{\text{SYNCOUT}\pm}$ is deasserted and that CGS has passed for all enabled link lanes by reading Register 0x470. To run the CGS followed by a repeated ILAS sequence test, follow the procedure to set up the links, but before performing the last write (enabling the links), enable the ILAS test mode by writing a 1 to Register 0x477, Bit 7. Then, enable the links. When the device recognizes four CGS characters on each lane, it deasserts the SYNCOUTx±. At this point, the transmitter starts sending a repeated ILAS sequence. Read Register 0x473 to verify that the initial lane synchronization has passed for all enabled link lanes. #### **JESD204B ERROR MONITORING** ## Disparity, Not in Table, and Unexpected Control (K) Character Errors As per Section 7.6 of the JESD204B specification, the AD9172 can detect disparity errors, not in table (NIT) errors, and unexpected control character errors, and can optionally issue a sync request and reinitialize the link when errors occur. Several other interpretations of the JESD204B specification are noted in this section. When three NIT errors are injected to one lane and QUAL\_RDERR (Register 0x476, Bit 4) = 1, the readback values of the bad disparity error (BDE) count register is 1. Reporting of disparity errors that occur at the same character position of an NIT error is disabled. No such disabling is performed for the disparity errors in the characters after an NIT error. Therefore, it is expected behavior that an NIT error may result in a BDE error. ## **Checking Error Counts** The error count can be checked for disparity errors, NIT errors, and unexpected control character errors. The error counts are on a per lane and per error type basis. Each error type and lane has a register dedicated to it. To check the error count, the following steps must be performed: - Choose and enable which errors to monitor by selecting them in Register 0x480, Bits[5:3] to Register 0x487, Bits[5:3]. Unexpected K (UEK) character, BDE, and NIT error monitoring can be selected for each lane by writing a 1 to the appropriate bit, as described in Table 60. These bits are enabled by default. - The corresponding error counter reset bits are in Register 0x480, Bits[2:0] to Register 0x487, Bits[2:0]. Write a 1 to the corresponding bit to reset that error counter. - 3. Registers 0x488, Bits[2:0] to Register 0x48F, Bits[2:0] have the terminal count hold indicator for each error counter. If this flag is enabled, when the terminal error count of 0xFF is reached, the counter ceases counting and holds that value until reset. Otherwise, it wraps to 0x00 and continues counting. Select the desired behavior and program the corresponding register bits per lane. #### **Check for Error Count Over Threshold** To check for the error count over threshold, follow these steps: - Define the error counter threshold. The error counter threshold can be set to a user defined value in Register 0x47C, or left to the default value of 0xFF. When the error threshold is reached, an IRQ is generated, SYNCOUTx± is asserted, or both, depending on the mask register settings. This one error threshold is used for all three types of errors (UEK, NIT, and BDE). - 2. Set the SYNC\_ASSERT\_MASK bits. The SYNCOUTx± assertion behavior is set in Register 0x47D, Bits[2:0]. By default, when any error counter of any lane is equal to the threshold, it asserts SYNCOUTx± (Register 0x47D, Bits[2:0] = 0b111). When setting the SYNC\_ASSERT\_MASK bits, LINK\_PAGE (Register 0x300, Bit 2) must be set to 1. - 3. Read the error count reached indicator. Each error counter has a terminal count reached indicator, per lane. This indicator is set to 1 when the terminal count of an error counter for a particular lane is reached. These status bits are located in Register 0x490, Bits[2:0] to Register 0x497, Bits[2:0]. Bit 3 can be read back to indicate whether a particular lane is active. #### **Error Counter and IRQ Control** For error counter and IRQ control, follow these steps: - 1. Enable the interrupts. Enable the JESD204B interrupts. The interrupts for the UEK, NIT, and BDE error counters are in Register 0x4B8, Bits[7:5]. There are other interrupts to monitor when bringing up the link, such as lane deskewing, initial lane sync, good check sum, frame sync, code group sync (Register 0x4B8, Bits[4:0], and configuration mismatch (Register 0x4B9, Bit 0). These bits are off by default but can be enabled by writing 0b1 to the corresponding bit. - 2. Read the JESD204B interrupt status. The interrupt status bits are in Register 0x4BA, Bits[7:0] and Register 0x4BB, Bit 0, with the status bit position corresponding to the enable bit position. - It is recommended to enable all interrupts that are planned to be used prior to bringing up the JESD204B link. When the link is up, the interrupts can be reset and then used to monitor the link status. ## Monitoring Errors via SYNCOUTx± When one or more disparity, NIT, or unexpected control character errors occur, the error is reported on the SYNCOUTx± pin as per Section 7.6 of the JESD204B specification. The JESD204B specification states that the SYNCOUTx± signal is asserted for exactly two frame periods when an error occurs. For the AD9172, the width of the SYNCOUTx± pulse can be programmed to ½, 1, or 2 PCLK cycles. The settings to achieve a SYNCOUTx± pulse of two frame clock cycles are given in Table 32. Table 32. Setting SYNCOUTx± Error Pulse Duration | F | PCLK Factor<br>(Frames/PCLK) | SYNC_ERR_DUR (Register 0x312,<br>Bits[7:4]) Setting <sup>1</sup> | |---|------------------------------|------------------------------------------------------------------| | 1 | 4 | 0 (default) | | 2 | 2 | 1 | | 3 | 1.5 | 2 | | 4 | 1 | 2 | | 8 | 0.5 | 4 | <sup>&</sup>lt;sup>1</sup> These register settings assert the SYNCOUTx± signal for two frame clock cycle pulse widths. #### Unexpected Control Character, NIT, Disparity IRQs For UEK character, NIT, and disparity errors, error count over the threshold events are available as IRQ events. Enable these events by writing to Register 0x4B8, Bits[7:5]. The IRQ event status can be read at Register 0x4BA, Bits[7:5] after the IRQs are enabled. See the Error Counter and IRQ Control section for information on resetting the IRQ. See the Interrupt Request Operation section for more information on IRQs. ## **Errors Requiring Reinitializing** A link reinitialization automatically occurs when four invalid disparity characters or four NIT characters are received as per Section 7.1 of the JESD204B specification. When a link reinitialization occurs, the resync request is at least five frames and nine octets long. The user can optionally reinitialize the link when the error count for disparity errors, NIT errors, or UEK character errors reaches a programmable error threshold. The process to enable the reinitialization feature for certain error types is as follows: - Choose and enable which errors to monitor by selecting them in Register 0x480, Bits[5:3] to Register 0x487, Bits[5:3]. UEK, BDE, and NIT error monitoring can be selected for each lane by writing a 1 to the appropriate bit, as described in Table 33. These are enabled by default. - 2. Write a 0 to the corresponding bit to Register 0x480, Bits[2:0] to Register 0x487, Bits[2:0] to take counter out of reset. - 3. Enable the sync assertion mask for each type of error by writing to SYNC\_ASSERT\_MASK (Register 0x47D, Bits[2:0]) according to Table 33. - 4. Program the desired error counter threshold into ERRORTHRES (Register 0x47C). - 5. For each error type enabled in the SYNC\_ASSERT\_MASK register, if the error counter on any lane reaches the programmed threshold, SYNCOUTx± falls, issuing a sync request. Note that all error counts are reset when a link reinitialization occurs. The IRQ does not reset and must be reset manually. Table 33. Sync Assertion Mask (SYNC\_ASSERT\_MASK) | Addr. | Bit No. | Bit Name | Description | |-------|---------|----------|-------------------------------------------------------------------------------------------| | 0x47D | 2 | BDE | Set to 1 to assert SYNCOUTx± if the disparity error count reaches the threshold | | | 1 | NIT | Set to 1 to assert SYNCOUTx± if the NIT error count reaches the threshold | | | 0 | UEK | Set to 1 to assert SYNCOUTx±<br>if the UEK character error<br>count reaches the threshold | #### CGS, Frame Sync, Checksum, and ILAS Monitoring Register 0x470 to Register 0x473 can be monitored to verify that each stage of the JESD204B link establishment has occurred. Bit x of CODE\_GRP\_SYNC (Register 0x470) is high if Link Lane x received at least four K28.5 characters and passed code group synchronization. Bit x of FRAME\_SYNC (Register 0x471) is high if Link Lane x completed initial frame synchronization. Bit x of GOOD\_CHECKSUM (Register 0x472) is high if the checksum sent over the lane matches the sum of the JESD204B parameters sent over the lane during ILAS for Link Lane x. The parameters can be added either by summing the individual fields in registers or summing the packed register. The calculated checksums are the lower eight bits of the sum of the following fields: DID, BID, LID, SCR, L -1, F -1, K -1, M -1, N -1, SUBCLASSV, NP -1, JESDV, S -1, and HD. Bit x of INIT\_LANE\_SYNC (Register 0x473) is high if Link Lane x passed the initial lane alignment sequence. ## CGS, Frame Sync, Checksum, and ILAS IRQs Fail signals for CGS, frame sync, checksum, and ILAS are available as IRQ events. Enable them by writing to Register 0x4B8, Bits[3:0]. The IRQ event status can be read at Register 0x4BA, Bits[3:0] after the IRQs are enabled. Write a 1 to Register 0x4BA, Bit 0 to reset the CGS IRQ. Write a 1 to Register 0x4BA, Bit 1 to reset the frame sync IRQ. Write a 1 to Register 0x4BA, Bit 2 to reset the checksum IRQ. Write a 1 to Register 0x4BA, Bit 3 to reset the ILAS IRQ. See the Interrupt Request Operation section for more information. ## **Configuration Mismatch IRQ** The AD9172 has a configuration mismatch flag that is available as an IRQ event. Use Register 0x4B9, Bit 0 to enable the mismatch flag (it is enabled by default), and then use Register 0x4BB, Bit 0 to read back its status and reset the IRQ signal. See the Interrupt Request Operation section for more information. The configuration mismatch event flag is high when the link configuration settings (in Register 0x450 to Register 0x45D) do not match the JESD204B settings received by the device (Register 0x400 to Register 0x40D). This function is different from the good checksum flags in Register 0x472. The good checksum flags ensure that the transmitted checksum matches a calculated checksum based on the transmitted settings. The configuration mismatch event ensures that the transmitted settings match the configured settings. ## DIGITAL DATAPATH The full digital datapath of the AD9172 consists of channel datapaths that are bypassable, as well as a main DAC datapath leading up to the analog DAC core. There is a variety of different digital feature blocks available within each of the channel and main DAC datapaths. ## TOTAL DATAPATH INTERPOLATION The AD9172 contains two separate blocks of interpolation: one block is located in each of the channelizer datapaths, and a second interpolation stage is located in the main DAC datapath. The total interpolation for the chip can be determined by multiplying the channel interpolation factor by the main datapath interpolation factor. The relationship between the DAC sample rate and input data rate is shown in the following equation: $\label{eq:continuous_continuous} Total\ Interpolation = Channel\ Interpolation \times \\ Main\ Interpolation$ $f_{DATA} = f_{DAC}/(Channel\ Interpolation \times Main\ Interpolation)$ Each of the various cascaded half-band filters has 80% signal bandwidth capabilities. Therefore, if using interpolation (not bypass or 1× total interpolation for both channel and main datapaths), the available signal bandwidth (BW) with respect to the input data rate is calculated as follows: Signal BW = $$0.8 \times (f_{DATA}/2)$$ where the total interpolation > 1. Signal $BW = (f_{DATA}/2)$ where the total interpolation = 1. The interpolation values are programmed as shown in the Table 34. **Table 34. Interpolation Factor Register Settings** | Interpolation<br>Factor | Main Datapath,<br>Register 0x111,<br>Bits[7:4] | Channel Datapath,<br>Register 0x111,<br>Bits[3:0] | |-------------------------|------------------------------------------------|---------------------------------------------------| | 1× | 0x1 | 0x1 | | 2× | 0x2 | 0x2 | | 3× | Not applicable | 0x3 | | 4× | 0x4 | 0x4 | | 6× | 0x6 | 0x6 | | 8× | 0x8 | 0x8 | | 12× | 0xC | Not applicable | Table 35. Interpolation Modes and Useable Bandwidth | Total Interpolation | Available Signal<br>Bandwidth | <b>f</b> data | |--------------------------------------------------------------|-------------------------------|---------------------------------------| | 1× (Bypass) | f <sub>DATA</sub> /2 | f <sub>DAC</sub> | | 2×, 4×, 6×, 8×, 12×,<br>16×, 18×, 24×, 32×,<br>36×, 48×, 64× | 80% × f <sub>DATA</sub> /2 | f <sub>DAC</sub> /total interpolation | #### Filter Performance The interpolation filters interpolate between existing data in such a way that they minimize changes in the incoming data while suppressing the creation of interpolation images. The usable bandwidth, as shown in Table 35, is defined as the frequency band over which the filters have a pass-band ripple of less than $\pm 0.001$ dB and an image rejection of greater than 85 dB. Conceptual drawings that shows the relative bandwidth of each of the filters are shown in Figure 64 and Figure 65. The maximum pass-band amplitude of all filters is the same; they are different in the illustration to improve understanding. Figure 64. Band Responses of Total Interpolation Rates for 1×, 2×, 4×, and 6× at Each Respective Maximum Achievable DAC Rate Figure 65. Band Responses of Total Interpolation Rates for 8×, 12×, 16×, 18×, 24×, 32×, 36×, 48×, and 64× at a 12 GHz DAC Rate ## **NCO Only Mode** The AD9172 is capable of operating in a mode with only the NCO enabled. In this mode, a single-tone sine wave is generated using a programmable internal dc amplitude level that is injected into the NCO block to modulate the data into a single tone. This internal dc level is injected into either the channel or main datapaths through various controls, as shown in Figure 66. Mode 3 and Mode 4 can be used to generate a single-channel or dual channel NCO only mode of operation, respectively. It is not necessary to bring up the JESD204B link in this mode. This mode is a useful option to bring up a transmitter radio signal chain without requiring a digital data source, because the device generates the NCO data internally. This mode can also be used in applications where a sine wave is all that is required, such as in a local oscillator application. There is an additional optional calibration NCO block that can be used as part of the initial system calibration without needing to reprogram the final main datapath NCO to the final system configuration. This feature is discussed in more detail in the Calibration NCO section. When the NCO test mode is enabled, the data source of the digital datapath is the dc test data word, meaning that the JESD204B link can be brought up and data can be transferred to the device over the link, but the data is not presented to the DAC when in this test mode. Connection to the SERDES data source is only achieved by disabling this test mode. The SPI control bit for this test mode can be set on the fly, but because disabling the mode and switching to the SERDES datapath normally requires the lanes and/or interpolation mode to also be set, on the fly setting or resetting of the NCO only mode control bit is normally not practical. Figure 66. DC Amplitude Injection for NCO Only Mode Block Diagram #### **CHANNEL DIGITAL DATAPATH** Figure 67. Block Diagram of the Channel Digital Datapath per the Main DAC Output Each main DAC output has three optional channelizers, or channel datapaths, that are selected based on the JESD204B mode selected. The channel datapaths also have the option to be bypassed (1× interpolation selected), which bypasses all of the digital features included in each channelizer. Each channelizer consists of a digital gain stage, complex interpolation block, and complex 48-bit NCO with modulus. The interpolation selection is the same for all three channelizers; however, the gain stage and complex NCO values can all be independently configured. The controls for these blocks are paged by the channel paging mask in the CHANNEL\_PAGE bits (Register 0x008, Bits[5:0]), as described in Table 36. Each bit of the page mask corresponds to a channel datapath. These channels can be paged individually to set the values for each channel uniquely, or can be paged simultaneously to set all channels to the same value for the control being configured. Table 36. Channel Page Mask | CHANNEL_PAGE<br>(Register 0x008,<br>Bits[5:0]) | Channel<br>Paged | Channel Datapath<br>Updated | |------------------------------------------------|------------------|-----------------------------| | 0x01 (Bit 0) | Channel 0 | Channel 0 of DAC0 | | 0x02 (Bit 1) | Channel 1 | Channel 1 of DAC0 | | 0x04 (Bit 2) | Channel 2 | Channel 2 of DAC0 | | 0x08 (Bit 3) | Channel 3 | Channel 0 of DAC1 | | 0x10 (Bit 4) | Channel 4 | Channel 1 of DAC1 | | 0x20 (Bit 5) | Channel 5 | Channel 2 of DAC1 | Each of the digital blocks in the channels is described in more detail in the following sections. ## **Digital Gain** The AD9172 has individual channel gain controls that allow unique gain scaling capabilities for each complex data input channel. The gain code for each channel is 12-bit resolution, located in Register 0x146 and Register 0x147, and can be calculated by the following formula: $$0 \le Gain \le (2^{12} - 1)/2^{11}$$ $-\infty dB < dBGain \le +6.018 dB$ $Gain = Gain Code \times (1/2048)$ $dBGain = 20 \times log_{10} (Gain)$ $Gain Code = 2048 \times Gain = 2^{11} \times 10^{(dBGain/20)}$ The gain code control (CHNL\_GAIN) is paged with the channel page mask (CHANNEL\_PAGE) in Register 0x008, Bits[5:0]. The digital gain feature is available in all modes, except when $1\times$ channel interpolation is used because the channel datapaths are bypassed in that mode. The summing node that combines the three channels may clip the summed signals if the combined amplitude is too large. For example, if all three channels are being used and all three data streams are >1/3 full-scale amplitude, clipping may occur. The sum of the data values when any number of channels is used must be between $-2^{15}$ and $+2^{15}$ . #### **Channel Interpolation** The channel interpolation options available are bypass $(1\times)$ , $2\times$ , $3\times$ , $4\times$ , $6\times$ , and $8\times$ . Each of the half-band filters used for interpolation has 80% bandwidths with 85 dB of stop band rejection. The channel half-band cascaded configuration is shown in Figure 68, with each of the useable bandwidths of the channel interpolation filters listed in Table 37. Figure 68. Channel Interpolation Half-Band Filter Block Diagram Table 37. Channel Interpolation Useable Bandwidths and Rejection | Half-Band<br>Filter | Bandwidth<br>(×f <sub>IN_FILTER</sub> ) (%) | Stop Band Rejection (dB) | |---------------------|---------------------------------------------|--------------------------| | HB0 | 80 | 85 | | TB0 | 54 | 85 | | HB1 | 40 | 85 | | HB2 | 27 | 85 | <sup>&</sup>lt;sup>1</sup> f<sub>IN\_FILTER</sub> is the frequency at the input of the half-band filter. ## **Channel Digital Modulation** The AD9172 has digital modulation features to modulate the baseband quadrature signal to a desired frequency. There are two stages of complex digital modulation available in the AD9172: channel modulation and main modulation. Each main DAC has three channels, each with its own NCO, that can individually modulate the data from each channel with a unique frequency and phase offset. The AD9172 is equipped with several NCO modes. The default NCO is a 48-bit, integer NCO. There is an additional modulus option for each channel NCO where the A/B ratio of the dual modulus NCO allows the output frequency to be synthesized with very fine precision. NCO mode is selected as shown in Table 38. These controls are paged per the channel page masks in the CHANNEL\_PAGE bits (Register 0x008, Bits[5:0]). **Table 38. Channel Modulation Mode Selection** | | Modulation Type | | |-------------------------|--------------------------|--------------------------| | Modulation Mode | Register 0x130,<br>Bit 6 | Register 0x130,<br>Bit 2 | | None | 0b0 | 0b0 | | 48-Bit Integer NCO | 0b1 | 0b0 | | 48-Bit Dual Modulus NCO | 0b1 | 0b1 | The channel NCO blocks also contain sideband selection controls as well as options for how the FTW and phase offset controls are updated. Calculate the phase offset word control as follows: $$-180^{\circ} \le Degrees \ Offset \le +180^{\circ}$$ Degrees Offset = $$180^{\circ} \times (DDSC\_NCO\_PHASE\_OFFSET/2^{15})$$ where *DDSC\_NCO\_PHASE\_OFFSET* is a 16-bit twos complement value programmed in the registers listed in Table 39. Table 39. Channel NCO Phase Offset Registers | Address | Value | Description | |---------|-----------------------------|------------------------| | 0x138 | DDSC_NCO_PHASE_OFFSET[7:0] | 8 LSBs of phase offset | | 0x139 | DDSC_NCO_PHASE_OFFSET[15:8] | 8 MSBs of phase offset | #### 48-Bit Dual Modulus NCO The 48-bit dual modulation mode uses an NCO, a phase shifter, and a complex modulator to modulate the signal by a programmable carrier signal, as shown in Figure 69. This configuration allows output signals to be placed anywhere in the output spectrum up to $\pm f_{\rm NCO}/2$ with very fine frequency resolution. The NCO produces a quadrature carrier to translate the input signal to a new center frequency. A quadrature carrier is a pair of sinusoidal waveforms of the same frequency, offset 90° from each other. The frequency of the quadrature carrier is set via a FTW. The quadrature carrier is mixed with the I and Q data and then summed into the I and Q datapaths, as shown in Figure 69. ## **Integer NCO Mode** The channel 48-bit NCOs can be used as integer NCOs. The FTW for the channel NCOs depends on the speed at which the channel NCO block is running ( $f_{NCO}$ ), which is the same rate as the summing node (maximum of 1.5 GSPS) and can be calculated by using the following formulas: $$f_{NCO} = f_{DATA} \times Channel Interpolation$$ or $$f_{NCO} = f_{DAC}/Main\ Interpolation = f_{SUMMING\_NODE}$$ The FTWs for each individual channel can be programmed separately and are calculated by using the following formula: $$-f_{NCO}/2 \le f_{CARRIER} < +f_{NCO}/2$$ $$DDSC\_FTW = (f_{CARRIER}/f_{NCO}) \times 2^{48}$$ where DDSC\_FTW is a 48-bit, twos complement number. The frequency tuning word is set as shown in Table 40. **Table 40. Channel NCO FTW Registers** | Address | Value | Description | |---------|-----------------|--------------------| | 0x132 | DDSC_FTW[7:0] | 8 LSBs of FTW | | 0x133 | DDSC_FTW[15:8] | Next 8 bits of FTW | | 0x134 | DDSC_FTW[23:16] | Next 8 bits of FTW | | 0x135 | DDSC_FTW[31:24] | Next 8 bits of FTW | | 0x136 | DDSC_FTW[39:32] | Next 8 bits of FTW | | 0x137 | DDSC_FTW[47:40] | 8 MSBs of FTW | Unlike other registers, the FTW registers are not updated immediately upon writing. Instead, the FTW registers update on the rising edge of DDSC\_FTW\_LOAD\_REQ (Register 0x131, Bit 0). After an update request, DDSC\_FTW\_LOAD\_ACK (Register 0x131, Bit 1) must be high to acknowledge that the FTW has updated. The DDSC\_SEL\_SIDEBAND bit (Register 0x130, Bit 1 = 0b1) is a convenience bit that can be set to use the lower sideband modulation result, which is equivalent to flipping the sign of the FTW. Figure 69. NCO Modulator Block Diagram # Channel Modulus NCO Mode (Direct Digital Synthesis (DDS)) Each of the channel 48-bit NCOs can also be used in a dual modulus mode to create fractional frequencies beyond the 48-bit accuracy. The modulus mode is enabled by programming the DDSC\_MODULUS\_EN bit in the DDSC\_DATAPATH\_CFG register to 1 (Register 0x130, Bit 2 = 0b1). The frequency ratio for the programmable modulus direct digital synthesis (DDS) is very similar to that of the typical accumulator-based DDS. The only difference is that N is not required to be a power of two for the programmable modulus, but can be an arbitrary integer. In practice, hardware constraints place limits on the range of values for N. As a result, the modulus extends the use of the NCO to applications that require exact rational frequency synthesis. The underlying function of the programmable modulus technique is to alter the accumulator modulus. Implementation of the programmable modulus function within the AD9172 is such that the fraction, M/N, is expressible by the following equation. Note that the form of the equation implies a compound frequency tuning word with X representing the integer part and A/B representing the fractional part. $$\frac{f_{CARRIER}}{f_{NCO}} = \frac{M}{N} = \frac{X + \frac{A}{B}}{2^{48}}$$ where *X* is programmed in Register 0x132 to Register 0x137. *A* is programmed in Register 0x140 to Register 0x145. *B* is programmed in Register 0x13A to Register 0x13F. ## **Programmable Modulus Example** Consider the case in which $f_{\rm NCO} = 1500$ MHz and the desired value of $f_{\rm CARRIER}$ is 150 MHz. This scenario synthesizes an output frequency that is not a power of two submultiple of the sample rate, namely $f_{\rm CARRIER} = (1/10) f_{\rm NCO}$ , which is not possible with a typical accumulator-based DDS. The frequency ratio, $f_{\rm CARRIER}/f_{\rm DAC}$ , leads directly to M and N, which are determined by reducing the fraction (150,000,000/1,500,000,000) to its lowest terms, that is, $$M/N = 150,000,000/1,500,000,000 = 1/10$$ Therefore, M = 1 and N = 10. After calculation, X = 28,147,497,671,065, A = 3, and B = 5. Programming these values into the registers for X, A, and B (X is programmed in Register 0x132 to Register 0x137 for DDSC\_FTWx, B is programmed in Register 0x13A to Register 0x13F for DDSC\_ACC\_MODULUSx, and A is programmed in Register 0x140 to Register 0x145 for DDSC\_ACC\_DELTAx) causes the NCO to produce an output frequency of exactly 150 MHz given a 1500 MHz sampling clock. For more details, refer to the AN-953 Application Note. ## **NCO** Reset Resetting the NCO can be useful when determining the start time and phase of the NCO. The NCO can be reset by several different methods, including a SPI write or by the SYSREF± signal. ## **Channel Summing Node** The channel datapaths all combine at the summing node junction before continuing on to the main DAC datapath. The summation of any number of channels being used must not exceed the $\pm 2^{15}$ value range to avoid clipping of the data signal into the main datapath. The maximum data rate for each channel when the channel interpolation is >1× is limited by the summing node junction maximum speed of 1.5 GSPS. If the channel datapaths are bypassed (channel interpolation is 1×), the summing node block is also bypassed, as shown in Figure 67. #### **MAIN DIGITAL DATAPATH** Figure 70. Block Diagram of the Main Digital Datapath per Main DAC Output Each main DAC digital datapath consists of a power amplifier (PA) protection block, a complex main datapath interpolation block, a 48-bit complex main datapath NCO, and a ramp-up/ramp-down gain block. The main DAC datapaths also have the option to be bypassed (1× interpolation selected), which bypasses all of the complex digital features included the main digital datapath. The interpolation selection is set the same for all main datapaths; however, the PA protection block and complex NCO values can all be independently configured. The controls for these blocks are paged by the main DAC datapath paging mask, MAINDAC\_PAGE (Register 0x008, Bits[7:6]), as listed in Table 41. Each bit of the page mask corresponds to a main DAC datapath. These datapaths can be paged individually to set the values for each DAC uniquely or can be paged simultaneously to set all channels to the same value for the control being configured. Table 41. Main DAC Datapath Page Mask | MAINDAC_PAGE<br>(Register 0x008,<br>Bits[7:6]) | DAC<br>Paged | DAC Datapath<br>Updated | |------------------------------------------------|--------------|-------------------------| | 0x40 (Bit 6) | DAC0 | DAC0 | | 0x80 (Bit 7) | DAC1 | DAC1 | Each of the digital blocks in the main datapaths is described in more detail in the following sections. #### **Downstream Protection (PA Protection)** The AD9172 has several blocks designed to protect the PA of the system, as well as other downstream blocks, by preventing transients out of the DAC outputs. The DAC output can be triggered to turn on and off by the following signals, shown in Figure 71: - PDP\_PROTECT. This signal asserts when the calculated digital vector power exceeds a programmable threshold. - INTERFACE\_PROTECT. This signal asserts when certain JESD204B errors occur. - SPI\_PROTECT. This signal asserts when the user writes the SPI trigger register control. - BSM\_PROTECT. This signal asserts and the blanking state machine (BSM) module flushes the datapath on the rising edge of the TXEN0 or TXEN1 signals, which may come from a SPI write or the external TXEN0 or TXEN1 pin. The flags of these events can also be routed out on the pins of IRQ ( $\overline{IRQ0}$ and $\overline{IRQ1}$ ) to shut down other external downstream components. The DAC output on/off is implemented through a feedforward trigger signal to the ramp-up/ramp-down digital gain block at the end of the main digital datapath, before the analog DAC core, which allows the DAC to be turned on or off gradually with the ramp on/off block. Figure 71. Block Diagram of Downstream Protection Triggers Figure 72. PDP Block Diagram #### Power Detection and Protection (PDP) Block The PDP block detects the average power of the DAC input signal and prevents overrange signals from being passed to the next stage, which may potentially cause destructive breakdown on power sensitive devices, such as PAs. The protection function provides a signal, PDP\_PROTECT, that can shut down the DAC outputs or be routed externally to shut down a PA. The PDP block uses a separate path with a shorter latency than the datapath to ensure that PDP\_PROTECT is triggered before the overrange signal reaches the analog DAC cores (except when the total interpolation is $1\times$ ). The sum of the $I^2$ and $Q^2$ are calculated as a representation of the input signal power (only the top six MSBs of data samples are used). The calculated sample power numbers are accumulated through a moving average filter with an output that is the average of the input signal power in a certain number of samples. There are two types of average filters with different lengths: the short filter detects pulses with high power in the digital domain and the long filter detects high power in the digital domain, which lasts longer than the thermal constant of the PA. When the output of the averaging filter is larger than the threshold, the internal signal, PDP\_PROTECT, goes high, which can optionally be configured to trigger an IRQ flag and turn off the DAC output through the ramp-up/ramp-down. The PDP block is configured as shown in Figure 72. The long and short averaging time is configured by the LONG\_PA\_AVG\_TIME (Register 0x585, Bits [3:0]) and the SHORT\_PA\_AVG\_TIME (Register 0x58A, Bits [1:0]) controls. Use the following calculations to determine the average window size times: Length of long average window = $2^{LONG\_PP\_AVG\_TIME + 9}$ Length of short average window = $2^{SHORT\_PA\_AVG\_TIME}$ When the average calculation value exceeds a specified threshold, the ramp-down signal is triggered to ramp down the output. The thresholds for the long and short average options are programmed in the registers listed in Table 42, along with their respective detected power calculation readbacks. Table 42. PDP Threshold and Power Calculation Controls | Register | Bits | Control | |----------|-------|--------------------------| | 0x583 | [7:0] | LONG_PA_THRESHOLD[7:0] | | 0x584 | [4:0] | LONG_PA_THRESHOLD[12:8] | | 0x586 | [7:0] | LONG_PA_POWER[7:0] | | 0x587 | [4:0] | LONG_PA_POWER[12:8] | | 0x588 | [7:0] | SHORT_PA_THRESHOLD[7:0] | | 0x589 | [4:0] | SHORT_PA_THRESHOLD[12:8] | | 0x58B | [7:0] | SHORT_PA_POWER[7:0] | | 0x58C | [4:0] | SHORT_PA_POWER[12:8] | #### **Main Datapath Interpolation** The main digital datapath interpolation options available are bypass $(1\times)$ , $2\times$ , $4\times$ , $6\times$ , $8\times$ and $12\times$ . Each of the half-band filters used for interpolation have 80% bandwidths with 85 dB of stop band rejection. The channel half-band cascaded configuration is shown in Figure 73, with each of the useable bandwidths of the channel interpolation filters listed in Table 43. Figure 73. Main Datapath Interpolation Half-Band Filter Block Diagram Table 43. Main Datapath Interpolation Useable Bandwidths and Rejection | Half-Band Filter | Bandwidth<br>(×f <sub>IN_FILTER</sub> ) | Stop Band Rejection (dB) | |------------------|-----------------------------------------|--------------------------| | HB3 | 80% | 85 | | HB4 | 40% | 85 | | TB1 | 27% | 85 | | HB5 | 20% | 85 | #### **Main Digital Modulation** The AD9172 has digital modulation features to modulate the baseband quadrature signal to a desired frequency. There are two stages of complex digital modulation available in the AD9172; channel modulation and main modulation. Each main DAC has a final main NCO that can individually modulate each main DAC datapath with a unique frequency and phase offset. The AD9172 is equipped with several NCO modes. The default NCO is a 48-bit, integer NCO. There is an additional modulus option for each main DAC datapath NCO where the A/B ratio of the dual modulus NCO allows the output frequency to be synthesized with very fine precision. NCO mode is selected as shown in Table 44. These controls are paged per the main DAC page masks, MAINDAC\_PAGE (Register 0x008, Bits [7:6]). **Table 44. Main Modulation Mode Selection** | | Modulation Type | | |-------------------------|--------------------------|--------------------------| | Modulation Mode | Register 0x112,<br>Bit 3 | Register 0x112,<br>Bit 2 | | None | 0b0 | 0b0 | | 48-Bit Integer NCO | 0b1 | 0b0 | | 48-Bit Dual Modulus NCO | 0b1 | 0b1 | The main NCO blocks also contain sideband selection controls as well as options for how the FTW and phase offset controls are updated. Calculate the phase offset word control as follows: $$-180^{\circ} \le Degrees \ Offset \le +180^{\circ}$$ Degrees Offset = $180^{\circ} \times (DDSM\ NCO\ PHASE\ OFFSET/2^{15})$ where *DDSM\_NCO\_PHASE\_OFFSET* is a 16-bit twos complement value programmed in the registers listed in Table 45. Table 45. Main Datapath NCO Phase Offset Registers | Address | Value | Description | |---------|------------------------------|------------------------| | 0x11C | DDSM_NCO_PHASE_OFFSET[7:0] | 8 LSBs of phase offset | | 0x11D | DDSM_NCO_PHASE_OFFSET [15:8] | 8 MSBs of phase offset | #### 48-Bit Dual Modulus NCO This modulation mode uses an NCO, a phase shifter, and a complex modulator to modulate the signal by a programmable carrier signal, as shown in Figure 69. This configuration allows output signals to be placed anywhere in the output spectrum up to $\pm f_{NCO}/2$ with very fine frequency resolution. The NCO produces a quadrature carrier to translate the input signal to a new center frequency. A quadrature carrier is a pair of sinusoidal waveforms of the same frequency, offset 90° from each other. The frequency of the quadrature carrier is set via a FTW. The quadrature carrier is mixed with the I and Q data and then summed into the I and Q datapaths, as shown in Figure 69. #### **Integer NCO Mode** The channel 48-bit NCOs can be used as integer NCOs. The FTW for the channel NCOs depends on the speed at which the main NCO block is running ( $f_{DAC}$ ), which is the same rate as the DAC sample rate (12.6 GSPS, maximum) and can be calculated by using the following formula: $f_{DAC} = f_{DATA} \times Channel Interpolation \times Main Interpolation$ The FTWs for each individual channel can be programmed separately and are calculated using the following formula: $$-f_{DAC}/2 \le f_{CARRIER} < +f_{DAC}/2$$ $$DDSM\_FTW = (f_{CARRIER}/f_{DAC}) \times 2^{48}$$ where *DDSM\_FTW* is a 48-bit, twos complement number. The frequency tuning word is set as shown in Table 46. Table 46. Main Datapath NCO FTW Registers | Address | Value | Description | |---------|-----------------|--------------------| | 0x114 | DDSM_FTW[7:0] | 8 LSBs of FTW | | 0x115 | DDSM_FTW[15:8] | Next 8 bits of FTW | | 0x116 | DDSM_FTW[23:16] | Next 8 bits of FTW | | 0x117 | DDSM_FTW[31:24] | Next 8 bits of FTW | | 0x118 | DDSM_FTW[39:32] | Next 8 bits of FTW | | 0x119 | DDSM_FTW[47:40] | 8 MSBs of FTW | Unlike other registers, the FTW registers are not updated immediately upon writing. Instead, the FTW registers update on the rising edge of DDSM\_FTW\_LOAD\_REQ (Register 0x113, Bit 0). After an update request, DDSM\_FTW\_LOAD\_ACK (Register 0x113, Bit 1) must be high to acknowledge that the FTW updated. The DDSM\_SEL\_SIDEBAND bit (Register 0x112, Bit 1 = 0b1) is a convenience bit that can be set to use the lower sideband modulation result, which is equivalent to flipping the sign of the FTW. Figure 74. NCO Modulator Block Diagram # Main Datapath Modulus NCO Mode (Direct Digital Synthesis (DDS)) Each of the main datapath 48-bit NCOs can also be used in a dual modulus mode to create fractional frequencies beyond the 48-bit accuracy. The modulus mode is enabled by programming the DDSM\_MODULUS\_EN bit in the DDSM\_DATAPATH\_ CFG register to 1 (Register 0x112, Bit 2 = 0b1). The frequency ratio for the programmable modulus DDS is very similar to that of the typical accumulator based DDS. The only difference is that N is not required to be a power of two for the programmable modulus, but can be an arbitrary integer. In practice, hardware constraints place limits on the range of values for N. As a result, the modulus extends the use of the NCO to applications that require exact rational frequency synthesis. The underlying function of the programmable modulus technique is to alter the accumulator modulus. Implementation of the programmable modulus function within the AD9172 is such that the fraction, M/N, is expressible by the following equation. Note that the form of the equation implies a compound frequency tuning word with X representing the integer part and A/B representing the fractional part. $$\frac{f_{CARRIER}}{f_{DAC}} = \frac{M}{N} = \frac{X + \frac{A}{B}}{2^{48}}$$ where: *X* is programmed in Register 0x114 to Register 0x119. *A* is programmed in Register 0x12A to Register 0x12F. *B* is programmed in Register 0x124 to Register 0x129. ## **Programmable Modulus Example** Consider the case in which $f_{DAC} = 12$ GHz and the desired value of $f_{CARRIER}$ is 1.2 GHz. This scenario synthesizes an output frequency that is not a power of two submultiple of the sample rate, namely $f_{CARRIER} = (1/10) f_{NCO}$ , which is not possible with a typical accumulator based DDS. The frequency ratio, $f_{CARRIER}/f_{DAC}$ , leads directly to M and N, which are determined by reducing the fraction (1,200,000,000,000/12,000,000,000) to its lowest terms, that is. $$M/N = 1,200,000,000/12,000,000,000 = 1/10$$ Therefore, M = 1 and N = 10. After calculation, X = 28,147,497,671,065, A = 3, and B = 5. Programming these values into the registers for X, A, and B (X is programmed in Register 0x114 to Register 0x119 for DDSM\_FTWx, B is programmed in Register 0x124 to Register 0x129 for DDSM\_ACC\_MODULUSx, and A is programmed in Register 0x12A to Register 0x12F for DDSM\_ACC\_DELTAx) causes the NCO to produce an output frequency of exactly 1.2 GHz given a 12 GHz sampling clock. For more details, refer to the AN-953 Application Note. #### **NCO** Reset Resetting the NCO can be useful when determining the start time and phase of the NCO. The NCO can be reset by several different methods, including via an SPI write or by the SYSREF± signal. ## **Calibration NCO** There is an additional 32-bit calibration NCO option as part of the main DAC NCO block, shown in Figure 66. Register 0x1E6, Bit 0 controls whether the 32-bit calibration NCO is in use in the main datapath, or if the normal 48-bit main NCO is used. First, enable the calibration NCO accumulator by setting Register 0x1E6, Bit 2 = 1. Then, program the calibration NCO FTW in Register 0x1E2 to Register 0x1E5 and update the FTW to take effect by toggling Register 0x113, Bit 0 from 0 to 1. Select the calibration NCO to be used instead of the main NCO by setting Register 0x1E6, Bit 0 = 1 If using the calibration NCO along with the internal dc amplitude level, enable the dc amplitude injection feature by setting Register 0x1E6, Bit 1 = 1. #### **Modulator Switch** The final DAC NCO block has an added functionality of a modulator switch that allows the user to select the desired outputs of the NCO block. There are four mode functionalities available, as shown in Figure 75 to Figure 78. Some modes bypass the main datapath NCO for each DAC and use the complex I and Q data from each datapath, whereas other modes only use the I data output from each of the main datapath NCO blocks and select which DAC is used to output the data. These modes are programmed in Register 0x112, Bits[5:4] and are paged by the MAINDAC\_PAGE register control. Rev. B | Page 60 of 145 ## Ramp Up/Down Gain In each of the main datapaths, the ramp-up and ramp-down gain block is immediately before the digital datapath enters the analog DAC core for decoding. This block works in conjunction with the power detection and protection (PDP) block to protect any downstream components from large power peaks or long, high average power. Various trigger signals can be configured in the PA protection block to trigger a gain ramp-down to mute the data being transmitted out of the DAC, as shown in Figure 71. The ramp-up and ramp-down steps can be configured via the SPI in Register 0x580, Bits[2:0]. The equation for the ramp-up and ramp-down occurs in 32 steps over 2<sup>(CODE+8)</sup> DAC clock periods. This control can be configured individually for each of the DAC ramp blocks via the MAINDAC\_PAGE control in Register 0x008. After the data is ramped down from one of the triggers, it can be ramped back up in two of the following ways after the error condition is cleared. If the SPI protection control bit triggered the interrupt for a ramp-down, the SPI is then also used to ramp the data back up by toggling Register 0x582, Bit 7 from 0 to 1, and then back to 0. Additionally, an option exists to mute the digital data during a digital clock rotation if the ROTATE\_SOFT\_OFF\_EN control in Register 0x581, Bit 2 is set to 1. When this bit is set, the synchronization logic rotation triggers the DAC ramp-down block, rotates the digital clocks, and ramps back up. These actions only occur if Bit 1 of the ROTATION\_MODE control in Register 0x03B is set to 1 to enable a datapath clock rotation when the synchronization logic rotates. ## INTERRUPT REQUEST OPERATION The AD9172 provides an interrupt request output signal ( $\overline{IRQ}$ ) on Ball D9 ( $\overline{IRQ0}$ ) and Ball E9 ( $\overline{IRQ1}$ ) that can be used to notify an external host processor of significant device events. The $\overline{IRQ}$ output can be switched between the $\overline{IRQ0}$ pin or the $\overline{IRQ1}$ pin by setting the corresponding bit for the $\overline{IRQ}$ signal in Register 0x028, Register 0x029, Register 0x02A, and Register 0x02B. Upon assertion of the interrupt, query the device to determine the precise event that occurred. The $\overline{IRQx}$ pins are open-drain, active low outputs. Pull the $\overline{IRQx}$ pins high, external to the device. These pins can be tied to the interrupt pins of other devices with open-drain outputs to wire; OR these pins together. Figure 79 shows a simplified block diagram of how the IRQx blocks works. If IRQ\_EN is low, the INTERRUPT\_SOURCE signal is set to 0. If IRQ\_EN is high, any rising edge of EVENT causes the INTERRUPT\_SOURCE signal to be set high. If any INTERRUPT\_SOURCE signal is high, the IRQx pin is pulled low. INTERRUPT\_SOURCE can be reset to 0 by either an IRQ\_RESET signal or a DEVICE\_RESET signal. Depending on the STATUS\_MODE signal, EVENT\_STATUS reads back an event signal or an INTERRUPT\_SOURCE signal. The AD9172 has several IRQ register blocks that can monitor up to 86 events, depending on the device configuration. Certain details vary by IRQ register block, as described in Table 47. Table 48 shows the source registers of the IRQ\_EN, IRQ\_RESET, and STATUS\_MODE signals in Figure 79, as well as the address where EVENT\_STATUS is read back. Table 47. IRQ Register Block Details | Register Block | Event<br>Reported | EVENT_STATUS | |-----------------------------------|----------------------|------------------------------------------------------------| | 0x020 to 0x27 | Per chip | INTERRUPT_SOURCE if IRQ is enabled; if not, it is an event | | 0x4B8 to 0x4BB;<br>0x470 to 0x473 | Per link and<br>lane | INTERRUPT_SOURCE if IRQ is enabled; if not, 0 | ## INTERRUPT SERVICE ROUTINE Interrupt request management starts by selecting the set of event flags that require host intervention or monitoring. Enable the events that require host action so that the host is notified when they occur. For events requiring host intervention upon $\overline{IRQ}$ activation, run the following routine to clear an interrupt request: - 1. Read the status of the event flag bits that are being monitored. - 2. Disable the interrupt by writing 0 to IRQ\_EN. - 3. Read the event source. - 4. Perform any actions that may be required to clear the cause of the event. In many cases, no specific actions may be required. - 5. Verify that the event source is functioning as expected. - 6. Clear the interrupt by writing 1 to IRQ\_RESET. - 7. Enable the interrupt by writing 1 to IRQ\_EN. Figure 79. Simplified Schematic of IRQx Circuitry Table 48. IRQ Register Block Address of IRQ Signal Details | | | Address of IRQ Signals <sup>1</sup> | | | | | | | | |----------------|----------------------------------|-------------------------------------|---------------------------------|----------------------------|--|--|--|--|--| | Register Block | IRQ_EN | IRQ_RESET | STATUS_MODE | EVENT_STATUS | | | | | | | 0x020 to 0x023 | 0x020 to 0x023; R/W per chip | 0x024 to 0x027; per chip | STATUS_MODE= IRQ_EN | 0x024 to 0x027; R per chip | | | | | | | 0x4B8 to 0x4BB | 0x4B8, 0x4B9; W per error type | 0x4BA, 0x4BB; W per error type | Not applicable, STATUS_MODE = 1 | 0x4BA, 0x4BB; W per chip | | | | | | | 0x470 to 0x473 | 0x470 to 0x473; W per error type | 0x470 to 0x473; W per link | Not applicable, STATUS_MODE = 1 | 0x470 to 0x473; W per link | | | | | | <sup>&</sup>lt;sup>1</sup> R is read, W is write, and R/W is read/write. # APPLICATIONS INFORMATION HARDWARE CONSIDERATIONS ## **Power Supply Recommendations** All the AD9172 supply domains must remain as noise free as possible for the best operation. Power supply noise has a frequency component that affects performance, and is specified in V rms. An LC filter on the output of the power supply is recommended to attenuate the noise, and must be placed as close to the AD9172 as possible. The AVDD1.0 supply, which supplies the clock receiver and DAC analog core circuitry, and the AVDD1.8 supply, which powers the DAC output and DAC PLL blocks, are the most noise sensitive supplies on the device. It is highly recommended that AVDD1.0 and AVDD1.8 be supplied separately with ultralow noise regulators, such as the ADP1763 and ADM7154 or better to achieve the best phase noise performance possible. Noisier regulators impose phase noise onto the DAC output. The DVDD1.0 supply provides power to the digital datapath blocks and the SVDD1.0 supply powers the SERDES circuitry on the chip. The DVDD1.8 supply powers circuitry blocks related to the SPI, SYNCOUTx± transmitter, SYSREF receiver, IRQx, RESET, and TXENx circuitry. Take note of the maximum power consumption numbers shown in Table 4 to ensure the power supply design can tolerate temperature and IC process variation extremes. The amount of current drawn is dependent on the chosen use cases, and specifications are provided for several use cases to illustrate examples and contributions from individual blocks, and to assist in calculating the maximum required current per supply. Another consideration for the power supply design is peak current handling capability. The AD9172 draws more current in the main digital supply when synthesizing a signal with significant amplitude variations, such as a modulated signal, as compared to when in idle mode or synthesizing a dc signal. Therefore, the power supply must be able to supply current quickly to accommodate burst signals such as GSM, TDMA, or other signals that have an on or off time domain response. Because the amount of current variation depends on the signals used, it is best to perform lab testing first to establish ranges. A typical difference can be several hundred milliamperes. #### **Power and Ground Planes** Solid ground planes are recommended to avoid ground loops and to provide a solid, uninterrupted ground reference for the high speed transmission lines that require controlled impedances. It is recommended that power planes be stacked between ground layers for high frequency filtering. Doing so adds extra filtering and isolation between power supply domains in addition to the decoupling capacitors. Do not use segmented power planes as a reference for controlled impedances unless the entire length of the controlled impedance trace traverses across only a single segmented plane. These and additional guidelines for the topology of high speed transmission lines are described in the JESD204B Serial Interface Inputs (SERDIN0± to SERDIN7±) section. For some applications, where highest performance and higher output frequencies are required, the choice of PCB materials significantly impacts results. For example, materials such as polyimide or materials from the Rogers Corporation can be used, for example, to improve tolerance to high temperatures and improve performance. Rogers 4350 material is used for the top three layers in some of the evaluation board designs: between the top signal layer and the ground layer below it. ## JESD204B Serial Interface Inputs (SERDIN0± to SERDIN7±) When considering the layout of the JESD204B serial interface transmission lines, there are many factors to consider to maintain optimal link performance. Among these factors are insertion loss, return loss, signal skew, and the topology of the differential traces. #### **Insertion Loss** The JESD204B specification limits the amount of insertion loss allowed in the transmission channel (see Figure 50). The AD9172 equalization circuitry allows significantly more loss in the channel than is required by the JESD204B specification. It is still important that the designer of the PCB minimize the amount of insertion loss by adhering to the following guidelines: - Keep the differential traces short by placing the AD9172 as close to the transmitting logic device as possible and routing the trace as directly as possible between the devices. - Route the differential pairs on a single plane using a solid ground plane as a reference. It is recommended to route the SERDES lanes on the same layer as the AD9172 to avoid vias being used in the SERDES lanes. - Use a PCB material with a low dielectric constant (<4) to minimize loss, if possible. When choosing between the stripline and microstrip techniques, keep in mind the following considerations: stripline has less loss (see Figure 51 and Figure 52) and emits less EMI, but requires the use of vias that can add complexity to the task of controlling the impedance; whereas microstrip is easier to implement (if the component placement and density allow routing on the top layer) and eases the task of controlling the impedance. If using the top layer of the PCB is problematic or the advantages of stripline are desirable, follow these recommendations: - Minimize the number of vias. - If possible, use blind vias to eliminate via stub effects and use microvias to minimize via inductance. - If using standard vias, use the maximum via length to minimize the stub size. For example, on an 8-layer board, use Layer 7 for the stripline pair (see Figure 80). - For each via pair, place a pair of ground vias adjacent to them to minimize the impedance discontinuity (see Figure 80). Figure 80. Minimizing Stub Effect and Adding Ground Vias for Differential Stripline Traces #### **Return Loss** The JESD204B specification limits the amount of return loss allowed in a converter device and a logic device but does not specify return loss for the channel. However, make every effort to maintain a continuous impedance on the transmission line between the transmitting logic device and the AD9172. Minimizing the use of vias, or eliminating them entirely, reduces one of the primary sources for impedance mismatches on a transmission line (see the Insertion Loss section). Maintain a solid reference beneath (for microstrip) or above and below (for stripline) the differential traces to ensure continuity in the impedance of the transmission line. If the stripline technique is used, follow the guidelines listed in the Insertion Loss section to minimize impedance mismatches and stub effects. Another primary source for impedance mismatch is at either end of the transmission line, where care must be taken to match the impedance of the termination to that of the transmission line. The AD9172 handles this matching internally with a calibrated termination scheme for the receiving end of the line. See the Interface Power-Up and Input Termination section for details on this circuit and the calibration routine. ## Signal Skew There are many sources for signal skew, but the two sources to consider when laying out a PCB are interconnect skew within a single JESD204B link and skew between multiple JESD204B links. In each case, keeping the channel lengths matched to within 10 mm (calculated by 12.5 mm $\times$ (12.5 Gbps/15 Gbps)) is adequate for operating the JESD204B link at speeds of up to 15 Gbps. This amount of channel length match is equivalent to about 85% UI on the AD9172 evaluation board. Managing the interconnect skew within a single link is straightforward. Managing multiple links across multiple devices is more complex. However, follow the 10 mm guideline for length matching. The AD9172 can handle more skew than the 85% UI due to the 6 PCLK buffer in the JESD204B receiver, but matching the channel lengths as close as possible is still recommended. ## Topology Structure the differential SERDINx $\pm$ pairs to achieve 50 $\Omega$ to ground for each half of the pair. Stripline vs. microstrip tradeoffs are described in the Insertion Loss section. In either case, it is important to keep these transmission lines separated from potential noise sources, such as high speed digital signals and noisy supplies. If using stripline differential traces, route them using a coplanar method, with both traces on the same layer. Although this method does not offer more noise immunity than the broadside routing method (traces routed on adjacent layers), it is easier to route and manufacture so that the impedance continuity is maintained. Broadside vs. coplanar differential Tx lines are shown in Figure 81. Figure 81. Broadside vs. Coplanar Differential Stripline Routing Techniques When considering the trace width vs. copper weight and thickness, the speed of the interface must be considered. At multigigabit speeds, the skin effect of the conducting material confines the current flow to the surface. Maximize the surface area of the conductor by making the trace width wider to reduce the losses. Additionally, loosely couple differential traces to accommodate the wider trace widths. This coupling helps reduce the crosstalk and minimize the impedance mismatch when the traces must separate to accommodate components, vias, connectors, or other routing obstacles. Tightly coupled vs. loosely coupled differential traces are shown in Figure 82. Figure 82. Tightly Coupled vs. Loosely Coupled Differential Traces ## **AC Coupling Capacitors** The AD9172 requires that the JESD204B input signals be ac-coupled to the source. These capacitors must be 100 nF and placed as close as possible to the transmitting logic device. To minimize the impedance mismatch at the pads, select the package size of the capacitor so that the pad size on the PCB matches the trace width as closely as possible. ## SYNCOUT±, SYSREF±, and CLK± Signals The SYSREF± signal on the AD9172 is a low speed, LVDS, differential signal. The SYNCOUTx± signals are LVDS or CMOS selectable. When LVDS mode is selected, use controlled impedance traces routed as 100 $\Omega$ differential impedance and 50 $\Omega$ to ground when routing these signals. As with the SERDIN0± to SERDIN7± data pairs, it is important to keep these signals separated from potential noise sources, such as high speed digital signals and noisy supplies. Separate the SYNCOUTx± signal from other noisy signals because noise on the SYNCOUTx± may be interpreted as a request for /K/ characters. It is important to keep similar trace lengths for the CLK± and SYSREF± signals from the clock source to each of the devices on either end of the JESD204B links (see Figure 83). If using a clock chip that can tightly control the phase of CLK± and SYSREF±, the trace length matching requirements are greatly reduced. Figure 83. SYSREF± Signal and Device Clock Trace Length # ANALOG INTERFACE CONSIDERATIONS DAC INPUT CLOCK CONFIGURATIONS The AD9172 DAC sample clock or device clock (DACCLK) can be sourced directly through CLKIN± (Pin H12 and Pin J12) or by using the on-chip, integrated, integer PLL VCO with the same CLKIN± differential input serving as the reference. Clock multiplying employs the on-chip DAC PLL that accepts a reference clock operating at a submultiple of the desired DACCLK rate. The PLL then multiplies the reference clock up to the desired DACCLK frequency, which generates all the clocks within the AD9172, as shown in Figure 86. The AD9172 contains a low jitter, differential clock receiver that is capable of interfacing directly to a differential or single-ended clock source. Because the input is self biased with a nominal impedance of 100 $\Omega$ , it is recommended that the clock source be ac-coupled to the CLKIN± input pins. Improved phase noise performance can be achieved with a higher clock input level. The quality of the clock source, as well as its interface to the AD9172 clock input, directly impacts ac performance. Select the phase noise and spur characteristics of the clock source to meet the target application requirements. Figure 84. Clock Receiver Input Simplified Equivalent Circuit Figure 85. Phase Noise vs. Frequency Offset; Direct Clock and PLL Phase Noise, 12 GHz DAC Sample Rate, 1.65 GHz Output Frequency ## **DAC On-Chip PLL** When using the on-chip PLL, the predivider setting is selected (via Register 0x793, Bits[1:0]) to divide the clock receiver frequency internally to be within the range of 25 MHz to 770 MHz for the phase frequency detector (PFD) circuitry block input. The AD9172 DAC VCO operates over a frequency range of 8.74 GHz to 12.4 GHz. Enable the DAC PLL synthesizer by setting Register 0x095, Bit 0 to 0. The DAC clock rate is user configurable to be the VCO frequency (8.74 GHz to 12.4 GHz), the VCO frequency divided by 2 (4.37 GHz to 6.2 GHz), or the VCO frequency divided by 3 (2.92 GHz to 4.1 GHz) by setting Register 0x094, Bits[1:0]. See the Startup sequence section for instructions on how to program the PLL. The AD9172 DAC PLL requires an external loop filter. The recommended filter is a standard passive filter, as shown in Figure 86. The user can customize the filter according to the PFD frequency, reference clock phase noise, and DAC output phase noise requirements. For lowest jitter applications, use the highest possible PFD frequency to minimize the contribution of in-band noise from the PLL. However, when operating with a VCO frequency from 9.96 GHz to 10.87 GHz, set the PFD frequency to less than 225 MHz to ensure optimized stability over temperature. Set the PLL filter bandwidth such that the in-band noise of the PLL intersects with the open-loop noise of the VCO, minimizing the contribution of both to the overall noise. The DAC PLL uses an integer type synthesizer to achieve the DAC sampling clock. The relation between DAC clock and the reference clock is as follows: $$f_{DAC} = (8 \times N \times f_{REF})/M/(Register\ 0x094,\ Bits[1:0] + 1)$$ where: $f_{DAC}$ is the desired DAC clock rate. N is the VCO feedback divider ratio, ranging from 2 to 50. $f_{REF}$ is the reference clock. *M* is the reference clock divider ratio; the valid values for reference clock divider (predivider) are 1, 2, 3, or 4 by setting Register 0x793, Bits[1:0]. The VCO automatic calibration is triggered by the falling edge of Register 0x792, Bit 1 transitioning from a logic high to logic low. A lock detector bit (Register 0x7B5, Bit 0) is provided to indicate that the DAC PLL achieved lock. If Register 0x7B5, Bit 0 = 1, the PLL has locked. Figure 86. DAC PLL and Clock Path Block Diagram ## **CLOCK OUTPUT DRIVER** The AD9172 is capable of generating and outputting a high performance divide down clock that can be used to clock a companion analog-to-digital converter (ADC). The integer clock divider supports divide ratios 1, 2, 3, and 4 and can be programmed by Register 0x799, Bits[7:6] to set the desired output frequency. The output frequency ranges from 727.5 MHz to 3 GHz. #### **ANALOG OUTPUTS** The AD9172 provides complementary current outputs, DAC0 $\pm$ and DAC1 $\pm$ . Figure 87 shows an equivalent output circuit for the DAC. The AD9172 features an internal 100 $\Omega$ termination resistor (R<sub>INT</sub>) that eliminates the need to terminate the DAC current output externally on the PCB board. Two RF chokes, one for each DAC output leg, are required to provide a dc current path for the DAC output. The value of the choke depends on the desired output frequency range. In general, a larger choke provides a lower cutoff output frequency. A 2:1 balun is recommended to transform the differential DAC output to a single-ended signal. $I_{\rm OUTFS}$ is the full-scale current of each of the two DAC outputs. It is an 8-bit value stored in Register 0x05A. The full-scale current of the DAC is typically 19.531 mA. The DAC full-scale current can be adjusted from 15.625 mA to 25.977 mA by programming the appropriate value in Register 0x05A. $$I_{OUTFS} = 15.625 \text{ mA} + FSC\_CTRL \times (25/256) \text{ (mA)}$$ The example shown in Figure 87 can be modeled as a pair of dc current sources that source half of the I<sub>OUTES</sub> current to each output. This differential ac current source models the signal (that is, a digital code) dependent nature of the DAC output. The ac differential current measured at DACx+ and DACx- is as follows: $I_{AC\_DIFF}$ (mA) = $DACCODE/DACCODEMAX \times I_{OUTFS} \times R_{INT}(R_{LOAD} + R_{INT})$ where: DACCODE = 0 to 65,535 (decimal). *R*<sub>LOAD</sub> is the load impedance seen on DACx+ and DACx-. Figure 87. Equivalent DAC Output Circuit and Recommended DAC Output Network # START-UP SEQUENCE Several steps are required to program the AD9172 to the proper operating state after the device is powered up. This sequence is divided into several steps, and is listed in Table 49 to Table 58, along with an explanation of the purpose of each step. Private registers are reserved but must be written for proper operation. Blank cells or cells with a variable or bit field name (in all capital letters) in Table 49 to Table 58 indicate that the value depends on the result as described in the Description column. Table 49. Power-Up and Required Register Writes | R/W | Register | Bits | Value | Description | |-----|----------|-------|-------|-----------------------------------------------------------------------------------------| | W | 0x000 | [7:0] | 0x81 | Soft reset. | | W | 0x000 | [7:0] | 0x3C | Release reset and set to 4-wire SPI (optional; leave at the default of the 3-wire SPI). | | W | 0x091 | [7:0] | 0x00 | Power up clock receiver. | | W | 0x206 | [7:0] | 0x01 | Take PHYs out of reset. | | W | 0x705 | [7:0] | 0x01 | Enable boot loader. | | W | 0x090 | [7:0] | 0x00 | Power on DACs and bias circuitry. | **Table 50. DAC PLL Configuration** | R/W | Register | Bits | Value | Description | |-----|----------------|-------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | W | 0x095 [7:0] 0x | | [7:0] 0x00 or 0x01 | Bypass PLL. Set to 0x00 to use internal DAC PLL. If the user plans to supply the DAC clock directly, set this register to 0x01 and execute the following two register writes; then, skip the remaining writes in this table. | | W | 0x790 | [7:0] | 0xFF or 0x00 | Write this register to 0xFF if bypassing the PLL (Register $0x095 = 0x01$ ). If using the PLL, write this register to $0x00$ . | | W | 0x791 | [7:0] | 0x1F or 0x00 | Write this register to $0xFF$ if bypassing the PLL (Register $0x095 = 0x01$ ) and then skip the remaining register writes in this table and continue to Table 51. If using the PLL, write this register to $0x00$ as well as the remainder of the register writes in this table. | | W | 0x796 | [7:0] | 0xE5 | DAC PLL required write. | | W | 0x7A0 | [7:0] | 0xBC | DAC PLL required write. | | W | 0x794 | [5:0] | DACPLL_CP | Set DAC PLL charge pump current. The recommended setting is 0x08, but can range from 0x04 to 0x10 for different phase noise performance targets. | | W | 0x797 | [7:0] | 0x10 | DAC PLL required write. | | W | 0x797 | [7:0] | 0x20 | DAC PLL required write. | | W | 0x798 | [7:0] | 0x10 | DAC PLL required write. | | W | 0x7A2 | [7:0] | 0x7F | DAC PLL required write. | | | Pause | | | Wait 100 ms. | | W | 0x799 | | | DAC PLL divider settings. | | | | [7:6] | ADC_CLK_DIVIDER | ADC driver/clock output divide ratio. | | | | | | $0b00 = \div 1.$ | | | | | | $0b01 = \div 2.$ | | | | | | $0b10 = \div 3.$ | | | | | | 0b11 = ÷4. | | | | [5:0] | N_DIVIDER | Programmable N divider. N_DIVIDER = $(f_{DAC} \times M_DIVIDER)/(8 \times reference clock)$ . | | W | 0x793 | | | DAC PLL divider settings. | | | | [7:2] | 0x06 | Keep default value for these bits. | | | | [1:0] | M_DIVIDER-1 | Programmable predivider M_DIVIDER-1 (in n – 1 notation). The relevant calculation is as follows: PFD Frequency = reference clock/M_DIVIDER, where 25 MHz $\leq$ PFD frequency $\leq$ 770 MHz. | | | | | | If 9.96 GHz $\leq$ PLL VCO frequency $\leq$ 10.87 GHz, must keep 25 MHz $\leq$ PFD frequency $\leq$ 225 MHz. | | | | | | $0b00 = \div 1.$ | | | | | | $0b01 = \div 2.$ | | | | | | $0b10 = \div 3.$ | | | | | | 0b11 = ÷4. | | R/W | Register | Bits | Value | Description | |-----|----------|-----------------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | W | 0x094 | [7:2] | 0x00 | Keep default value for these bits. | | | | 1 PLL_VCO_DIV3_EN Enable PLL output clock to be div | | Enable PLL output clock to be divided by 3. If this bit is set to 1, DAC clock = PLL VCO frequency/3. | | | | 0 | PLL_VCO_DIV2_EN | Enable PLL output clock to be divided by 2. Either this bit or Bit 1 in this register can be set to 1, but both bits cannot be set at the same time (there is no divide by 6 option). | | | | | | 0b0: DAC clock = PLL VCO frequency. | | | | | | 0b1: DAC clock = PLL VCO frequency/2. | | W | 0x792 | [7:0] | 0x02 | Reset VCO. | | W | 0x792 | [7:0] | 0x00 | | | | Pause | | | Wait 100 ms for PLL to lock. | | R | 0x7B5 | 0 | 0b1 | Ensure PLL is locked by reading back a value of 1 for bit 0 of this register. | ## Table 51. Delay Lock Loop (DLL) Configuration | R/W | Register | Bits | Value | Description | |-----|----------|-------|--------------|------------------------------------------------------------------------------------------------------------------| | W | 0x0C0 | [7:0] | 0x00 | Power-up delay line. | | W | 0x0DB | [7:0] | 0x00 | | | W | 0x0DB | [7:0] | 0x01 | Update DLL settings to circuitry. | | W | 0x0DB | [7:0] | 0x00 | | | W | 0x0C1 | [7:0] | 0x68 or 0x48 | Set DLL search mode. If $f_{DAC}$ is < 4.5 GHz, set this register to 0x48. Otherwise, set this register to 0x68. | | W | 0x0C1 | [7:0] | 0x69 or 0x49 | Set DLL search mode. If $f_{DAC}$ is < 4.5 GHz, set this register to 0x49. Otherwise, set this register to 0x69. | | W | 0x0C7 | [7:0] | 0x01 | Enable DLL read status. | | R | 0x0C3 | 0 | 0b1 | Ensure DLL is locked by reading back a value of 1 for Bit 0 of this register. | ## **Table 52. Calibration** | R/W | Register | Bits | Value | Description | |-----|----------|-------|-------|-----------------------------------------------| | W | 0x050 | [7:0] | 0x2A | Optimized calibration setting register write. | | W | 0x061 | [7:0] | 0x68 | Required calibration control register write. | | W | 0x051 | [7:0] | 0x82 | Optimized calibration setting register write. | | W | 0x051 | [7:0] | 0x83 | Required calibration control register write. | | W | 0x081 | [7:0] | 0x03 | Required calibration control register write. | ## Table 53. JESD204B Mode Setup | R/W | Register | Bits | Value | Description | |-----|----------|-------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | W | 0x100 | [7:0] | 0x00 | Power up digital datapath clocks when internal clocks are stable. | | W | 0x110 | [5:0] | JESD_MODE | Bit 5 of the JESD_MODE bit field determines whether the device is operating in single link or dual link modes. 0 = single-link mode; 1 = dual-link mode. Bits[4:0] determine the SERDES JESD204B mode of operation chosen from the appropriate single-link or dual-link modes in Table 15 or Table 16. | | W | 0x111 | [7:4] | DP_INTERP_MODE | Main datapath interpolation mode. The valid interpolation options for this control is based on the JESD_MODE selected in Register 0x110. Bit 7 of Register 0x110 equals 1 if the JESD_MODE, DP_INTERP_MODE, and CH_INTERP_MODE settings are not a valid combination. | | | | [3:0] | CH_INTERP_MODE | Channel datapath interpolation mode. The valid interpolation options for this control is based on the JESD_MODE selected in Register 0x110. Bit 7 of Register 0x110 equals 1 if the JESD_MODE, DP_INTERP_MODE, and CH_INTERP_MODE settings are not a valid combination. | | W | 0x084 | 6 | SYSREF_INPUTMODE | SYSREF± signal input mode selection. | | | | | | 0b0 = ac-coupled. | | | | | | 0b1 = dc-coupled. | | | | 0 | SYSREF_PD | If using Subclass 0, this bit can be set to 1 to power down the SYSREF± receiver. If using Subclass 1, keep at the default of 0. | | W | 0x312 | [7:4] | | Set SYNCOUTx± error duration, depending on the selected mode. | | R/W | Register | Bits | Value | Description | |-----|----------|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------| | W | 0x300 | 3 | LINK_MODE | Corresponds to the mode selection made in Register 0x110. | | | | | | 0b0 = single-link mode. | | | | | | 0b1 = dual-link mode. | | | | 2 | 0b0 | Select Link 0 for setup. This bit selects the link QBD being paged. | | | | | | 0b0 = Link 0 (QBD0). | | | | | | 0b1 = Link 1 (QBD1). | | | | [1:0] | LINK_EN | Enables the links. | | | | | | 0b01 = single-link mode. | | | | | | 0b11 = dual link mode. | | W | 0x475 | [7:0] | 0x09 | Soft reset the JESD204B quad-byte deframer. | | W | 0x453 | 7 | SCR | Set scrambling option for SERDES data. | | | | | | 0 = disable scrambling. | | | | | | 1 = enable scrambling. | | | | [4:0] | L-1 | Write the L value (in $n-1$ notation) for the selected JESD_MODE. | | W | 0x458 | [7:5] | SUBCLASSV | For Subclass 0, set this bit to 0. For Subclass 1, set this bit to 1. | | | | [4:0] | NP-1 | Write the NP value (in $n-1$ notation) for the selected JESD_MODE. | | W | 0x475 | [7:0] | 0x01 | Bring the JESD204B quad-byte deframer out of reset. | | W | 0x300 | | | If running in dual link mode, repeat writes for Link 1 as follows. If running in single-link mode, skip the remaining steps in this table. | | | | 3 | LINK_MODE | Corresponds to the mode selection made in Register 0x110. | | | | | | 0b0 = single-link mode. | | | | | | 0b1 = dual link mode. | | | | 2 | 0b1 | Select Link 1 for setup. This bit selects which link QBD is being paged. | | | | | | 0b0 = Link 0 (QBD0). | | | | | | 0b1 = Link 1 (QBD1). | | | | [1:0] | 0b00 | Keep links disabled until end of routine. | | W | 0x475 | [7:0] | 0x09 | Soft reset the JESD204B quad-byte deframer. | | W | 0x453 | 7 | SCR | Set scrambling option for SERDES data. | | | | | | 0 = disable scrambling. | | | | | | 1 = enable scrambling. | | W | 0x458 | [4:0] | L-1 | Write the L value (in n – 1 notation) for the selected JESD_MODE. | | | | [7:5] | SUBCLASSV | For Subclass 0, set this bit to 0. For Subclass 1, set this bit to 1. | | | | [4:0] | NP-1 | Write the NP value (in $n-1$ notation) for the selected JESD_MODE. | | W | 0x475 | [7:0] | 0x01 | Bring the JESD204B quad-byte deframer out of reset. | | | | • | | · | Table 54 lists optional registers to configure the channel datapaths if they are being configured for a specific application. If the channel datapaths are bypassed (CH\_INTERP\_MODE = 1 for $1 \times$ channel interpolation), Table 54 can be skipped in the start-up sequence. Table 54. Channel Datapath Setup: Digital Gain and Channel NCOs | R/W | Register | Bits | Value | Description | |-----|----------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | W | 0x008 | [5:0] | | CHANNEL_PAGE. Select the channels to be programmed at the same time (or repeat this block for each channel to independently program values). Bit x of this control corresponds to the Channel x datapath. | | W | 0x146 | [7:0] | | CHNL_GAIN[7:0]. Write LSBs of channel digital gain. Configure digital gain for selected channels in Paging Register 0x008. Calculation: CHNL_GAIN = $2^{11} \times 10$ (dBGain/20) where dBGain is the gain value in dB for the channel gain desired. | | W | 0x147 | [7:0] | | CHNL_GAIN[11:8]. Write MSBs of channel digital gain. Calculations shown in Register 0x146. | | W | 0x130 | 6 | | Enable NCO for selected channels in paging Register 0x008. | | | | | | 0b0 = disable NCO. | | | | | | 0b1 = enable NCO. | | | | 2 | | Enable NCO modulus for selected channels in paging Register 0x008. | | | | | | 0b0 = disable NCO modulus. | | | | | | 0b1 = enable NCO modulus. | | | | 1 | | Select sideband from modulation result. | | | | | | 0b0 = upper sideband. | | | | | | 0b1 = lower sideband (spectral flip). | | | | 0 | | If dc test mode or NCO test mode is desired, set this bit to 1 to enable the test tone generation. Otherwise, set this bit to the default value of 0. | | | | | | Integer NCO mode calculation: DDSC_FTW = $(f_{CARRIER}/f_{NCO}) \times 2^{48}$ , where $f_{NCO} = f_{DATA}/CH_INTERP_MODE$ . | | W | 0x132 | [7:0] | | Write DDSC_FTW[7:0]. | | W | 0x133 | [7:0] | | Write DDSC_FTW[15:8]. | | W | 0x134 | [7:0] | | Write DDSC_FTW[23:16]. | | W | 0x135 | [7:0] | | Write DDSC_FTW[31:24]. | | W | 0x136 | [7:0] | | Write DDSC_FTW[39:32]. | | W | 0x137 | [7:0] | | Write DDSC_FTW[47:40]. | | W | 0x138 | [7:0] | | Write DDSC_NCO_PHASE_OFFSET[7:0]. Calculation: DDSC_NCO_PHASE_OFFSET = (Degrees Offset/180) $\times$ 2 <sup>15</sup> . | | W | 0x139 | [7:0] | | Write DDSC_NCO_PHASE_OFFSET[15:8]. | | | | | | If using NCO modulus mode, also program modulus parameters. If not, skip this section. For modulus NCO mode: $(f_{CARRIER}/f_{NCO}) = (X + (A/B))/2^{48}$ where DDSC_ACC_DELTA = A, DDSC_ACC_MODULUS = B, and DDSC_FTW = X. | | W | 0x13A | [7:0] | | Write DDSC_ACC_MODULUS[7:0]. | | W | 0x13B | [7:0] | | Write DDSC_ACC_MODULUS[15:8]. | | W | 0x13C | [7:0] | | Write DDSC_ACC_MODULUS[23:16]. | | W | 0x13D | [7:0] | | Write DDSC_ACC_MODULUS[31:24]. | | W | 0x13E | [7:0] | | Write DDSC_ACC_MODULUS[39:32]. | | W | 0x13F | [7:0] | | Write DDSC_ACC_MODULUS[47:40]. | | W | 0x140 | [7:0] | | Write DDSC_ACC_DELTA[7:0]. | | W | 0x141 | [7:0] | | Write DDSC_ACC_DELTA[15:8]. | | W | 0x142 | [7:0] | | Write DDSC_ACC_DELTA[23:16]. | | W | 0x143 | [7:0] | | Write DDSC_ACC_DELTA[31:24]. | | W | 0x144 | [7:0] | | Write DDSC_ACC_DELTA[39:32]. | | W | 0x145 | [7:0] | | Write DDSC_ACC_DELTA[47:40]. | | W | 0x131 | 0 | 0b1 | Update all NCO phase and FTW words. | Table 55 lists optional registers to configure the main DAC datapaths if they are being configured for a specific application. If the main DAC datapaths are bypassed (DP\_INTERP\_MODE = $1 \text{ for } 1 \times \text{ channel interpolation}$ ), Table 55 can be skipped in the start-up sequence. Table 55. Main DAC Datapath Setup: PA Protect and Main NCOs | R/W | Register | Bits | Value | Description | |-----|----------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | W | 0x008 | [7:6] | | MAINDAC_PAGE. Select the main DAC datapath to be programmed at the same time (or repeat this block for each DAC datapath to independently program values). Bit x of this control corresponds to the DAC x datapath. | | W | 0x112 | 3 | | Enable NCO for selected channels in paging Register 0x008. | | | | | | 0b0 = disable NCO. | | | | | | 0b1 = enable NCO. | | | | 2 | | Enable NCO modulus for selected channels in paging Register 0x008. | | | | | | 0b0 = disable NCO modulus. | | | | | | 0b1 = enable NCO modulus. | | | | 1 | | Select sideband from modulation result. | | | | | | 0b0 = upper sideband. | | | | | | 0b1 = lower sideband (spectral flip). | | | | 0 | | Set this bit to 0. | | | | | | Integer NCO mode calculation: DDSM_FTW = $(f_{CARRIER}/f_{DAC}) \times 2^{48}$ . | | W | 0x114 | [7:0] | | Write DDSM_FTW[7:0]. | | W | 0x115 | [7:0] | | Write DDSM_FTW[15:8]. | | W | 0x116 | [7:0] | | Write DDSM_FTW[23:16]. | | W | 0x117 | [7:0] | | Write DDSM_FTW[31:24]. | | W | 0x118 | [7:0] | | Write DDSM_FTW[39:32]. | | W | 0x119 | [7:0] | | Write DDSM_FTW[47:40]. | | W | 0x11C | [7:0] | | Write DDSM_NCO_PHASE_OFFSET[7:0]. Calculation: DDSM_NCO_PHASE_OFFSET = $(\text{degrees offset/180}) \times 2^{15}$ . | | W | 0x11D | [7:0] | | Write DDSM_NCO_PHASE_OFFSET[15:8]. | | | | | | If using NCO modulus mode, also program modulus parameters. If not, skip this section. For modulus NCO mode: $(f_{CARRIER}/f_{DAC}) = (X + (A/B))/2^{48}$ , where DDSM_ACC_DELTA = A, DDSM_ACC_MODULUS = B, and DDSM_FTW = X. | | W | 0x124 | [7:0] | | Write DDSM_ACC_MODULUS[7:0]. | | W | 0x125 | [7:0] | | Write DDSM_ACC_MODULUS[15:8]. | | W | 0x126 | [7:0] | | Write DDSM_ACC_MODULUS[23:16]. | | W | 0x127 | [7:0] | | Write DDSM_ACC_MODULUS[31:24]. | | W | 0x128 | [7:0] | | Write DDSM_ACC_MODULUS[39:32]. | | W | 0x129 | [7:0] | | Write DDSM_ACC_MODULUS[47:40]. | | W | 0x12A | [7:0] | | Write DDSM_ACC_DELTA[7:0]. | | W | 0x12B | [7:0] | | Write DDSM_ACC_DELTA[15:8]. | | W | 0x12C | [7:0] | | Write DDSM_ACC_DELTA[23:16]. | | W | 0x12D | [7:0] | | Write DDSM_ACC_DELTA[31:24]. | | W | 0x12E | [7:0] | | Write DDSM_ACC_DELTA[39:32]. | | W | 0x12F | [7:0] | | Write DDSM_ACC_DELTA[47:40]. | | W | 0x113 | 0 | 0b1 | Update all NCO phase and FTW words. | Table 56. JESD204B SERDES Required Interface Setup | R/W | Register | Bits | Value | Description | |-----|----------------|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------| | W | 0x240 | [7:0] | 0xAA or | EQ settings determined by amount of insertion loss according to Table 22. For insertion loss ≤ | | | | | 0xFF | 11 dB, set to 0xAA; otherwise, set to 0xFF. | | W | 0x241 | [7:0] | 0xAA or | EQ settings determined by amount of insertion loss according to Table 22. For insertion loss ≤ | | | | | 0xFF | 11 dB, set to 0xAA; otherwise, set to 0xFF. | | W | 0x242 | [7:0] | 0x55 or<br>0xFF | EQ settings determined by amount of insertion loss according to Table 22. For insertion loss ≤ 11 dB, set to 0x55; otherwise, set to 0xFF. | | W | 0x243 | [7:0] | 0x55 or<br>0xFF | EQ settings determined by amount of insertion loss according to Table 22. For insertion loss ≤ 11 dB, set to 0x55; otherwise, set to 0xFF. | | W | 0x244 | [7:0] | 0x1F | EQ settings. | | W | 0x245 | [7:0] | 0x1F | EQ settings. | | W | 0x246 | [7:0] | 0x1F | EQ settings. | | W | 0x247 | [7:0] | 0x1F | EQ settings. | | W | 0x248 | [7:0] | 0x1F | EQ settings. | | W | 0x249 | [7:0] | 0x1F | EQ settings. | | W | 0x24A | [7:0] | 0x1F | EQ settings. | | W | 0x24B | [7:0] | 0x1F | EQ settings. | | W | 0x201 | [7:0] | | Power down unused PHYs. Bit x corresponds to SERDINx± pin power-down. | | W | 0x203 | | | If in single-link mode, set to 0x01. If in dual-link mode and using both SYNCOUTx± signals, set to 0x00. | | | | 1 | 0b0 | Power up SYNCOUT0± driver by setting this bit to 0. | | | | 0 | | Power up SYNCOUT1± driver by setting this bit to 0 if using dual link and both SYNCOUTx± signals. | | W | 0x253 | [7:0] | 0x01 | Set SYNCOUT0± to be LVDS output. For CMOS output on SYNCOUT0+, set Bit 0 to 0. | | W | 0x254 | [7:0] | 0x01 | Set SYNCOUT1± to be LVDS output. For CMOS output on SYNCOUT1+, set Bit 0 to 0. | | W | 0x210 | [7:0] | 0x16 | SERDES required register write. | | W | 0x216 | [7:0] | 0x05 | SERDES required register write. | | W | 0x210 | [7:0] | 0xFF | SERDES required register write. | | W | 0x212<br>0x212 | [7:0] | 0x00 | SERDES required register write. | | W | 0x212<br>0x210 | [7:0] | 0x87 | SERDES required register write. | | W | 0x216 | [7:0] | 0x11 | SERDES required register write. | | W | 0x210 | [7:0] | 0x01 | SERDES required register write. | | W | 0x213 | [7:0] | 0x00 | SERDES required register write. | | W | 0x213 | [7:0] | 0x00 | Power up the SERDES circuitry blocks. | | VV | Pause | [7.0] | 0,000 | Wait 100 ms. | | W | 0x210 | [7:0] | 0x86 | SERDES required register write. | | W | 0x216 | [7:0] | 0x40 | SERDES required register write. | | W | 0x213 | [7:0] | | SERDES required register write. | | W | 0x213 | [7:0] | 0x00 | SERDES required register write. | | W | 0x210 | [7:0] | 0x86 | SERDES required register write. | | W | 0x216 | [7:0] | 0x00 | SERDES required register write. | | W | 0x210 | [7:0] | 0x01 | SERDES required register write. | | W | 0x213 | [7:0] | 0x00 | SERDES required register write. | | W | 0x210 | [7:0] | 0x87 | SERDES required register write. | | W | 0x216 | [7:0] | 0x01 | SERDES required register write. | | W | 0x210 | [7:0] | 0x01 | SERDES required register write. | | W | 0x213 | [7:0] | 0x00 | SERDES required register write. | | W | 0x213 | [7:0] | 0x05 | SERDES required register write. | | * V | | | | | | W | 0x280 | [7:0] | 0x01 | Start up SERDES PLL circuitry blocks and initiate SERDES PLL calibration. | Crossbar mapping writes the SERDINx input pin that is the source for each given logical lane in these registers. A value of x corresponds to mapping data from the SERDINx± pin to the logical lane of the control bit field. These values in Table 57 vary with different PCB layout routing. Table 57. Transport Layer Setup, Synchronization, and Enable Links | R/W | Register | Bits | Value | Description | |-----|----------|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | W | 0x308 | [7:0] | | Crossbar setup. Program the physical lane value that is providing data (the source) for each of the logical lanes. [5:3] = Logical Lane 1 source, [2:0] = Logical Lane 0 source. | | W | 0x309 | [7:0] | | [5:3] = Logical Lane 3 source, [2:0] = Logical Lane 2 source. | | W | 0x30A | [7:0] | | [5:3] = Logical Lane 5 source, [2:0] = Logical Lane 4 source. | | W | 0x30B | [7:0] | | [5:3] = Logical Lane 7 source, [2:0] = Logical Lane 6 source. | | W | 0x306 | [7:0] | 0x0C | If operating in Subclass 0, this register write is not needed. | | W | 0x307 | [7:0] | 0x0C | If operating in Subclass 0, this register write is not needed. | | W | 0x304 | [7:0] | | If operating in Subclass 0, this register write is not needed. For Subclass 1, these values must be determined by following one of the deterministic latency methods (with or without known delays), as mentioned in the Link Delay section. | | W | 0x305 | [7:0] | | If operating in Subclass 0, this register write is not needed. For Subclass 1, these values must be determined by following one of the deterministic latency methods (with or without known delays), as mentioned in the Link Delay section. | | W | 0x03B | [7:0] | 0xF1 | Enable the sync logic, and set the rotation mode to reset the synchronization logic upon a sync reset trigger. | | W | 0x03A | [7:0] | 0x02 | Set up sync for one-shot sync mode. | | | SYSREF± | | | If operating in Subclass 1, send SYSREF± pulse edges to the device for synchronization alignment. | | W | 0x300 | 3 | LINK_MODE | Corresponds to the mode selection made in Register 0x110. | | | | | | 0b0 = single-link mode. | | | | | | 0b1 = dual-link mode. | | | | 2 | 0b0 | Select Link 0 for setup. This bit selects which link QBD is being paged. | | | | | | 0b0 = Link 0 (QBD0). | | | | | | 0b1 = Link 1 (QBD1). | | | | [1:0] | LINK_EN | Enables the links. | | | | | | 0b01 = single-link mode | | | | | | 0b11 = dual-link mode. | Table 58. Cleanup Registers | R/W | Register | Bits | Value | Description | |-----|----------|-------|-------|----------------------------------------------------------------------------| | W | 0x085 | [7:0] | 0x13 | Set to the default register value. | | W | 0x1DE | [7:0] | 0x00 | Disable analog SPI. To debug and continue readback capability, write 0x03. | | W | 0x008 | [7:0] | 0xC0 | Page all main DACs for TXEN control update. | | W | 0x596 | [7:0] | 0x0C | SPI turn on TXENx feature. | ## **REGISTER SUMMARY** Table 59. Register Summary | 0x000 | Name<br>SPI_INTFCONFA | Bit 7 SOFTRESET_ | Bit 6<br>LSBFIRST M | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset | RW | |-------|-----------------------|-----------------------|---------------------|-------------------------|-----------------------------|-------------------------------------|---------------------------------|-----------------------------|------------------------|--------------|-------| | | SPI_INTFCONFA | SOFTRESET | | | | | | | | | | | | | M | | ADDRINC_M | SDOACTIVE_M | SDOACTIVE | ADDRINC | LSBFIRST | SOFTRESET | 0x00 | R/W | | 0x001 | SPI_INTFCONFB | SINGLEINS | CSSTALL | | | RESERVE | D | | | 0x00 | R/W | | 0x003 | SPI_CHIPTYPE | | | | CHIP_TYP | PΕ | | | | 0x04 | R | | 0x004 | SPI_PRODIDL | | | | PROD_ID[7 | 7:0] | | | | 0x72 | R | | 0x005 | SPI_PRODIDH | | | | PROD_ID[1: | 5:8] | | | | 0x91 | R | | 0x006 | SPI_CHIPGRADE | | PROE | D_GRADE | | | DEV_F | REVISION | | 0x04 | R | | 0x008 | SPI_PAGEINDX | MAINDA | AC_PAGE | | | CHANNEL_ | PAGE | | | 0xFF | R/W | | 0x00A | SPI_<br>SCRATCHPAD | | | | SCRATCHP. | AD | | | | 0x00 | R/W | | 0x010 | CHIP_ID_L | | | | CHIP_ID[7: | :0] | | | | 0x00 | R | | 0x011 | CHIP_ID_M1 | | | | CHIP_ID[15 | 5:8] | | | | 0x00 | R | | 0x012 | CHIP_ID_M2 | | | | CHIP_ID[23: | :16] | | | | 0x00 | R | | 0x013 | CHIP_ID_H | | | | CHIP_ID[31 | :24] | | | | 0x00 | R | | 0x020 | IRQ_ENABLE | | RESERVED | | EN_SYSREF_<br>JITTER | EN_DATA_<br>READY | EN_LANE_<br>FIFO | EN_PRBSQ | EN_PRBSI | 0x00 | R/W | | 0x021 | IRQ_ENABLE0 | | RES | SERVED | | EN_DAC0_<br>CAL_DONE | RESERVED | | EN_<br>PAERRO | 0x00 | R/W | | 0x022 | IRQ_ENABLE1 | | RES | SERVED | | EN_DAC1_<br>CAL_DONE | RES | ERVED | EN_<br>PAERR1 | 0x00 | R/W | | 0x023 | IRQ_ENABLE2 | RESE | RVED | EN_DLL_LOST | EN_DLL_<br>LOCK | RESE | RVED | EN_PLL_<br>LOST | EN_PLL_<br>LOCK | 0x00 | R/W | | 0x024 | IRQ_STATUS | | RESERVED | | IRQ_SYSREF_<br>JITTER | IRQ_DATA_<br>READY | IRQ_ IRQ_PRBSQ<br>LANE_<br>FIFO | | IRQ_PRBSI | 0x00 | R/W | | 0x025 | IRQ_STATUS0 | | RES | SERVED | | IRQ_DAC0_<br>CAL_DONE | RESERVED | | IRQ_<br>PAERRO | 0x00 | R/W | | 0x026 | IRQ_STATUS1 | | RES | | IRQ_DAC1_<br>CAL_DONE | RESERVED | | IRQ_<br>PAERR1 | 0x00 | R/W | | | 0x027 | IRQ_STATUS2 | RESERVED IRQ_DLL_LOST | | | IRQ_DLL_<br>LOCK | RESE | RVED IRQ_PLL_<br>LOST | | IRQ_PLL_<br>LOCK | 0x00 | R/W | | 0x028 | IRQ OUTPUT M | RESERVED | | | MUX | MUX_ | MUX_ | MUX_ | MUX_ | 0x00 | R/W | | | UX | | | | SYSREF_<br>JITTER | DATA_<br>READY | LANE_FIFO | PRBSQ | PRBSI | | ., | | 0x029 | IRQ_OUTPUT_<br>MUX0 | | RES | SERVED | | MUX_<br>DACO_<br>CAL_DONE | RES | ERVED | MUX_<br>PAERRO | 0x00 | R/W | | 0x02A | IRQ_OUTPUT_<br>MUX1 | | RES | SERVED | | MUX_DAC1<br>_CAL_<br>DONE | RESERVED | | MUX_<br>PAERR1 | 0x00 | R/W | | 0x02B | IRQ_OUTPUT_<br>MUX2 | RESE | RVED | MUX_DLL_<br>LOST | MUX_DLL_<br>LOCK | RESERVED MUX_PLL_<br>LOST | | | MUX_PLL_<br>LOCK | 0x00 | R/W | | 0x02C | IRQ_STATUS_<br>ALL | | | | RESERVED | | | | IRQ_<br>STATUS_<br>ALL | 0x00 | R/W | | 0x036 | SYSREF_COUNT | | | | SYSREF_CO | UNT | | | | 0x00 | R/W | | 0x039 | SYSREF_ERR_ | RESERVED | | | | F_ERR_WINDOW | 1 | | | 0x00 | R/W | | 0,037 | WINDOW | NESERVED | | | STSILL | I_LIIIL_VVIIVDOVV | | | | 0,00 | 10,00 | | 0x03A | SYSREF_MODE | | RESERVED | | SYNC_<br>ROTATION_<br>DONE | RESE | RVED | SYSREF_<br>MODE_<br>ONESHOT | RESERVED | 0x10 | R/W | | 0x03B | ROTATION_<br>MODE | SYNCLOGIC_<br>EN | RESERVED | PERIODIC_<br>RST_EN | NCORST_<br>AFTER_ROT_<br>EN | RESE | RVED | ROTATIO | ON_MODE | 0xB0 | R/W | | 0x03F | TX_ENABLE | RESE | RVED | TXEN_DATA-<br>PATH_DAC1 | TXEN_<br>DATAPATH_<br>DAC0 | | RES | ERVED | | 0x00 | R/W | | 0x050 | CAL_CLK_DIV | | RES | SERVED | 1 | | CAL ( | CLK_DIV | | 0x28 | R/W | | 0x051 | CAL_CTRL | CAL_CTRL0 | | | | 1 | | CTRL1 | CAL_START | 0x82 | R/W | | 0x052 | CAL_STAT | | 1 | RESERVED | - | | CAL_<br>ACTIVE | CAL_FAIL_<br>SEARCH | CAL_<br>FINISH | 0x00 | R/W | | 0x059 | FSC0 | | | RESER | VED | ACTIVE SEARCH FINISH FSC_CTRL[1:0] | | | | | R/W | | 0x05A | FSC1 | | | HESEN | FSC_CTRL[9 | | | | | | R/W | | 0x061 | CAL DEBUGO | RESERVED | CAL_CTRL2 | CAL_CTRL3 | RESERVED | | | | | 0x28<br>0x60 | R/W | | | CLK_CTRL | HESERVED | C/IL_CITIEZ | RESER | | CAL_CLK_ CA | | | CAL_CLK_<br>PD0 | 0x00 | R/W | | 0x081 | | | | | | | | | | | | Rev. B | Page 76 of 145 | Reg | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset | RW | |----------------|---------------------------|-----------------------|--------------------------|----------------|----------------------------|-----------------|------------------------------|---------------------------|-----------------------------------------|--------------|------------| | 0x084 | SYSREF_CTRL | RESERVED | SYSREF_ | | R | RESERVED | | 1. | SYSREF_PD | 0x00 | R/W | | 0x085 | NVM_CTRL1 | RESERVED | INPUTMODE | NVM_CTRL1A | | RESE | ERVED | NVM_ | NVM_ | 0x13 | R/W | | 0x08D | ADC_CLK_ | | RESERVED | | | C | LKOUT_SWING | CTRL1B | CTRL1C | 0x00 | R/W | | 0x08F | CTRL0 ADC_CLK_ CTRL2 | | | | RESERVED | | | | PD_<br>CLKOUT_ | 0x00 | R/W | | 0x090 | DAC_ | | | RESER | WED. | | | DAC_PD1 | DRIVER | 0x03 | R/W | | 0x090 | POWERDOWN | | | RESER | IVED | | | DAC_PD1 | DAC_PD0 | 0x03 | IN/ VV | | 0x091 | ACLK_CTRL | | | | RESERVED | | | | ACLK_<br>POWER-<br>DOWN | 0x01 | R/W | | 0x094 | PLL_CLK_DIV | | | RESER | RVED | | | PLL_VCO_<br>DIV3_EN | PLL_VCO_<br>DIV2_EN | 0x00 | R/W | | 0x095 | PLL_BYPASS | | | | RESERVED | | | | PLL_<br>BYPASS | 0x00 | R/W | | 0x09A | NVM_CTRL | PD_BGR | | | R | ESERVED | | | | 0x00 | R/W | | 0x0C0 | DELAY_LINE_<br>PD | RESI | ERVED | DLL_CTRL0B | DLL_CTRL0A | | RESERVED | | DLL_PD | 0x31 | R/W | | 0x0C1 | DLL_CTRL0 | DLL_ | CTRL1C | DLL_CTRL1B | DLL_CT | RL1A | RESE | RVED | DLL_<br>ENABLE | 0x70 | R/W | | 0x0C3 | DLL_STATUS | | | | RESERVED | | | | DLL_LOCK | 0x00 | R/W | | 0x0C7 | DLL_READ | | | | RESERVED | | | | DLL_<br>READ_EN | 0x00 | R/W | | 0x0CC | DLL_FINE_<br>DELAY0 | RESI | ERVED | | | DLL_FINE_0 | DELAY0 | | | 0x00 | R/W | | 0x0CD | DLL_FINE_<br>DELAY1 | RESI | RESERVED DLL_FINE_DELAY1 | | | | | | | 0x00 | R/W | | 0x0DB | DLL_UPDATE | | RESERVED DLL_DELAN UPDA | | | | | | | 0x00 | R/W | | 0x100 | DIG_RESET | | | | RESERVED | | | | DIG_<br>DATAPATH_<br>PD | 0x01 | R/W | | 0x110 | JESD_MODE | MODE_NOT_<br>IN_TABLE | COM_SYNC | | | JESD_MC | DDE | | 10 | 0x20 | R/W | | 0x111 | INTRP_MODE | | | TERP_MODE | | | | RP_MODE | 1 | 0x84 | R/W | | 0x112 | DDSM_<br>DATAPATH_<br>CFG | RESI | ERVED | DDSM | I_MODE | DDSM_<br>NCO_EN | DDSM_<br>MODULUS<br>_EN | DDSM_SEL<br>_SIDEBAND | EN_SYNC_<br>ALL_CHNL_<br>NCO_<br>RESETS | 0x01 | R/W | | 0x113 | DDSM_FTW_<br>UPDATE | RESERVED | С | DDSM_FTW_REQ_M | ODE | RESERVED | DDSM_FTW<br>_LOAD_<br>SYSREF | DDSM_<br>FTW_<br>LOAD_ACK | DDSM_<br>FTW_<br>LOAD_REQ | 0x00 | R/W | | 0x114 | DDSM_FTW0 | | | | DDSM_FTW[7 | | | | | 0x00 | R/W | | 0x115 | DDSM_FTW1 | | | | DDSM_FTW[1 | | | | | 0x00 | R/W | | 0x116<br>0x117 | DDSM_FTW2<br>DDSM_FTW3 | | | | DDSM_FTW[23<br>DDSM_FTW[31 | | | | | 0x00<br>0x00 | R/W<br>R/W | | 0x117 | DDSM_FTW4 | | | | DDSM_FTW[39 | | | | | 0x00 | R/W | | 0x119 | DDSM_FTW5 | | | | DDSM_FTW[47 | | | | | 0x00 | R/W | | 0x11C | DDSM_PHASE_<br>OFFSET0 | | | D | DSM_NCO_PHASE_0 | | | | | 0x00 | R/W | | 0x11D | DDSM_PHASE_<br>OFFSET1 | | | DI | DSM_NCO_PHASE_C | DFFSET[15:8] | | | | 0x00 | R/W | | 0x124 | DDSM_ACC_<br>MODULUS0 | | | | DDSM_ACC_MODU | | | | | 0x00 | R/W | | 0x125 | DDSM_ACC_<br>MODULUS1 | | | | DDSM_ACC_MODU | | | | | 0x00 | R/W | | 0x126 | DDSM_ACC_<br>MODULUS2 | | DDSM_ACC_MODULUS[23:16] | | | | | | | 0x00 | R/W | | 0x127 | DDSM_ACC_<br>MODULUS3 | | DDSM_ACC_MODULUS[31:24] | | | | | | | 0x00 | R/W | | 0x128 | DDSM_ACC_<br>MODULUS4 | | DDSM_ACC_MODULUS[39:32] | | | | | | | 0x00 | R/W | | 0x129 | DDSM_ACC_<br>MODULUS5 | | DDSM_ACC_MODULUS[47:40] | | | | | | | | R/W | | | DDSM_ACC_ | | | | | | | | | 0x00 | R/W | | 0x12A<br>0x12B | DELTA0 DDSM_ACC_ | | | | DDSM_ACC_DELT | | | | | 0x00 | R/W | | Reg<br>0x12C | Name DDSM_ACC_ DELTA2 | Bit 7 | Bit 6 | Bit 5 | Bit 4 DDSM_ACC_DEL | Bit 3<br>.TA[23:16] | Bit 2 | Bit 1 | Bit 0 | Reset<br>0x00 | RW<br>R/W | |--------------|---------------------------|-------------------|-------------------------|----------|--------------------|---------------------|------------------------------|------------------------------|-------------------------------|---------------|-----------| | 0x12D | DDSM_ACC_<br>DELTA3 | | | | DDSM_ACC_DEL | .TA[31:24] | | | | 0x00 | R/W | | 0x12E | DDSM_ACC_<br>DELTA4 | | | | DDSM_ACC_DEL | TA[39:32] | | | | 0x00 | R/W | | 0x12F | DDSM_ACC_<br>DELTA5 | | | | DDSM_ACC_DEL | TA[47:40] | | | | 0x00 | R/W | | 0x130 | DDSC_<br>DATAPATH_<br>CFG | RESERVED | DDSC_NCO<br>_EN | | RESERVED | | DDSC_<br>MODULUS_<br>EN | DDSC_<br>SEL_<br>SIDEBAND | DDSC_EN_<br>DC_INPUT | 0x00 | R/W | | 0x131 | DDSC_FTW_<br>UPDATE | | | RESERVED | | | DDSC_FTW<br>_LOAD_<br>SYSREF | DDSC_<br>FTW_<br>LOAD_ACK | DDSC_<br>FTW_<br>LOAD_REQ | 0x00 | R/W | | 0x132 | DDSC_FTW0 | | | | DDSC_FTW | [7:0] | | | 0x00 | R/W | | | 0x133 | DDSC_FTW1 | | | | DDSC_FTW[ | 15:8] | | | | 0x00 | R/W | | 0x134 | DDSC_FTW2 | | | | DDSC_FTW[2 | 23:16] | | | | 0x00 | R/W | | 0x135 | DDSC_FTW3 | | | | DDSC_FTW[3 | 31:24] | | | | 0x00 | R/W | | 0x136 | DDSC_FTW4 | | | | DDSC_FTW[3 | 39:32] | | | | 0x00 | R/W | | 0x137 | DDSC_FTW5 | | | | DDSC_FTW[4 | 17:40] | | | | 0x00 | R/W | | 0x138 | DDSC_PHASE_<br>OFFSET0 | | | DE | SC_NCO_PHASE | _OFFSET[7:0] | | | | 0x00 | R/W | | 0x139 | DDSC_PHASE_<br>OFFSET1 | | | DD | SC_NCO_PHASE_ | OFFSET[15:8] | | | | 0x00 | R/W | | 0x13A | DDSC_ACC_<br>MODULUS0 | | | | DDSC_ACC_MOD | OULUS[7:0] | | | | 0x00 | R/W | | 0x13B | DDSC_ACC_<br>MODULUS1 | | | ] | DDSC_ACC_MOD | ULUS[15:8] | | | | 0x00 | R/W | | 0x13C | DDSC_ACC_<br>MODULUS2 | | | D | DSC_ACC_MODU | JLUS[23:16] | | | | 0x00 | R/W | | 0x13D | DDSC_ACC_<br>MODULUS3 | | | D | DSC_ACC_MODU | JLUS[31:24] | | | | 0x00 | R/W | | 0x13E | DDSC_ACC_<br>MODULUS4 | | DDSC_ACC_MODULUS[39:32] | | | | | | | | | | 0x13F | DDSC_ACC_<br>MODULUS5 | | | С | DSC_ACC_MODU | JLUS[47:40] | | | | 0x00 | R/W | | 0x140 | DDSC_ACC_<br>DELTA0 | | | | DDSC_ACC_DE | LTA[7:0] | | | | 0x00 | R/W | | 0x141 | DDSC_ACC_<br>DELTA1 | | | | DDSC_ACC_DEL | -TA[15:8] | | | | 0x00 | R/W | | 0x142 | DDSC_ACC_<br>DELTA2 | | | | DDSC_ACC_DEL | TA[23:16] | | | | 0x00 | R/W | | 0x143 | DDSC_ACC_<br>DELTA3 | | | | DDSC_ACC_DEL | TA[31:24] | | | | 0x00 | R/W | | 0x144 | DDSC_ACC_<br>DELTA4 | | | | DDSC_ACC_DEL | TA[39:32] | | | | 0x00 | R/W | | 0x145 | DDSC_ACC_<br>DELTA5 | | | | DDSC_ACC_DEL | TA[47:40] | | | | 0x00 | R/W | | 0x146 | CHNL_GAIN0 | | | | CHNL_GAIN | I[7:0] | | | | 0x00 | R/W | | 0x147 | CHNL_GAIN1 | | RE | SERVED | | | CHNL_G | AIN[11:8] | | 0x08 | R/W | | 0x148 | DC_CAL_TONE0 | | | | _TEST_INPUT_AM | | | | | 0x00 | R/W | | 0x149 | DC_CAL_TONE1 | | | _ | TEST_INPUT_AM | PLITUDE[15:8] | | | | 0x00 | R/W | | 0x14B | PRBS | PRBS_GOOD_<br>Q | PRBS_<br>GOOD_I | RESERVED | PRBS_INV_Q | PRBS_INV_I | PRBS_<br>MODE | PRBS_<br>RESET | PRBS_EN | 0x10 | R/W | | 0x14C | PRBS_ERROR_I | | | | PRBS_COU | NT_I | | | | 0x00 | R | | 0x14D | PRBS_ERROR_Q | | | | PRBS_COUN | NT_Q | | | | 0x00 | R | | 0x14E | PRBS_CHANSEL | | | RESERVED | | | | PRBS_CHANSE | L | 0x07 | R/W | | 0x151 | DECODE_MODE | RESE | RVED | MSB_I | | | RESE | RVED | | 0x00 | R/W | | 0x1DE | SPI_ENABLE | | | RESERV | | | SPI_EN1 | SPI_EN0 | 0x03 | R/W | | | 0x1E2 | DDSM_CAL_<br>FTW0 | DDSM_CAL_FTW[7:0] | | | | | | | | 0x00 | R/W | | 0x1E3 | DDSM_CAL_<br>FTW1 | | | | DDSM_CAL_FT | W[15:8] | | | | 0x00 | R/W | | 0x1E4 | DDSM_CAL_<br>FTW2 | | | | DDSM_CAL_FT | W[23:16] | | | | 0x00 | R/W | | 0x1E5 | DDSM_CAL_<br>FTW3 | | | | DDSM_CAL_FT | W[31:24] | | | | 0x00 | R/W | | 0x1E6 | DDSM_CAL_<br>MODE_DEF | | | RESERVED | | | DDSM_EN_<br>CAL_ACC | DDSM_EN_<br>CAL_DC_<br>INPUT | DDSM_EN_<br>CAL_FREQ_<br>TUNE | 0x00 | R/W | | Reg | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset | RW | |-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-----------------------------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------------------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|------------------------------------------| | 0x1E7 | DATAPATH | | | RESER | | | | ALL_NCO_ | START | 0x00 | R/W | | | NCO_ | | | | | | | SYNC_ACK | NCO_ | | | | | SYNC_CFG | | | | | | | | SYNC | | | | 0x200 | MASTER_PD | | | | RESERVED | | | | SERDES_ | 0x01 | R/W | | | | | | | | | | | MASTER_<br>PD | | | | 0x201 | PHY_PD | | | | PHY_PD | ) | | | 1.0 | 0xEE | R/W | | 0x203 | GENERIC PD | | | RESER | | | | PD | PD | 0x01 | R/W | | | | | | | | | | SYNCOUT0 | SYNCOUT1 | | | | 0x206 | CDR RESET | | | | RESERVED | | | | CDR_PHY_ | 0x00 | R/W | | | _ | | | | | | | | RESET | | | | 0x210 | CBUS_ADDR | | | | SERDES_CBUS | | 0x00 | R/W | | | | | 0x212 | CBUS_ | | | | SERDES_CBUS | S_WR0 | | | | 0x00 | R/W | | | WRSTROBE_<br>PHY | | | | | | | | | | | | 0x213 | CBUS_ | | | | RESERVED | | | | SERDES | 0x00 | R/W | | UX213 | WRSTROBE | | | | RESERVED | | | | CBUS_WR1 | UXUU | IT/ VV | | | OTHER | | | | | | | | 5555_11111 | | | | 0x216 | CBUS_WDATA | | | | SERDES_CBUS | _DATA | | | 1 | 0x00 | R/W | | 0x234 | CDR_ | | | SE | L_IF_PARDATAINV | _DES_RC_CH | | | | 0x66 | R/W | | | BITINVERSE | | | | | | | | | | | | 0x240 | EQ_BOOST_ | EQ_BOOS | ST_PHY3 | EQ_BOC | ST_PHY2 | EQ_BOO | ST_PHY1 | EQ_BOO | OST_PHY0 | 0xFF | R/W | | | PHY_3_0 | | | | | | | | | | | | 0x241 | EQ_BOOST_<br>PHY_7_4 | EQ_BOOS | I_PHY/ | EG_ROC | ST_PHY6 | EG_ROO | ST_PHY5 | EQ_BOC | OST_PHY4 | 0xFF | R/W | | 0x242 | EQ_GAIN_PHY_ | EQ_GAIN | J PHY3 | FO GA | EQ_GAIN_PHY2 | | | FO GA | IN_PHY0 | 0xFF | R/W | | UXZ-TZ | 3_0 | EQ_G/III | 1_11113 | EQ_G/ | EQ_GAIN_PHY2 EQ_GAIN_F | | | LQ_G/ | | OXII | 10,00 | | 0x243 | EQ_GAIN_PHY_ | EQ_GAIN | N_PHY7 | EQ_GA | IN_PHY6 | EQ_GAI | EQ_GA | IN_PHY4 | 0xFF | R/W | | | | 7_4 | | | | | | | _ | | | | | 0x244 | EQ_FB_PHY_0 | RESERVED | | | EQ_PHY_0 | | | | | 0x19 | R/W | | 0x245 | EQ_FB_PHY_1 | | RESERVED | | | | EQ_PHY1 | | | 0x19 | R/W | | 0x246 | EQ_FB_PHY_2 | | RESERVED | | | | EQ_PHY2 | | | 0x19 | R/W | | 0x247 | EQ_FB_PHY_3 | | RESERVED | | | | EQ_PHY3 | | | 0x19 | R/W | | 0x248 | EQ_FB_PHY_4 | | RESERVED | | | | EQ_PHY4 | | | 0x19 | R/W | | 0x249 | EQ_FB_PHY_5 | | RESERVED | | | | EQ_PHY5 | | | 0x19 | R/W | | 0x24A | EQ_FB_PHY_6 | | RESERVED | | | | EQ_PHY6 | | | 0x19 | R/W | | 0x24B | EQ_FB_PHY_7 | | RESERVED | | | | EQ_PHY7 | | | 0x19 | R/W | | 0x250 | LBT_REG_ | | | | EN_LBT_DES_I | | 0x00 | R/W | | | | | | CNTRL_0 | | | | | | | | | | | | 0x251 | LBT_REG_<br>CNTRL_1 | | | RESER | VED | | | EN_LBT_<br>HALFRATE | INIT_LBT_<br>SYNC_DES_ | 0x02 | R/W | | | CIVIIIL_I | | | | | HALFR/<br>_DES_F | | | | | | | | | | | | | | | | | | | | 0x253 | SYNCOUT0_ | | | | RESERVED | | | | SEL_ | 0x00 | R/W | | 0x253 | SYNCOUTO_<br>CTRL | | | | RESERVED | | | | SYNCOUT0_ | 0x00 | R/W | | | CTRL | | | | | | | | SYNCOUTO_<br>MODE | | | | 0x253<br>0x254 | CTRL SYNCOUT1_ | | | | RESERVED RESERVED | | | | SYNCOUTO_<br>MODE<br>SEL_ | 0x00<br>0x00 | R/W | | | CTRL | | | | | | | | SYNCOUTO_<br>MODE<br>SEL_<br>SYNCOUT1_ | | | | 0x254 | SYNCOUT1_CTRL | | | RESERVED | | | LOLSTICKY | | SYNCOUTO_<br>MODE SELSYNCOUT1_<br>MODE | 0x00 | R/W | | | CTRL SYNCOUT1_ | | | RESERVED | | | LOLSTICKY<br>CLEAR_ | LDSYNTH_<br>LCPLL_RC | SYNCOUTO<br>MODE SEL_ SYNCOUT1_ MODE SERDES_ PLL_ | | | | 0x254<br>0x280 | SYNCOUT1_ CTRL PLL_ENABLE_ CTRL | | | RESERVED | RESERVED | | | LDSYNTH_ | SYNCOUTO_<br>MODE SEL_<br>SYNCOUT1_<br>MODE SERDES_<br>PLL_<br>STARTUP | 0x00<br>0x01 | R/W | | 0x254 | SYNCOUTI_ CTRL PLL_ENABLE_ | | | RESERVED | | | CLEAR_ | LDSYNTH_ | SYNCOUTO_ MODE SEL_ SYNCOUT1_ MODE SERDES_ PLL_ STARTUP SERDES_ | 0x00 | R/W | | 0x254<br>0x280 | SYNCOUT1_ CTRL PLL_ENABLE_ CTRL | | | RESERVED | RESERVED | | CLEAR_ | LDSYNTH_ | SYNCOUTO_<br>MODE SEL_ SYNCOUT1_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ PLL_ | 0x00<br>0x01 | R/W | | 0x254<br>0x280<br>0x281 | SYNCOUT1_ CTRL PLL_ENABLE_ CTRL PLL_STATUS | | RE | | RESERVED | LINK | CLEAR_<br>LCPLL_RC | LDSYNTH_<br>LCPLL_RC | SYNCOUTO_ MODE SEL_ SYNCOUTI_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ LOCK | 0x00<br>0x01<br>0x00 | R/W<br>R/W | | 0x254<br>0x280 | SYNCOUT1_ CTRL PLL_ENABLE_ CTRL | | RE | RESERVED | RESERVED | LINK_<br>MODE | CLEAR_ | LDSYNTH_<br>LCPLL_RC | SYNCOUTO_<br>MODE SEL_ SYNCOUT1_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ PLL_ | 0x00<br>0x01 | R/W | | 0x254<br>0x280<br>0x281 | SYNCOUT1_ CTRL PLL_ENABLE_ CTRL PLL_STATUS GENERAL_JRX_ | RESER | | | RESERVED | | CLEAR_<br>LCPLL_RC | LDSYNTH_<br>LCPLL_RC | SYNCOUTO_ MODE SEL_ SYNCOUTI_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ LOCK | 0x00<br>0x01<br>0x00 | R/W<br>R/W | | 0x254<br>0x280<br>0x281<br>0x300 | SYNCOUT1_ CTRL PLL_ENABLE_ CTRL PLL_STATUS GENERAL_JRX_ CTRL_0 DYN_LINK_ LATENCY_0 | RESER | | | RESERVED | MODE | CLEAR_<br>LCPLL_RC | LDSYNTH_<br>LCPLL_RC | SYNCOUTO_ MODE SEL_ SYNCOUTI_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ LOCK | 0x00<br>0x01<br>0x00<br>0x00 | R/W<br>R/W<br>R | | 0x254<br>0x280<br>0x281<br>0x300 | CTRL SYNCOUT1_ CTRL PLL_ENABLE_ CTRL PLL_STATUS GENERAL_JRX_ CTRL_0 DYN_LINK_ LATENCY_0 DYN_LINK_ | RESER | RVED | | RESERVED | MODE | CLEAR_<br>LCPLL_RC LINK_PAGE TENCY_0 | LDSYNTH_<br>LCPLL_RC | SYNCOUTO_ MODE SEL_ SYNCOUTI_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ LOCK | 0x00<br>0x01<br>0x00<br>0x00 | R/W<br>R/W<br>R | | 0x254 0x280 0x281 0x300 0x302 0x303 | SYNCOUT1_ CTRL PLL_ENABLE_ CTRL PLL_STATUS GENERAL_JRX_ CTRL_0 DYN_LINK_ LATENCY_0 DYN_LINK_ LATENCY_1 | RESER | RVED | | RESERVED | MODE DYN_LINK_LA | CLEAR_<br>LCPLL_RC LINK_PAGE TENCY_0 TENCY_1 | LDSYNTH_<br>LCPLL_RC | SYNCOUTO_ MODE SEL_ SYNCOUTI_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ LOCK | 0x00 0x01 0x00 0x00 0x00 0x00 | R/W R/W R R/R R/R | | 0x254 0x280 0x281 0x300 0x302 0x303 0x304 | CTRL SYNCOUT1_ CTRL PLL_ENABLE_ CTRL PLL_STATUS GENERAL_JRX_ CTRL_0 DYN_LINK_ LATENCY_0 DYN_LINK_ LATENCY_1 LMFC_DELAY_0 | RESER<br>RESER | RVED RVED | | RESERVED | MODE DYN_LINK_LA* DYN_LINK_LA* | CLEAR_<br>LCPLL_RC LINK_PAGE TENCY_0 TENCY_1 AY_0 | LDSYNTH_<br>LCPLL_RC | SYNCOUTO_ MODE SEL_ SYNCOUTI_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ LOCK | 0x00 0x01 0x00 0x00 0x00 0x00 0x00 0x00 | R/W R/W R R R/W R R R | | 0x254 0x280 0x281 0x300 0x302 0x303 0x304 0x305 | CTRL SYNCOUT1_ CTRL PLL_ENABLE_ CTRL PLL_STATUS GENERAL_JRX_ CTRL_0 DYN_LINK_ LATENCY_0 DYN_LINK_ LATENCY_1 LMFC_DELAY_0 LMFC_DELAY_1 | RESER<br>RESER<br>RESER | EVED EVED | | RESERVED | MODE DYN_LINK_LA* DYN_LINK_LA* LMFC_DEL LMFC_DEL | CLEAR_<br>LCPLL_RC LINK_PAGE TENCY_0 TENCY_1 AY_0 AY_1 | LDSYNTH_<br>LCPLL_RC | SYNCOUTO_ MODE SEL_ SYNCOUTI_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ LOCK | 0x00 0x01 0x00 0x00 0x00 0x00 0x00 0x00 0x00 | R/W R/W R R R/W R R R | | 0x254 0x280 0x281 0x300 0x302 0x303 0x304 0x305 0x306 | SYNCOUT1_CTRL PLL_ENABLE_CTRL PLL_STATUS GENERAL_JRX_CTRL_0 DYN_LINK_LATENCY_0 DYN_LINK_LATENCY_1 LMFC_DELAY_0 LMFC_DELAY_0 LMFC_DELAY_1 LMFC_VAR_0 | RESER<br>RESER<br>RESER<br>RESER | EVED EVED EVED EVED EVED EVED | | RESERVED | MODE DYN_LINK_LA* DYN_LINK_LA* LMFC_DEL LMFC_DEL LMFC_VA | CLEAR_<br>LCPLL_RC LINK_PAGE TENCY_0 TENCY_1 AY_0 AY_1 R_0 | LDSYNTH_<br>LCPLL_RC | SYNCOUTO_ MODE SEL_ SYNCOUTI_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ LOCK | 0x00 0x01 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x3F | R/W R/W R R R R/W R R R/W R/W R/W | | 0x254 0x280 0x281 0x300 0x302 0x303 0x304 0x305 0x306 0x307 | SYNCOUT1_CTRL PLL_ENABLE_CTRL PLL_STATUS GENERAL_JRX_CTRL_0 DYN_LINK_LATENCY_0 DYN_LINK_LATENCY_1 LMFC_DELAY_0 LMFC_DELAY_1 LMFC_VAR_0 LMFC_VAR_1 | RESER<br>RESER<br>RESER<br>RESER<br>RESER | EVED EVED EVED EVED EVED EVED EVED EVED | SERVED | RESERVED | MODE DYN_LINK_LA* DYN_LINK_LA* LMFC_DEL LMFC_DEL LMFC_VA LMFC_VA | CLEAR_<br>LCPLL_RC LINK_PAGE TENCY_0 TENCY_1 AY_0 AY_1 R_0 R_1 | LDSYNTH_<br>LCPLL_RC | SYNCOUTO_ MODE SEL_ SYNCOUT1_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ LOCK K_EN | 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x3F 0x3F | R/W R/W R R R R/W R R R R/W R/W R/W R/W | | 0x254 0x280 0x281 0x300 0x302 0x303 0x304 0x305 0x306 0x307 0x308 | SYNCOUT1_CTRL PLL_ENABLE_CTRL PLL_STATUS GENERAL_JRX_CTRL_0 DYN_LINK_LATENCY_0 DYN_LINK_LATENCY_1 LMFC_DELAY_0 LMFC_DELAY_1 LMFC_VAR_0 LMFC_VAR_1 XBAR_LN_0_1 | RESER<br>RESER<br>RESER<br>RESER<br>RESER<br>RESER | EVED EVED EVED EVED EVED EVED EVED EVED | SERVED | RESERVED RESERVED | MODE DYN_LINK_LA* DYN_LINK_LA* LMFC_DEL LMFC_VA LMFC_VA | CLEAR_<br>LCPLL_RC LINK_PAGE TENCY_0 TENCY_1 AY_0 AY_1 R_0 R_1 LO | LDSYNTH_<br>LCPLL_RC<br>LIN | SYNCOUTO_ MODE SEL_ SYNCOUT1_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ LOCK K_EN | 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x3F 0x3F 0x08 | R/W R/W R R R R R R R R R R R R R R R R | | 0x254 0x280 0x281 0x300 0x302 0x303 0x304 0x305 0x306 0x307 0x308 0x309 | SYNCOUT1_CTRL PLL_ENABLE_CTRL PLL_STATUS GENERAL_JRX_CTRL_0 DYN_LINK_LATENCY_0 DYN_LINK_LATENCY_1 LMFC_DELAY_0 LMFC_DELAY_1 LMFC_VAR_0 LMFC_VAR_1 XBAR_LN_0_1 XBAR_LN_0_1 XBAR_LN_2_3 | RESER<br>RESER<br>RESER<br>RESER<br>RESER<br>RESER | EVED EVED EVED EVED EVED EVED EVED EVED | SERVED LC | RESERVED RESERVED OGICAL_LANE1_SRO | MODE DYN_LINK_LA* DYN_LINK_LA* LMFC_DEL LMFC_VA LMFC_VA | CLEAR_<br>LCPLL_RC LINK_PAGE TENCY_0 TENCY_1 AY_0 AY_1 R_0 R_1 LO | LDSYNTH_<br>LCPLL_RC<br>LIN<br>GICAL_LANEO_<br>GICAL_LANEO_ | SYNCOUTO_ MODE SEL_ SYNCOUT1_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ LOCK K_EN SRC SRC | 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x3F 0x3F 0x08 0x1A | R/W R/W R R R R R/W R R R R/W R/W R/W R/ | | 0x254 0x280 0x281 0x300 0x302 0x303 0x304 0x305 0x306 0x307 0x308 0x309 0x30A | SYNCOUT1_CTRL PLL_ENABLE_CTRL PLL_STATUS GENERAL_JRX_CTRL_0 DYN_LINK_LATENCY_0 DYN_LINK_LATENCY_1 LMFC_DELAY_0 LMFC_DELAY_1 LMFC_VAR_0 LMFC_VAR_0 LMFC_VAR_1 XBAR_LN_0_1 XBAR_LN_0_1 XBAR_LN_2_3 XBAR_LN_4_5 | RESER RESER RESER RESER RESER RESER RESER RESER RESER | EVED EVED EVED EVED EVED EVED EVED EVED | SERVED LC LC LC | RESERVED RESERVED OGICAL_LANE1_SROGICAL_LANE3_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SROGICAL_LANE5_SRO | MODE DYN_LINK_LA* DYN_LINK_LA* LMFC_DEL LMFC_VA LMFC_VA C C | CLEAR_<br>LCPLL_RC LINK_PAGE TENCY_0 TENCY_1 AY_0 AY_1 R_0 R_1 LO LO | LDSYNTH_<br>LCPLL_RC<br>LIN<br>GICAL_LANEO_<br>GICAL_LANE2_<br>GICAL_LANE4_ | SYNCOUTO_ MODE SEL_ SYNCOUTI_ MODE SEL_ SYNCOUTI_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ LOCK K_EN SRC SRC SRC SRC | 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x3F 0x3F 0x08 0x1A 0x2C | R/W R/W R R R R R/W R R R R/W R/W R/W R/ | | 0x254 0x280 0x281 0x300 0x302 0x303 0x304 0x305 0x306 0x307 0x308 0x309 | SYNCOUT1_CTRL PLL_ENABLE_CTRL PLL_STATUS GENERAL_JRX_CTRL_0 DYN_LINK_LATENCY_0 DYN_LINK_LATENCY_1 LMFC_DELAY_0 LMFC_DELAY_1 LMFC_VAR_0 LMFC_VAR_1 XBAR_LN_0_1 XBAR_LN_0_1 XBAR_LN_2_3 | RESER<br>RESER<br>RESER<br>RESER<br>RESER<br>RESER | EVED EVED EVED EVED EVED EVED EVED EVED | SERVED LC LC LC | RESERVED RESERVED OGICAL_LANE1_SRO | MODE DYN_LINK_LA* DYN_LINK_LA* LMFC_DEL LMFC_VA LMFC_VA C C C | CLEAR_<br>LCPLL_RC LINK_PAGE TENCY_0 TENCY_1 AY_0 AY_1 R_0 R_1 LO LO | LDSYNTH_<br>LCPLL_RC<br>LIN<br>GICAL_LANEO_<br>GICAL_LANEO_ | SYNCOUTO_ MODE SEL_ SYNCOUTI_ MODE SEL_ SYNCOUTI_ MODE SERDES_ PLL_ STARTUP SERDES_ PLL_ LOCK K_EN SRC SRC SRC SRC | 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x3F 0x3F 0x08 0x1A | R/W R/W R R R R R/W R R R R/W R/W R/W R/ | | Reg<br>0x30D | Name<br>FIFO_STATUS_<br>REG_1 | Bit 7 | Bit 6 | Bit 5 | Bit 4 LANE_FIFO_E | Bit 3<br>MPTY | Bit 2 | Bit 1 | Bit 0 | Reset<br>0x00 | <b>RW</b> | | |----------------|---------------------------------------------|----------|---------------------------------|-------------|------------------------|-----------------|-----------------|------------------------------|---------------------------|---------------|------------|--| | 0x311 | SYNCOUT_<br>GEN_0 | | RES | SERVED | | EOMF_<br>MASK_1 | EOMF_<br>MASK_0 | EOF_<br>MASK_1 | EOF_<br>MASK_0 | 0x00 | R/W | | | 0x312 | SYNCOUT_ | | SYNC | _ERR_DUR | | | RES | ERVED | | 0x00 | R/W | | | 0x315 | GEN_1 PHY_PRBS_ TEST_EN | | | | PHY_TEST_ | EN | | | | 0x00 | R/W | | | 0x316 | PHY_<br>PRBS_TEST_<br>CTRL | RESERVED | | PHY_SRC_ERR | L_CNT | PHY_PR | RBS_PAT_SEL | PHY_TEST_<br>START | PHY_TEST_<br>RESET | 0x00 | R/W | | | 0x317 | PHY_<br>PRBS_TEST_<br>THRESHOLD_<br>LOBITS | | | | PHY_PRBS_THRESHO | OLD_LOBITS | | | · | 0x00 | R/W | | | 0x318 | PHY_<br>PRBS_TEST_<br>THRESHOLD_<br>MIDBITS | | | | PHY_PRBS_THRESHO | LD_MIDBITS | | | | 0x00 | R/W | | | 0x319 | PHY_<br>PRBS_TEST_<br>THRESHOLD_<br>HIBITS | | | | PHY_PRBS_THRESHO | OLD_HIBITS | | | | 0x00 | R/W | | | 0x31A | PHY_<br>PRBS_TEST_<br>ERRCNT_LOBITS | | | | PHY_PRBS_ERR_CN | IT_LOBITS | | | | 0x00 | R | | | 0x31B | PHY_PRBS_<br>TEST_<br>ERRCNT_<br>MIDBITS | | | | PHY_PRBS_ERR_CN | T_MIDBITS | | | | 0x00 | R | | | 0x31C | PHY_<br>PRBS_TEST_ | | PHY_PRBS_ERR_CNT_HIBITS | | | | | | | | | | | 0x31D | PHY_<br>PRBS_TEST_<br>STATUS | | PHY_PRBS_PASS | | | | | | | | | | | 0x31E | PHY_DATA_<br>SNAPSHOT_<br>CTRL | | | RES | SERVED | | | PHY_<br>GRAB_<br>MODE | PHY_GRAB_<br>DATA | 0x00 | R/W | | | 0x31F | PHY_<br>SNAPSHOT_<br>DATA_BYTE0 | | | | PHY_SNAPSHOT_D | ATA_BYTE0 | | | | 0x00 | R | | | 0x320 | PHY_<br>SNAPSHOT_<br>DATA_BYTE1 | | | | PHY_SNAPSHOT_D | ATA_BYTE1 | | | | 0x00 | R | | | 0x321 | PHY_<br>SNAPSHOT_<br>DATA_BYTE2 | | | | PHY_SNAPSHOT_D | ATA_BYTE2 | | | | 0x00 | R | | | 0x322 | PHY_<br>SNAPSHOT_<br>DATA_BYTE3 | | | | PHY_SNAPSHOT_D | ATA_BYTE3 | | | | 0x00 | R | | | 0x323 | PHY_<br>SNAPSHOT_<br>DATA_BYTE4 | | | | PHY_SNAPSHOT_D | ATA_BYTE4 | | | | 0x00 | R | | | 0x32C | SHORT_TPL_<br>TEST_0 | | SHORT_ | TPL_SP_SEL | | SHORT_ | _TPL_M_SEL | SHORT_<br>TPL_TEST_<br>RESET | SHORT_<br>TPL_<br>TEST_EN | 0x00 | R/W | | | 0x32D | SHORT_TPL_<br>TEST_1 | | | | SHORT_TPL_REF | _SP_LSB | | | 1 | 0x00 | R/W<br>R/W | | | 0x32E | SHORT_TPL_<br>TEST_2 | | SHORT_TPL_REF_SP_MSB | | | | | | | | | | | 0x32F | SHORT_TPL_<br>TEST_3 | RESERVED | SHORT_TPL_<br>IQ_SAMPLE_<br>SEL | | | RESERVED | | | SHORT_<br>TPL_FAIL | 0x00 | R/W | | | 0x334 | JESD_BIT_<br>INVERSE_CTRL | | | | JESD_BIT_INV | ERSE | | | | 0x00 | R/W | | | 0x400 | DID_REG | | | | DID_RD | | | | | 0x00 | R | | | 0x401<br>0x402 | BID_REG<br>LID0_REG | RESERVED | ADJDIR_RD | PHADJ RD | BID_RD | | LL LID0 | | | 0x00<br>0x00 | R<br>R | | | 0x402<br>0x403 | SCR_L_REG | SCR_RD | _ | SERVED | | | L_RD-1 | | | 0x00 | R | | | 0x404 | F_REG | | | · | F_RD-1 | | | | | 0x00 | R | | | 0x405 | K_REG | | RESERVED | | | - | K_RD-1 | | | 0x00 | R | | | 0x406 | M_REG | | | 1 | M_RD-1 | | | | | 0x00 | R | | | 0x407 | CS_N_REG | CS_ | _RD | RESERVED | Rev. B Page 80 of 14 | | N_RD-1 | | | 0x00 | R | | Rev. B | Page 80 of 145 | Reg | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset | RW | | |----------------|--------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|------------|--| | 0x408 | NP_REG | | SUBCLASSV_RD | ) | | | NP_RD-1 | | | 0x00 | R | | | 0x409 | S_REG | | JESDV_RD-1 | | | | S_RD-1 | | | 0x00 | R | | | 0x40A | HD_CF_REG | HD_RD | RES | ERVED | | | CF_RD | | | 0x00 | R | | | 0x40B | RES1_REG | | | | RES1_ | | | | | 0x00 | R | | | 0x40C | RES2_REG | | | | RES2_ | | | | | 0x00 | R | | | 0x40D | CHECKSUM0_<br>REG | | | | LL_FC | .HKU | | | | 0x00 | R | | | 0x40E | COMPSUM0_<br>REG | | | | LL_FC | MP0 | | | | 0x00 | R | | | 0x412 | LID1_REG | | RESERVED | | | | LL_LID1 | | | 0x00 | R | | | 0x415 | CHECKSUM1_<br>REG | | | | LL_FC | HK1 | | | | 0x00 | R | | | 0x416 | COMPSUM1_<br>REG | | | | LL_FC | MP1 | | | | 0x00 | R | | | 0x41A | LID2_REG | | RESERVED | | | | 0x00 | R | | | | | | 0x41D | CHECKSUM2_<br>REG | | | | LL_FC | HK2 | | | | 0x00 | R | | | 0x41E | COMPSUM2_<br>REG | | | | LL_FC | MP2 | | | | 0x00 | R | | | 0x422 | LID3_REG | | RESERVED | | | | LL_LID3 | | | 0x00 | R | | | 0x425 | CHECKSUM3_<br>REG | | | | LL_FC | НК3 | | | | 0x00 | R | | | 0x426 | COMPSUM3_<br>REG | | | | LL_FC | MP3 | | | | 0x00 | R | | | 0x42A | LID4_REG | | RESERVED | | | | 0x00 | R | | | | | | 0x42D | CHECKSUM4_<br>REG | | | | LL_FC | | 0x00 | R | | | | | | 0x42E | COMPSUM4_<br>REG | | | | LL_FC | | 0x00 | R | | | | | | 0x432 | LID5_REG | | RESERVED | | | | 0x00 | R | | | | | | 0x435 | CHECKSUM5_<br>REG | | | | LL_FC | | 0x00 | R | | | | | | 0x436 | COMPSUM5_<br>REG | | | | LL_FC | LL_FCMP5 | | | | | | | | 0x43A | LID6_REG | | RESERVED | | | | 0x00 | R | | | | | | 0x43D | CHECKSUM6_<br>REG | | | | LL_FC | HK6 | | | | 0x00 | R | | | 0x43E | COMPSUM6_<br>REG | | | | LL_FC | MP6 | | | | 0x00 | R | | | 0x442 | LID7_REG | | RESERVED | | | | 0x00 | R | | | | | | 0x445 | CHECKSUM7_<br>REG | | | | LL_FC | | 0x00 | R | | | | | | 0x446 | COMPSUM7_<br>REG | | | | LL_FC | MP7 | | | | 0x00 | R | | | 0x450 | ILS_DID | | | | DIE | | | | | 0x00 | R/W | | | 0x451 | ILS_BID | | | | BIC | ) | | | | 0x00 | R/W | | | 0x452 | ILS_LID0 | RESERVED | ADJDIR | PHADJ | | | LID0 | | | 0x00 | R/W | | | 0x453 | ILS_SCR_L | SCR | RES | ERVED | F-1 | 1 | L-1 | | | 0x87 | R/W<br>R/W | | | 0x454 | ILS_F | | RESERVED | | F-1 | | K-1 | | | 0x00<br>0x1F | R/W | | | 0x455<br>0x456 | ILS_K<br>ILS_M | | NESERVED | | M- | 1 | r\-1 | | | 0x1F<br>0x01 | R/W | | | 0x450<br>0x457 | ILS_CS_N | | CS | RESERVED | 141- | ! | N-1 | | | 0x0F | R/W | | | 0x458 | ILS_NP | | SUBCLASSV | | | | NP-1 | | | 0x0F | R/W | | | 0x459 | ILS_S | | JESDV | | | | S-1 | | | 0x01 | R/W | | | 0x45A | ILS_HD_CF | HD | | ERVED | | | CF | | | 0x80 | R | | | 0x45B | ILS_RES1 | | | | RES | 51 | | | | 0x00 | R/W | | | 0x45C | ILS_RES2 | RES2 | | | | | | | 0x00 | R/W | | | | 0x45D | ILS_CHECKSUM | | | | FCH | K0 | | | | 0x00 | R/W | | | 0x46C | LANE_DESKEW | ILD7 | ILD6 | ILD5 | ILD4 | ILD3 | ILD2 | ILD1 | ILD0 | 0x00 | R | | | 0x46D | BAD_DISPARITY | BDE7 | BDE6 | BDE5 | BDE4 | BDE3 | BDE2 | BDE1 | BDE0 | 0x00 | R | | | 0x46E<br>0x46F | NOT_IN_TABLE UNEXPECTED_ | NIT7<br>UEK7 | NIT6<br>UEK6 | NIT5<br>UEK5 | NIT4<br>UEK4 | NIT3<br>UEK3 | NIT2<br>UEK2 | NIT1<br>UEK1 | NIT0<br>UEK0 | 0x00<br>0x00 | R<br>R | | | 0x470 | CODE_GRP_ | CGS7 | CGS6 | CGS5 | CGS4 | CGS3 | CGS2 | CGS1 | CGS0 | 0x00 | R | | | 0x471 | SYNC<br>FRAME_SYNC | FS7 | FS6 | FS5 | FS4 | FS3 | FS2 | FS1 | FS0 | 0x00 | R | | | 0x472 | GOOD_ | CKS7 | CKS6 | CKS5 | CKS4 | CKS3 | CKS2 | CKS1 | CKS0 | 0x00 | R | | | | CHECKSUM | | | | | | | | | | | | | Reg | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset | RW | | |----------------|---------------------------|---------------------------------|--------------------------------|-------------|------------|------------------------------|----------------------------|----------------------|---------------------|-------|-----|--| | 0x473 | INIT_LANE_<br>SYNC | ILS7 | ILS6 | ILS5 | ILS4 | ILS3 | ILS2 | ILS1 | ILS0 | 0x00 | R | | | 0x475 | CTRLREG0 | | RES | ERVED | | SOFTRST | FORCE-<br>SYNCREQ | RESERVED | REPL_FRM_<br>ENA | 0x01 | R/W | | | 0x476 | CTRLREG1 | | RESERVED | | QUAL_RDERR | | RESERVED | | FCHK_N | 0x14 | R/W | | | 0x477 | CTRLREG2 | ILS_MODE | RESERVED | REPDATATEST | QUETESTERR | AR_ECNTR | | RESERVED | | 0x00 | R/W | | | 0x478 | KVAL | | | | KSYNC | | | | | 0x01 | R/W | | | 0x47C | ERRORTHRES | | | | ETH | | | | | 0xFF | R/W | | | 0x47D | SYNC_ASSERT_<br>MASK | | | RESERVED | | | SY | /NC_ASSERT_M | ASK | 0x07 | R/W | | | 0x480 | ECNT_CTRL0 | RESE | RVED | | ECNT_ENA0 | | | ECNT_RST0 | | 0x3F | R/W | | | 0x481 | ECNT_CTRL1 | RESE | RVED | | ECNT_ENA1 | | | ECNT_RST1 | | 0x3F | R/W | | | 0x482 | ECNT_CTRL2 | RESE | RVED | | ECNT_ENA2 | | | ECNT_RST2 | | 0x3F | R/W | | | 0x483 | ECNT_CTRL3 | RESE | RVED | | ECNT_ENA3 | | | ECNT_RST3 | | 0x3F | R/W | | | 0x484 | ECNT_CTRL4 | RESE | RVED | | ECNT_ENA4 | | | ECNT_RST4 | | 0x3F | R/W | | | 0x485 | ECNT_CTRL5 | RESE | RVED | | ECNT_ENA5 | | | ECNT_RST5 | | 0x3F | R/W | | | 0x486 | ECNT_CTRL6 | RESE | RVED | | ECNT_ENA6 | | | ECNT_RST6 | | 0x3F | R/W | | | 0x487 | ECNT_CTRL7 | RESER | RVED | | ECNT_ENA7 | | | ECNT_RST7 | | 0x3F | R/W | | | 0x488 | ECNT_TCH0 | | | RESERVED | | | | ECNT_TCH0 | | 0x07 | R/W | | | 0x489 | ECNT_TCH1 | | | RESERVED | | | | ECNT_TCH1 | | 0x07 | R/W | | | 0x48A | ECNT_TCH2 | | | RESERVED | | | | ECNT_TCH2 | | 0x07 | R/W | | | 0x48B | ECNT_TCH3 | | | RESERVED | | | | ECNT_TCH3 | | 0x07 | R/W | | | 0x48C | ECNT_TCH4 | | | RESERVED | | | | ECNT_TCH4 | | 0x07 | R/W | | | 0x48D | ECNT TCH5 | | | RESERVED | | | | ECNT_TCH5 | | 0x07 | R/W | | | 0x48E | ECNT_TCH6 | | | RESERVED | | | | ECNT_TCH6 | | 0x07 | R/W | | | 0x48F | ECNT_TCH7 | | | RESERVED | | | | ECNT_TCH7 | | 0x07 | R/W | | | 0x490 | ECNT_STATO | | REG | SERVED | | LANE ENAO | | ECNT_TCR0 | | 0x00 | R | | | 0x490<br>0x491 | ECNT_STAT1 | | | SERVED | | LANE ENA1 | | ECNT_TCR1 | | 0x00 | R | | | | _ | | | | | | | | | | | | | 0x492 | ECNT_STAT2 | | | SERVED | | LANE_ENA2 | | ECNT_TCR2 | | 0x00 | R | | | 0x493 | ECNT_STAT3 | | | SERVED | | LANE_ENA3 | | ECNT_TCR3 | | 0x00 | R | | | 0x494 | ECNT_STAT4 | | | SERVED | | LANE_ENA4 | | ECNT_TCR4 | | 0x00 | R | | | 0x495 | ECNT_STATS | | | SERVED | | LANE_ENA5 | | ECNT_TCR5 | | 0x00 | R | | | 0x496 | ECNT_STAT6 | | | SERVED | | LANE_ENA6 | | ECNT_TCR6 | | 0x00 | R | | | 0x497 | ECNT_STATUS | DDEO | | SERVED | II Do | LANE_ENA7 | CICO | ECNT_TCR7 | 6660 | 0x00 | R | | | 0x4B0 | LINK_STATUS0 | BDE0 | NITO | UEK0 | ILD0 | ILS0 | CKS0 | FS0 | CGS0 | 0x00 | R | | | 0x4B1 | LINK_STATUS1 | BDE1 | NIT1 | UEK1 | ILD1 | ILS1 | CKS1 | FS1 | CGS1 | 0x00 | R | | | 0x4B2 | LINK_STATUS2 | BDE2 | NIT2 | UEK2 | ILD2 | ILS2 | CKS2 | FS2 | CGS2 | 0x00 | R | | | 0x4B3 | LINK_STATUS3 | BDE3 | NIT3 | UEK3 | ILD3 | ILS3 | CKS3 | FS3 | CGS3 | 0x00 | R | | | 0x4B4 | LINK_STATUS4 | BDE4 | NIT4 | UEK4 | ILD4 | ILS4 | CKS4 | FS4 | CGS4 | 0x00 | R | | | 0x4B5 | LINK_STATUS5 | BDE5 | NIT5 | UEK5 | ILD5 | ILS5 | CKS5 | FS5 | CGS5 | 0x00 | R | | | 0x4B6 | LINK_STATUS6 | BDE6 | NIT6 | UEK6 | ILD6 | ILS6 | CKS6 | FS6 | CGS6 | 0x00 | R | | | 0x4B7 | LINK_STATUS7 | BDE7 | NIT7 | UEK7 | ILD7 | ILS7 | CKS7 | FS7 | CGS7 | 0x00 | R | | | 0x4B8 | JESD_IRQ_<br>ENABLEA | EN_BDE | EN_NIT | EN_UEK | EN_ILD | EN_ILS | EN_CKS | EN_FS | EN_CGS | 0x00 | R/W | | | 0x4B9 | JESD_IRQ_<br>ENABLEB | | | | RESERVED | T | | | EN_ILAS | 0x00 | R/W | | | 0x4BA | JESD_IRQ_<br>STATUSA | IRQ_BDE | IRQ_NIT | IRQ_UEK | IRQ_ILD | IRQ_ILS | IRQ_CKS | IRQ_FS | IRQ_CGS | 0x00 | R/W | | | 0x4BB | JESD_IRQ_<br>STATUSB | | | | RESERVED | | | | IRQ_ILAS | 0x00 | R/W | | | 0x4BC | IRQ_OUTPUT_<br>MUX_JESD | | | | RESERVED | | | | MUX_JESD_<br>IRQ | 0x00 | R/W | | | 0x580 | BE_SOFT_OFF_<br>GAIN_CTRL | BE_SOFT_OFF<br>_GAIN_EN | | RESE | RVED | | BE | _GAIN_RAMP_F | RATE | 0x00 | R/W | | | 0x581 | BE_SOFT_OFF_<br>ENABLE | ENA_SHORT_<br>PAERR_<br>SOFTOFF | ENA_LONG_<br>PAERR_<br>SOFTOFF | RESERVED | | ENA_JESD_<br>ERR_<br>SOFTOFF | ROTATE_<br>SOFT_OFF_<br>EN | TXEN_SOF<br>T_OFF_EN | SPI_SOFT_<br>OFF_EN | 0xC6 | R/W | | | 0x582 | BE_SOFT_ON_<br>ENABLE | SPI_SOFT_<br>ON_EN | LONG_<br>LEVEL_<br>SOFTON_EN | | | RESERVE | ED | | | 0x40 | R/W | | | 0x583 | LONG_PA_<br>THRES_LSB | | LONG_PA_THRESHO | | | | | SHOLD[7:0] | | | | | | 0x584 | LONG_PA_<br>THRES_MSB | | RESERVED | | | | LONG_PA_THRESHOLD[12:8] | | | | R/W | | | 0x585 | LONG_PA_<br>CONTROL | LONG_PA_<br>ENABLE | | RESERVED | • | | LONG_PA | _AVG_TIME | | 0x00 | R/W | | | Reg | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset | RW | |-------|------------------------|---------------------|---------------------------|-----------------------|----------------|-----------------------------|--------------------------------|-----------------|---------------------|-------|-----| | 0x586 | LONG_PA_<br>POWER_LSB | | 1 | 1 | LONG_PA_POW | /ER[7:0] | 1 | 1 | | 0x00 | R | | 0x587 | LONG_PA_<br>POWER_MSB | | RESERVED | | | LONG | G_PA_POWER[12 | 2:8] | | 0x00 | R | | 0x588 | SHORT_PA_<br>THRES_LSB | | | | SHORT_PA_THRES | HOLD[7:0] | | | | 0x00 | R/W | | 0x589 | SHORT_PA_<br>THRES_MSB | | RESERVED | | | SHORT_ | PA_THRESHOLD | 0[12:8] | | 0x00 | R/W | | 0x58A | SHORT_PA_<br>CONTROL | SHORT_PA_<br>ENABLE | | | RESERVED | | | SHORT_P | A_AVG_TIME | 0x00 | R/W | | 0x58B | SHORT_PA_<br>POWER_LSB | | 1 | | SHORT_PA_POV | VER[7:0] | | 1 | | 0x00 | R | | 0x58C | SHORT_PA_<br>POWER_MSB | | RESERVED | | | SHOR | T_PA_POWER[1 | 2:8] | | 0x00 | R | | 0x58D | TXEN_SM_0 | | | | RESERVED | | | | ENA_<br>TXENSM | 0x50 | R/W | | 0x596 | BLANKING_<br>CTRL | | RES | SERVED | | SPI_TXEN | PI_TXEN ENA_SPI_ RESERVED TXEN | | | | R/W | | 0x597 | JESD_PA_INT0 | | | | JESD_PA_INT_CN | NTRL[7:0] | | | | 0x00 | R/W | | 0x598 | JESD_PA_INT1 | RESERVED | | | | | INT_ | 0x00 | R/W | | | | 0x599 | TXEN_FLUSH_<br>CTRL0 | | RESERVED SPI_FLUSH_<br>EN | | | | | | | 0x01 | R/W | | 0x705 | NVM_LOADER_<br>EN | | | | RESERVED | | | | NVM_BLR_<br>EN | 0x00 | R/W | | 0x790 | DACPLL_<br>PDCTRL0 | PLL_PD5 | | PLL_PD4 | | PLL_PD3 | PLL_PD2 | PLL_PD1 | PLL_PD0 | 0x02 | R/W | | 0x791 | DACPLL_<br>PDCTRL1 | | RESERVED | | PLL_PD10 | PLL_PD9 | PLL_PD8 | PLL_PD7 | PLL_PD6 | 0x00 | R/W | | 0x792 | DACPLL_CTRL0 | | | RESER | VED | | | D_CAL_<br>RESET | D_RESET_<br>VCO_DIV | 0x02 | R/W | | 0x793 | DACPLL_CTRL1 | | | RESER | VED | | | M_D | IVIDER-1 | 0x18 | R/W | | 0x794 | DACPLL_CTRL2 | RESE | RVED | | | DACPLL <sub></sub> | _CP | | | 0x04 | R/W | | 0x795 | DACPLL_CTRL3 | | RES | SERVED | | | D_CP_0 | CALBITS | | 0x08 | R/W | | 0x796 | DACPLL_CTRL4 | | PLL | _CTRL0 | | | RESE | RVED | | 0xD2 | R/W | | 0x797 | DACPLL_CTRL5 | RESE | RVED | | | PLL_CTF | RL1 | | | 0x20 | R/W | | 0x798 | DACPLL_CTRL6 | RESERVED | PLL_CTRL3 | | | PLL_CTF | RL2 | | | 0x1C | R/W | | 0x799 | DACPLL_CTRL7 | ADC_CLK | _DIVIDER | | | N_DIVID | ER | | | 0x08 | R/W | | 0x7A0 | DACPLL_CTRL9 | RESE | RVED | D_EN_VAR_<br>FINE_PRE | RESEF | RVED | D_EN_VAR_<br>COARSE_<br>PRE | RES | SERVED | 0x90 | R/W | | 0x7A2 | DACPLL_<br>CTRL10 | RESERVED | D_REGULAT | OR_CAL_WAIT | D_VCO_C | O_CAL_WAIT D_VCO_CAL_CYCLES | | | RESERVED | 0x35 | R/W | | 0x7B5 | PLL_STATUS | | 1 | | RESERVED | RESERVED PLL LOCK | | | | | | ## **REGISTER DETAILS** Table 60. Register Details | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------------------------------------|-------|----------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x000 | SPI_INTFCONFA | 7 | SOFTRESET_M | | Soft reset (mirror). Set this bit to mirror Bit 0. | 0x0 | R | | | | 6 | LSBFIRST_M | | LSB first (mirror). Set this bit to mirror Bit 1. | 0x0 | R | | | | 5 | ADDRINC_M | | Address increment (mirror). Set this bit to mirror Bit 2. | 0x0 | R | | | | 4 | SDOACTIVE_M | | SDO active (mirror). Set this bit to mirror Bit 3. | 0x0 | R | | | | 3 | SDOACTIVE | | SDO active. Enables 4-wire SPI bus mode. | 0x0 | R/W | | | | 2 | ADDRINC | | Address increment. When set, this bit causes incrementing streaming addresses; otherwise, descending addresses are generated. | 0x0 | R/W | | | | | | 1 | Streaming addresses are incremented. | | | | | | | | 0 | Streaming addresses are decremented. | | | | | | 1 | LSBFIRST | | LSB first. When set, this bit causes SPI input<br>and output data to be oriented as LSB first.<br>If this bit is clear, data is oriented as MSB first. | 0x0 | R/W | | | | | | 1 | Shift LSB in first. | | | | | | | | 0 | Shift MSB in first. | | | | | | 0 | SOFTRESET | 1 | Soft reset. This bit automatically clears to 0 after performing a reset operation. Setting this bit initiates a reset. This bit autoclears after the soft reset is complete. Pulse the soft reset line. | 0x0 | R/W | | | | | | 0 | Reset the soft reset line. | | | | 0x001 | SPI_INTFCONFB | 7 | SINGLEINS | - | Single instruction. | 0x0 | R/W | | 0,001 | 311_11111111111111111111111111111111111 | ' | Sirveleints | 1 | Perform single transfers. | - OAG | | | | | | | 0 | Perform multiple transfers. | | | | | | 6 | CSSTALL | | CS stalling. | 0x0 | R/W | | | | | | 0 | Disable CS stalling. | | | | | | | | 1 | Enable CS stalling. | | | | | | [5:0] | RESERVED | | Reserved. | 0x0 | R/W | | 0x003 | SPI_CHIPTYPE | [7:0] | CHIP_TYPE | | Chip type. | 0x4 | R | | 0x004 | SPI_PRODIDL | [7:0] | PROD_ID[7:0] | | Product ID. | 0x72 | R | | 0x005 | SPI_PRODIDH | [7:0] | PROD_ID[15:8] | | Product ID. | 0x91 | R | | 0x006 | SPI_CHIPGRADE | [7:4] | PROD_GRADE | | Product grade. | 0x0 | R | | | | [3:0] | DEV_REVISION | | Device revision. | 0x4 | R | | 0x008 | SPI_PAGEINDX | [7:6] | MAINDAC_PAGE | | Sets the main DAC paging. Each high bit in this field pages a DAC starting at the LSB. Both main DACs can be paged and programmed at the same time if desired. | 0x3 | R/W | | | | [5:0] | CHANNEL_PAGE | | Sets channel paging. Each high bit in this field pages a complex channel starting at the LSB. Multiple channels can be paged and programmed at a time if desired. | 0x3F | R/W | | 0x00A | SPI_SCRATCHPAD | [7:0] | SCRATCHPAD | | Scratch pad read/write register. | 0x0 | R/W | | 0x010 | CHIP_ID_L | [7:0] | CHIP_ID[7:0] | | Chip ID serial number. | 0x0 | R | | 0x011 | CHIP_ID_M1 | [7:0] | CHIP_ID[15:8] | | Chip ID serial number. | 0x0 | R | | 0x012 | CHIP_ID_M2 | [7:0] | CHIP_ID[23:16] | | Chip ID serial number. | 0x0 | R | | 0x013 | CHIP_ID_H | [7:0] | CHIP_ID[31:24] | | Chip ID serial number. | 0x0 | R | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-------------|-------|----------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x020 | IRQ_ENABLE | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | 4 | EN_SYSREF_JITTER | | Enable SYSREF± jitter interrupt. | 0x0 | R/W | | | | 3 | EN_DATA_READY | | Enable JESD204B receiver ready (JRX_DATA_READY) low interrupt. | 0x0 | R/W | | | | 2 | EN_LANE_FIFO | | Enable lane FIFO overflow/underflow interrupt. | 0x0 | R/W | | | | 1 | EN_PRBSQ | | Enable PRBS imaginary error interrupt. | 0x0 | R/W | | | | 0 | EN_PRBSI | | Enable PRBS real error interrupt. | 0x0 | R/W | | 0x021 | IRQ_ENABLE0 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | EN_DAC0_CAL_<br>DONE | | Enable DAC0 calibration complete interrupt. | 0x0 | R/W | | | | [2:1] | RESERVED | | Reserved. | 0x0 | R/W | | | | 0 | EN_PAERRO | | Enable PA protection error interrupt for DAC0. | 0x0 | R/W | | 0x022 | IRQ_ENABLE1 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | EN_DAC1_CAL_<br>DONE | | Enable DAC1 calibration complete interrupt. | 0x0 | R/W | | | | [2:1] | RESERVED | | Reserved. | 0x0 | R/W | | | | 0 | EN_PAERR1 | | Enable PA protection error interrupt for DAC1. | 0x0 | R/W | | 0x023 | IRQ_ENABLE2 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | 5 | EN_DLL_LOST | | Enable DLL lock lost interrupt. | 0x0 | R/W | | | | 4 | EN_DLL_LOCK | | Enable DLL lock interrupt. | 0x0 | R/W | | | | [3:2] | RESERVED | | Reserved. | 0x0 | R/W | | | | 1 | EN_PLL_LOST | | Enable PLL lock lost interrupt. | 0x0 | R/W | | | | 0 | EN_PLL_LOCK | | Enable PLL lock interrupt. | 0x0 | R/W | | 0x024 | IRQ_STATUS | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | 4 | IRQ_SYSREF_JITTER | | SYSREF± jitter too large. If EN_SYSREF_JITTER is low, IRQ_SYSREF_JITTER shows the current status. If EN_SYSREF_JITTER is high, IRQ_SYSREF_JITTER latches and pulls the IRQx pin low (x = the MUX_SYSREF_JITTER setting). Writing a 1 to IRQ_SYSREF_JITTER when latched clears the bit. | 0x0 | R/W | | | | 3 | IRQ_DATA_READY | | JESD204x receiver data ready is low. If EN_DATA_READY is low, IRQ_DATA_READY shows the current status. If EN_DATA_ READY is high, IRQ_DATA_READY latches and pulls the IRQx pin low (x = MUX_ DATA_READY setting). Writing a 1 to IRQ_ DATA_READY when latched clears the bit. | 0x0 | R/W | | | | 2 | IRQ_LANE_FIFO | | Lane FIFO overflow/underflow. If EN_<br>LANE_FIFO is low, IRQ_LANE_FIFO shows<br>the current status. If EN_LANE_FIFO is high,<br>IRQ_LANE_FIFO latches and pulls the IRQx<br>pin low (x = MUX_LANE_FIFO setting).<br>Writing a 1 to IRQ_LANE_FIFO when<br>latched clears the bit. | 0x0 | R/W | | | | 1 | IRQ_PRBSQ | | DAC1 PRBS error. If EN_PRBSQ is low, IRQ_PRBSQ shows the current status. If EN_PRBSQ is high, IRQ_PRBSQ latches and pulls the IRQx pin low (x = MUX_PRBSQ setting). Writing a 1 to IRQ_PRBSQ when latched clears the bit. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-------------|-------|-----------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 0 | IRQ_PRBSI | | DACO PRBS error. If EN_PRBSI is low, IRQ_PRBSI shows the current status. If EN_PRBSI is high, IRQ_PRBSI latches and pulls the IRQx pin low (x = MUX_PRBSI setting). Writing a 1 to IRQ_PRBSI when latched clears the bit. | 0x0 | R/W | | 0x025 | IRQ_STATUS0 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | 0.023 | INQ_STATUSU | 3 | IRQ_DACO_CAL_<br>DONE | | DACO calibration done. If EN_DACO_CAL_DONE is low, IRQ_DACO_CAL_DONE shows the current status. If EN_DACO_CAL_DONE is high, IRQ_DACO_CAL_DONE latches and pulls the IRQx pin low (x = MUX_DACO_CAL_DONE setting). Writing a 1 to IRQ_DACO_CAL_DONE when latched clears the bit. | 0x0 | R/W | | | | [2:1] | RESERVED | | Reserved. | 0x0 | R/W | | | | 0 | IRQ_PAERR0 | | DACO PA error. If EN_PAERRO is low, IRQ_PAERRO shows the current status. If EN_PAERRO is high, IRQ_PAERRO latches and pulls the IRQx pin low (x = MUX_PAERRO setting). Writing a 1 to IRQ_PAERRO when latched clears the bit. | 0x0 | R/W | | 0x026 | IRQ_STATUS1 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | IRQ_DAC1_CAL_<br>DONE | | DAC1 calibration done. If EN_DAC0_CAL_DONE is low, IRQ_DAC1_CAL_DONE shows the current status. If EN_DAC1_CAL_DONE is high, IRQ_DAC1_CAL_DONE latches and pulls the IRQx pin low (x = MUX_DAC1_CAL_DONE setting). Writing a 1 to IRQ_DAC1_CAL_DONE when latched clears the bit. | 0x0 | R/W | | | | [2:1] | RESERVED | | Reserved. | 0x0 | R/W | | | | 0 | IRQ_PAERR1 | | DAC1 PA error. If EN_PAERR1 is low, IRQ_PAERR1 shows the current status. If EN_PAERR1 is high, IRQ_PAERR1 latches and pulls the IRQx pin low (x = MUX_PAERR1 setting). Writing a 1 to IRQ_PAERR1 when latched clears the bit. | 0x0 | R/W | | 0x027 | IRQ_STATUS2 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | 5 | IRQ_DLL_LOST | | DLL lost. If EN_DLL_LOST is low, IRQ_DLL_LOST shows the current status. If EN_DLL_LOST is high, IRQ_DLL_LOST latches and pulls the IRQx pin low (x = MUX_DLL_LOST setting). Writing a 1 to IRQ_DLL_LOST when latched clears the bit. | 0x0 | R/W | | | | 4 | IRQ_DLL_LOCK | | DLL locked. If EN_DLL_LOCK is low, IRQ_DLL_LOCK shows current status. If EN_DLL_LOCK is high, IRQ_DLL_LOCK latches and pulls the IRQx pin low (x = MUX_DLL_LOCK setting). Writing a 1 to IRQ_DLL_LOCK when latched clears the bit. | 0x0 | R/W | | | | [3:2] | RESERVED | | Reserved. | 0x0 | R/W | | | | 1 | IRQ_PLL_LOST | | DAC PLL lock lost. If EN_PLL_LOST is low, IRQ_PLL_LOST shows the current status. If EN_PLL_LOST is high, IRQ_PLL_LOST latches and pulls the IRQx pin low (x = MUX_PLL_LOST setting). Writing a 1 to IRQ_PLL_LOST when latched clears the bit. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------------|-------|-----------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 0 | IRQ_PLL_LOCK | | DAC PLL locked. If EN_PLL_LOCK is low, IRQ_PLL_LOCK shows the current status. If EN_PLL_LOCK is high, IRQ_PLL_LOCK latches and pulls the IRQx pin low (x = MUX_PLL_LOCK setting). Writing a 1 to IRQ_PLL_LOCK when latched clears the bit. | 0x0 | R/W | | 0x028 | IRQ_OUTPUT_MUX | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | 4 | MUX_SYSREF_<br>JITTER | 0 | If EN_SYSREF_JITTER is set, this control chooses the IRQx output pin on which the event is triggered. Route IRQ trigger signal to the IRQ0 pin. Route IRQ trigger signal to the IRQ1 pin. | 0x0 | R/W | | | | 3 | MUX_DATA_READY | 0 | If EN_DATA_READY is set, this control chooses the IRQx output pin on which the event is triggered. Route IRQ trigger signal to the IRQ0 pin. Route IRQ trigger signal to the IRQ1 pin. | 0x0 | R/W | | | | 2 | MUX_LANE_FIFO | 0 | If EN_LANE_FIFO is set, this control chooses the IRQx output pin on which the event is triggered. Route IRQ trigger signal to the IRQ0 pin. Route IRQ trigger signal to the IRQ1 pin. | 0x0 | R/W | | | | 1 | MUX_PRBSQ | 0 | If EN_PRBSQ is set, this control chooses the IRQx output pin on which the event is triggered. Route IRQ trigger signal to the IRQ0 pin. Route IRQ trigger signal to the IRQ1 pin. | 0x0 | R/W | | | | 0 | MUX_PRBSI | 0 | If EN_PRBSI is set, this control chooses the IRQx output pin on which the event is triggered. Route IRQ trigger signal to the IRQ0 pin. Route IRQ trigger signal to the IRQ1 pin. | 0x0 | R/W | | 0x029 | IRQ_OUTPUT_MUX0 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | MUX_DACO_CAL_<br>DONE | 0 | If EN_DACO_CAL_DONE is set, this control chooses the IRQx output pin on which the event is triggered. Route IRQ trigger signal to the IRQ0 pin. Route IRQ trigger signal to the IRQ1 pin. | 0x0 | R/W | | | | [2:1] | RESERVED | | Reserved. | 0x0 | R/W | | | | 0 | MUX_PAERRO | 0 | If EN_PAERR0 is set, this control chooses the IRQx output pin on which the event is triggered. Route IRQ trigger signal to the IRQ0 pin. Route IRQ trigger signal to the IRQ1 pin. | 0x0 | R/W | | 0x02A | IRQ_OUTPUT_MUX1 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | MUX_DAC1_CAL_<br>DONE | 0 | If EN_DAC1_CAL_DONE is set, this control chooses the IRQx output pin on which the event is triggered. Route IRQ trigger signal to the IRQ0 pin. Route IRQ trigger signal to the IRQ1 pin. | 0x0 | R/W | | | 1 | [2:1] | RESERVED | | Reserved. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------------|-------|-------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 0 | MUX_PAERR1 | 0 | If EN_PAERR1 is set, this control chooses the IRQx output pin on which the event is triggered. Route IRQ trigger signal to the IRQ0 pin. | 0x0 | R/W | | | | | | 1 | Route IRQ trigger signal to the $\overline{\text{IRQ1}}$ pin. | | | | 0x02B | IRQ_OUTPUT_MUX2 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | 5 | MUX_DLL_LOST | 0 | If EN_DLL_LOST is set, this control chooses the IRQx output pin on which the event is triggered. Route IRQ trigger signal to the IRQ0 pin. Route IRQ trigger signal to the IRQ1 pin. | 0x0 | R/W | | | | 4 | MUX_DLL_LOCK | 0 | If EN_DLL_LOCK is set, this control chooses the IRQx output pin on which the event is triggered. Route IRQ trigger signal to the IRQ0 pin. Route IRQ trigger signal to the IRQ1 pin. | 0x0 | R/W | | | | [3:2] | RESERVED | | Reserved. | 0x0 | R/W | | | | 1 | MUX_PLL_LOST | 0 | If EN_PLL_LOST is set, this control chooses the IRQx pin on which the event is triggered. Route IRQ trigger signal to the IRQ0 pin. Route IRQ trigger signal to the IRQ1 pin. | 0x0 | R/W | | | | 0 | MUX_PLL_LOCK | 0 | If EN_PLL_LOCK is set, this control chooses the IRQx pin on which the event is triggered. Route IRQ trigger signal to the IRQ0 pin. Route IRQ trigger signal to the IRQ1 pin. | 0x0 | R/W | | 0x02C | IRQ_STATUS_ALL | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | IRQ_STATUS_ALL | | This bit is an OR of all the bits in Register 0x24 to Register 0x27. Writing a one to this bit clears any latched IRQx signals in Register 0x24 to Register 0x27. | 0x0 | R/W | | 0x036 | SYSREF_COUNT | [7:0] | SYSREF_COUNT | | Number of rising SYSREF± edges to ignore before synchronization (pulse counting mode). | 0x0 | R/W | | 0x039 | SYSREF_ERR_ | 7 | RESERVED | | Reserved. | 0x0 | R | | | WINDOW | [6:0] | SYSREF_ERR_<br>WINDOW | | Amount of jitter allowed on the SYSREF± input. SYSREF± jitter variations larger than this trigger an interrupt. Units are in DAC clocks. | 0x0 | R/W | | 0x03A | SYSREF_MODE | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | 4 | SYNC_ROTATION_<br>DONE | | Synchronization logic rotation complete flag. | 0x1 | R | | | | [3:2] | RESERVED | 1 | Reserved. | 0x0 | R | | | | 1 | SYSREF_MODE_<br>ONESHOT | | Enable one-shot synchronization rotation mode. | 0x0 | R/W | | | | | | 00 | Monitor mode. Status/error flag for IRQ_SYSREF_JITTER is 1 if the SYSREF± edge is outside the error window (Register 0x039, Bits[6:0]). Perform a single synchronization on the next | | | | | | | | | SYSREF±, then switch to monitor mode. | | | | | | 0 | RESERVED | 1 | Reserved. | 0x0 | R/W | | 0x03B | ROTATION_MODE | 7 | SYNCLOGIC_EN | | This bit must always be set to 1 (default) for both Subclass 0 and Subclass 1 operations. | 0x1 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-------------|-------|-------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------------| | | | 6 | RESERVED | | Reserved. For proper operation, write this bit to a 1. | 0x0 | R/W | | | | 5 | PERIODIC_RST_EN | | Synchronization required setting. Always set this bit to 1 for both Subclass 0 and Subclass 1 operation. | 0x1 | R/W | | | | 4 | NCORST_AFTER_<br>ROT_EN | | Set this bit to 1 to reset all NCOs after digital reset or synchronization rotation. Either this control or the START_NCO_SYNC bit (Register 0x1E7, Bit 0) can be used to reset all the NCOs (main and channel datapaths). | 0x1 | R/W | | | | [3:2] | RESERVED | | Reserved. | 0x0 | R | | | | [1:0] | ROTATION_MODE | 0 | Selects the circuitry to be reset when a synchronization rotation occurs. Certain bits being set to 1 determine the actions taken when a synchronization rotation is performed. Bit 0 corresponds to a SERDES clock reset and realignment. Bit 1 corresponds to a datapath soft off/on gain, which must only be used if PA protection is in use. If PA protection is not used, set Bit 1 to 0. No action, with either the SERDES clocks or the datapath, occurs when a synchronization rotation occurs. The links drop and the SERDES clocks are reset. It is recommended to set this bit high so that when a synchronization rotation is performed, the SERDES clocks realign properly. | 0x0 | R/W | | | | | | 10 | The datapath automatically uses the soft on/off functionality to turn on and off the datapath stream during a synchronization rotation to avoid corrupted data from being transmitted. Only use this feature if the PA protection block is in use. Both the SERDES clock reset and datapath | | | | | | | | | soft on/off feature are enabled. | | | | 0x03F | TX_ENABLE | 5 | RESERVED TXEN_DATAPATH_ DAC1 | 0 | Reserved. Selects whether the datapath of DAC1 is muted when the TXEN1 pin is brought low. Datapath output is normal. If TXEN1 = 0, the datapath output is | 0x0<br>0x0 | R/W<br>R/W | | | | | | | immediately zeroed. If TXEN1 = 1, the | | | | | | 4 | TXEN_DATAPATH_<br>DAC0 | 0 | datapath outputs normal operation. Selects whether the datapath of DAC0 is muted when the TXEN0 pin is brought low. Datapath output is normal. If TXEN0 = 0, the datapath output is | 0x0 | R/W | | | | | | | immediately zeroed. If TXEN0 = 1, the datapath outputs normal operation. | | | | | | [3:0] | RESERVED | | Reserved. | 0x0 | R/W | | 0x050 | CAL_CLK_DIV | [7:4] | RESERVED | | Reserved | 0x2 | R/W | | | | [3:0] | CAL_CLK_DIV | | Calibration register control. Set these bits to 0xA for optimized calibration setting. | 0x8 | R/W | | 0x051 | CAL_CTRL | 7 | CAL_CTRL0 | 0 | Calibration setting. Set this bit to 1. Reset the calibration engine. Enable the calibration routine. | 0x1 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|------------|-------|-----------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | [6:3] | RESERVED | | Reserved. | 0x0 | R/W | | | | [2:1] | CAL_CTRL1 | 1 | Calibration mode selection. Set this bit field to 1 for optimized calibration mode. Paged by the MAINDAC_PAGE bits in Register 0x008. | 0x1 | R/W | | | | 0 | CAL_START | 1 | Set calibration control setting. Start calibration. After starting calibration, do not write to any register from Register 0x051 to Register 0x061 until Register 0x052, Bit 2 reads low (indicating that the calibration is no longer active). Paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x052 | CAL_STAT | [7:3] | RESERVED | | Reserved. | 0x0 | R/W | | | | 2 | CAL_ACTIVE | | Calibration active status flag. A readback of 1 indicates the calibration routine is still in progress. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R | | | | 1 | CAL_FAIL_SEARCH | | Calibration failure flag. A readback of 1 indicates the calibration routine failed and is possibly not valid. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R | | | | 0 | CAL_FINISH | | Calibration complete flag. A readback of 1 indicates the calibration completed. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R | | )x059 | FSC0 | [7:2] | RESERVED | | Reserved. | 0xA | R/W | | | | [1:0] | FSC_CTRL[1:0] | | Sets the full-scale current control. This control is paged by the MAINDAC_PAGE bits in Register 0x008. Full-scale current = 15.6 mA + FSC_CTRL × (25/256) (mA). | 0x0 | R/W | | 0x05A | FSC1 | [7:0] | FSC_CTRL[9:2] | | Sets the full-scale current control. This control is paged by the MAINDAC_PAGE bits in Register 0x008. Full-scale current = 15.6 mA + FSC_CTRL × (25/256) (mA). | 0x28 | R/W | | 0x061 | CAL_DEBUG0 | 7 | RESERVED | | Reserved. | 0x0 | R/W | | | | 6 | CAL_CTRL2 | | Calibration control. Set this bit to 1 for optimized calibration setting. | 0x1 | R/W | | | | 5 | CAL_CTRL3 | | Calibration control. Set this bit to 1 for optimized calibration setting. | 0x1 | R/W | | | | 4 | RESERVED | | Reserved. | 0x0 | R/W | | | | 3 | CAL_CTRL4 | | Calibration control. Set this bit to 1 for optimized calibration setting. | 0x0 | R/W | | | | [2:0] | RESERVED | | Reserved. | 0x0 | R/W | | 0x081 | CLK_CTRL | [7:2] | RESERVED | | Reserved. | 0x0 | R/W | | | | 1 | CAL_CLK_PD1 | | After the calibration is complete for DAC1 (Register 0x052, Bit $0 = 1$ ), set this bit high to power down the calibration clock. | 0x0 | R/W | | | | 0 | CAL_CLK_PD0 | | After the calibration is complete for DAC0 (Register 0x052, Bit 0 = 1), set this bit high to power down the calibration clock. | 0x0 | R/W | | )x083 | NVM_CTRL0 | 7 | NVM_CTRL0A | | NVM register control for the ring oscillator. | 0x0 | R/W | | | | [6:2] | RESERVED | | Reserved. | 0x0 | R | | | | [1:0] | NVM_CTRL0B | 00<br>01 | NVM register control for the ring oscillator. Divide by 8. Divide by 16. | 0x2 | R/W | | | | | | 10 | Divide by 10. Divide by 32. | | | | | | 1 | | 11 | Divide by 64. | | 1 | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|---------------|-------|----------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x084 | SYSREF_CTRL | 7 | RESERVED | | Reserved. | 0x0 | R/W | | | | 6 | SYSREF_<br>INPUTMODE | | Sets the input mode type for the SYSREF± pins. | 0x0 | R/W | | | | | | 0 | AC couple SYSREF±. | | | | | | | | 1 | DC couple SYSREF±. | | | | | | [5:1] | RESERVED | | Reserved. | 0x0 | R/W | | | | 0 | SYSREF_PD | 0 | Power down the SYSREF± receiver and synchronization circuitry. If using Subclass 0, set this bit to 1 because the SYSREF± pins are not used. SYSREF± receiver is powered on. SYSREF± receiver is powered down. | 0x0 | R/W | | 0x085 | NVM_CTRL1 | 7 | RESERVED | | Reserved. | 0x0 | R | | | | [6:4] | NVM_CTRL1A | | NVM control. Set this control to 1 at the start of the configuration sequence (as shown in the Start-Up Sequence section) and set to 0 at the end of the start-up routine when no longer programming the device. | 0x1 | R/W | | | | [3:2] | RESERVED | | Reserved. | 0x0 | R | | | | 1 | NVM_CTRL1B | | NVM control. Set this control to 1 at the start of the configuration sequence (as shown in the Start-Up Sequence section) and set to 0 at the end of the start-up routine when no longer programming the device. | 0x1 | R/W | | | | 0 | NVM_CTRL1C | | NVM control. Set this control to 0 at the start | 0x1 | R/W | | | | | | | of the configuration sequence (as shown in<br>the Start-Up Sequence section) and set to 1<br>at the end of the start-up routine when no<br>longer programming the device. | | | | 0x08D | ADC_CLK_CTRL0 | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | CLKOUT_SWING | | Controls the swing level of the ADC clock driver. Note that swing can be negative (inverts clock). The calculation for Code 0 to Code 9 is as follows: ADC driver swing = 993 mV – CLKOUT_ SWING × 77 mV. The calculation for Code 10 to Code 19 is as follows: ADC driver swing = (20 – CLKOUT_SWING × 77 mV) – 1 V. | 0x0 | R/W | | 0x08F | ADC_CLK_CTRL2 | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | PD_CLKOUT_<br>DRIVER | | Powers down the CLKOUT± output driver. | 0x0 | R/W | | )x090 | DAC_POWERDOWN | [7:2] | RESERVED | | Reserved. | 0x0 | R | | | | 1 | DAC_PD1 | 0 | Powers down DAC1. Power up DAC1. | 0x1 | R/W | | | | | | 1 | Power down DAC1. | | | | | | 0 | DAC_PD0 | 0 | Powers down DAC0. Power up DAC0. | 0x1 | R/W | | | | | | 1 | Power down DAC0. | | | | 0x091 | ACLK_CTRL | [7:1] | RESERVED | | Reserved. | 0x0 | R/W | | | | 0 | ACLK_<br>POWERDOWN | | Analog clock receiver power-down. | 0x1 | R/W | | 0x094 | PLL_CLK_DIV | [7:2] | RESERVED | | Reserved. | 0x0 | R | | | | 1 | PLL_VCO_DIV3_EN | | Enable PLL output clock divide by 3. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------------|-------|----------------------|----------|--------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 0 | PLL_VCO_DIV2_EN | | Enable PLL output clock divide by 2. | 0x0 | R/W | | | | | | 0 | DAC clock = PLL VCO clock frequency. | | | | | | | | 1 | DAC clock = PLL VCO clock frequency $\div$ 2. | | | | 0x095 | PLL_BYPASS | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | PLL_BYPASS | | Enable direct clocking (bypassing the PLL clock). | 0x0 | R/W | | | | | | 0 | Use the internal PLL to generate the DAC clock. | | | | | | | | 1 | Bypass the PLL and directly clock with the DAC clock frequency. | | | | 0x09A | NVM_CTRL | 7 | PD_BGR | | Bias power-down. Set this bit to 1 to power down the internal bias. | 0x0 | R/W | | | | [6:0] | RESERVED | | Reserved. | 0x0 | R/W | | 0x0C0 | DELAY_LINE_PD | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | 5 | DLL_CTRL0B | | DLL control. Set this bit to 0 to power up the delay line during the device configuration sequence. | 0x1 | R/W | | | | 4 | DLL_CTRL0A | | DLL control. Set this bit to 0 to power up the delay line during the device configuration sequence. | 0x1 | R/W | | | | [3:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | DLL_PD | | Power down delay line. Set this bit to 0 to power up the delay line during the device configuration sequence. | 0x1 | R/W | | | | | | 0 | Power up and enable the delay line. | | | | | | | | 1 | Power down and bypass the delay line. | | | | 0x0C1 | DLL_CTRL0 | [7:6] | DLL_CTRL1C | | DAC control setting. Set this control to 1 for optimal performance. | 0x1 | R/W | | | | 5 | DLL_CTRL1B | | DLL control search mode. If the DAC frequency is <4.5 GHz, set this bit to 0; otherwise, set this bit to 1. | 0x1 | R/W | | | | [4:3] | DLL_CTRL1A | | DLL control search direction. Set this control to 1 for optimal performance. | 0x2 | R/W | | | | [2:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | DLL_ENABLE | | DLL controller enable. | 0x0 | R/W | | | | | | 0 | Disable DLL. | | | | | | | | 1 | Enable DLL. | | | | 0x0C3 | DLL_STATUS | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | DLL_LOCK | | DLL lock indicator. This control reads back 1 if the DLL locks. | 0x0 | R | | 0x0C7 | DLL_READ | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | DLL_READ_EN | | Enable DLL readback status. A transition of 0 to 1 updates the lock status bit readback in Register 0x0C3. | 0x0 | R/W | | 0x0CC | DLL_FINE_DELAY0 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | [5:0] | DLL_FINE_DELAY0 | | DLL delay control. | 0x0 | R/W | | 0x0CD | DLL_FINE_DELAY1 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | [5:0] | DLL_FINE_DELAY1 | | DLL delay control. | 0x0 | R/W | | 0x0DB | DLL_UPDATE | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | DLL_DELAY_<br>UPDATE | | DLL update control. A transition from 0 to 1 updates the DLL circuitry with the current register control settings. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |--------|----------------|-------|-----------------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x100 | DIG_RESET | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | DIG_DATAPATH_PD | 0 | Holds all digital logic (SERDES digital, digital clock generation, and digital datapath) in reset until clock tree is stable. Normal operating mode. Holds the digital logic in reset. Must be released (set to 0) after clocks to the chip are stable (PLL and DLL blocks are locked) to use the digital datapath. | 0x1 | R/W | | 0x110 | JESD_MODE | 7 | MODE_NOT_IN_<br>TABLE | | Programmed JESD204B mode and interpolation mode combination is not valid. Select a different combination. | 0x0 | R | | | | 6 | COM_SYNC | | Combine the SYNCOUTx± signals in dual link case. | 0x0 | R/W | | | | [5:0] | JESD_MODE | | Sets the JESD204B mode configuration. See Table 13 for the JESD204B supported operating modes and compatible interpolation rates. Bit 5 of this control determines single link (set to 0) or dual link (set to 1). Bits[4:0] set the desired JESD204B mode according to Table 13. | 0x20 | R/W | | 0x111 | INTRP_MODE | [7:4] | DP_INTERP_MODE | 0x1 | Sets main datapath interpolation rate. See Table 13 for the JESD204B supported operating modes and compatible JESD204B modes and channel interpolation rates. 1×. | 0x8 | R/W | | | | | | 0x2<br>0x4<br>0x6<br>0x8<br>0xC | 2x.<br>4x.<br>6x.<br>8x.<br>12x. | | | | | | [3:0] | CH_INTERP_MODE | 0x1<br>0x2<br>0x3<br>0x4<br>0x6<br>0x8 | Sets channel interpolation rate. See Table 13 for the JESD204B supported operating modes and compatible JESD204B modes and main datapath interpolation rates. 1×. 2×. 3×. 4×. 6×. 8×. | 0x4 | R/W | | 0x112 | DDSM_DATAPATH_ | [7:6] | RESERVED | OAO | Reserved. | 0x0 | R | | 0.7712 | CFG | [5:4] | DDSM_MODE | 00 | Modulator switch mode selection. This control chooses the mode of operation for the main datapath NCO being configured. This control is paged by the MAINDAC_PAGE bits in Register 0x008. DACO = 10; DAC1 = 11. | 0x0 | R/W | | | | | | 01<br>10<br>11 | DAC0 = 10, DAC1 = 11.<br>DAC0 = 10 + 11; DAC1 = Q0 + Q1.<br>DAC0 = 10; DAC1 = Q0.<br>DAC0 = 10 + 11; DAC1 = 0. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------|-------|---------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 3 | DDSM_NCO_EN | 0 | Main datapath modulation enable. If the JESD204B mode chosen is a complex mode (main datapath interpolation >1×), this bit must be set to 1 for each main datapath being used. If no modulation is desired, set the FTW to be 0. This control is paged by the MAINDAC_PAGE bits in Register 0x008. Disable main datapath NCO. | 0x0 | R/W | | | | | | 1 | Enable main datapath NCO. | | | | | | 2 | DDSM_<br>MODULUS_EN | 0 | Enable main datapath modulus DDS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. Disable modulus DDS. | 0x0 | R/W | | | | | 22014 651 | 1 | Enable modulus DDS. | 0.0 | D 044 | | | | 1 | DDSM_SEL_<br>SIDEBAND | | Selects upper or lower sideband from modulation result. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | | | | | 0 | Use upper sideband. | | | | | | | ENL CYALC ALL | 1 | Use lower sideband = spectral flip. | 0.1 | D // M | | | | 0 | EN_SYNC_ALL_<br>CHNL_NCO_RESETS | | Selects the signal channel NCOS used for resets and FTW updates. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x1 | R/W | | | | | | 0 | Channel NCOs reset or update their FTW based on channel NCO update requests. | | | | | | | | 1 | Channel NCOs reset or update their FTW based on main datapath NCO update requests. | | | | 0x113 | DDSM_FTW_ | 7 | RESERVED | | Reserved. | 0x0 | R | | | UPDATE | [6:4] | DDSM_FTW_REQ_<br>MODE | | Frequency tuning word automatic update mode. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | | | | | 000 | No automatic requests are generated when the FTW registers are written. | | | | | | | | 001 | Automatically generates a DDSM_FTW_<br>LOAD_REQ after DDSM_FTW Bits[7:0] are<br>written. | | | | | | | | 010 | Automatically generates a DDSM_FTW_<br>LOAD_REQ after DDSM_FTW Bits[15:8] are<br>written. | | | | | | | | 011 | Automatically generates a DDSM_FTW_<br>LOAD_REQ after DDSM_FTW Bits[23:16]<br>are written. | | | | | | | | 100 | Automatically generates a DDSM_FTW_<br>LOAD_REQ after DDSM_FTW Bits[31:24]<br>are written. | | | | | | | | 101 | Automatically generate a DDSM_FTW_<br>LOAD_REQ after DDSM_FTW Bits[39:32] is<br>written. | | | | | | | | 110 | Automatically generates a DDSM_FTW_<br>LOAD_REQ after DDSM_FTW Bits[47:40]<br>are written. | | | | | | 3 | RESERVED | | Reserved. | 0x0 | R | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------|-------|--------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 2 | DDSM_FTW_<br>LOAD_SYSREF | | Uses the next rising edge of SYSREF± to trigger FTW load and reset. This bit also loads the calibration tone FTW, as well as the main NCO FTW on a rising edge detection. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | | | 1 | DDSM_FTW_<br>LOAD_ACK | 0 | Frequency tuning word update acknow-ledge. This bit reads back 1 if the FTW and phase offset word is loaded properly. This control is paged by the MAINDAC_PAGE bits in Register 0x008. FTW is not loaded. FTW is loaded. | 0x0 | R | | | | 0 | DDSM_FTW_<br>LOAD_REQ | 0 | Frequency tuning word update request from the SPI. This bit also loads the calibration tone FTW, as well as the main NCO FTW on a rising edge detection. This control is paged by the MAINDAC_PAGE bits in Register 0x008. Clear DDSM_FTW_LOAD_ACK. 0 to 1 transition loads the FTW. | 0x0 | R/W | | 0x114 | DDSM_FTW0 | [7:0] | DDSM_FTW[7:0] | | Sets the main datapath NCO FTW. If DDSM_MODULUS_EN is low, the main datapath NCO frequency = $f_{DAC} \times (DDSM\_FTW/2^{48})$ . If DDSM_MODULUS_EN is high, the main datapath NCO frequency = $f_{DAC} \times (DDSM\_FTW + DDSM\_ACC\_DELTA/DDSM\_ACC\_MODULUS)/2^{48}$ . DDSM_ACC_DELTA must be >0. DDSM_ACC_DELTA must be >DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x115 | DDSM_FTW1 | [7:0] | DDSM_FTW[15:8] | | Sets the main datapath NCO FTW. If DDSM_MODULUS_EN is low, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSM_FTW/2 <sup>48</sup> . If DDSM_MODULUS_EN is high, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSM_FTW + DDSM_ACC_DELTA/DDSM_ACC_MODULUS)/2 <sup>48</sup> . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x116 | DDSM_FTW2 | [7:0] | DDSM_FTW[23:16] | | Sets the main datapath NCO FTW. If DDSM_MODULUS_EN is low, the main datapath NCO frequency = $f_{DAC} \times (DDSM\_FTW/2^{48}$ . If DDSM_MODULUS_EN is high, the main datapath NCO frequency = $f_{DAC} \times (DDSM\_FTW + DDSM\_ACC\_DELTA/DDSM\_ACC\_MODULUS)/2^{48}$ . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|------------------------|-------|-------------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x117 | DDSM_FTW3 | [7:0] | DDSM_FTW[31:24] | | Sets the main datapath NCO FTW. If DDSM_MODULUS_EN is low, the main datapath NCO frequency = $f_{DAC} \times (DDSM\_FTW/2^{48}$ . If DDSM_MODULUS_EN is high, the main datapath NCO frequency = $f_{DAC} \times (DDSM\_FTW + DDSM\_ACC\_DELTA/DDSM\_ACC\_MODULUS)/2^{48}$ . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x118 | DDSM_FTW4 | [7:0] | DDSM_FTW[39:32] | | Sets the main datapath NCO FTW. If DDSM_MODULUS_EN is low, the main datapath NCO frequency = $f_{DAC} \times (DDSM\_FTW/2^{48}$ . If DDSM_MODULUS_EN is high, the main datapath NCO frequency = $f_{DAC} \times (DDSM\_FTW + DDSM\_ACC\_DELTA/DDSM\_ACC\_MODULUS)/2^{48}$ . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x119 | DDSM_FTW5 | [7:0] | DDSM_FTW[47:40] | | Sets the main datapath NCO FTW. If DDSM_MODULUS_EN is low, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSM_FTW/2 <sup>48</sup> . If DDSM_MODULUS_EN is high, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSM_FTW + DDSM_ACC_DELTA/DDSM_ACC_MODULUS)/2 <sup>48</sup> . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x11C | DDSM_PHASE_<br>OFFSET0 | [7:0] | DDSM_NCO_<br>PHASE_OFFSET[7:0] | | Sets main datapath NCO phase offset. Code is in 16-bit, twos complement format. Degrees offset = $180 \times (\text{code}/2^{15})$ . This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x11D | DDSM_PHASE_<br>OFFSET1 | [7:0] | DDSM_NCO_<br>PHASE_<br>OFFSET[15:8] | | Sets main datapath NCO phase offset. Code is in 16-bit, twos complement format. Degrees offset = $180 \times (\text{code}/2^{15})$ . This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x124 | DDSM_ACC_<br>MODULUS0 | [7:0] | DDSM_ACC_<br>MODULUS[7:0] | | Sets DDSM_ACC_MODULUS. If DDSM_MODULUS_EN is high, the main datapath NCO frequency = $f_{DAC} \times (DDSM\_FTW + DDSM\_ACC\_DELTA/DDSM\_ACC\_MODULUS)/2^{48}$ . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x125 | DDSM_ACC_<br>MODULUS1 | [7:0] | DDSM_ACC_<br>MODULUS[15:8] | | Sets DDSM_ACC_MODULUS. If DDSM_MODULUS_EN is high, the main datapath NCO frequency = $f_{DAC} \times$ (DDSM_FTW + DDSM_ACC_DELTA/DDSM_ACC_MODULUS)/ $2^{48}$ . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------------------|-------|-----------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x126 | DDSM_ACC_<br>MODULUS2 | [7:0] | DDSM_ACC_<br>MODULUS[23:16] | | Sets DDSM_ACC_MODULUS. If DDSM_MODULUS_EN is high, the main datapath NCO frequency = $f_{DAC} \times (DDSM\_FTW + DDSM\_ACC\_DELTA/DDSM\_ACC\_MODULUS)/2^{48}$ . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x127 | DDSM_ACC_<br>MODULUS3 | [7:0] | DDSM_ACC_<br>MODULUS[31:24] | | Sets DDSM_ACC_MODULUS. If DDSM_MODULUS_EN is high, the main datapath NCO frequency = $f_{DAC} \times (DDSM\_FTW + DDSM\_ACC\_DELTA/DDSM\_ACC\_MODULUS)/2^{48}$ . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x128 | DDSM_ACC_<br>MODULUS4 | [7:0] | DDSM_ACC_<br>MODULUS[39:32] | | Sets DDSM_ACC_MODULUS. If DDSM_MODULUS_EN is high, the main datapath NCO frequency = $f_{DAC} \times (DDSM\_FTW + DDSM\_ACC\_DELTA/DDSM\_ACC\_MODULUS)/2^{48}$ . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x129 | DDSM_ACC_<br>MODULUS5 | [7:0] | DDSM_ACC_<br>MODULUS[47:40] | | Sets DDSM_ACC_MODULUS. If DDSM_MODULUS_EN is high, the main datapath NCO frequency = $f_{DAC} \times (DDSM\_FTW + DDSM\_ACC\_DELTA/DDSM\_ACC\_MODULUS)/2^{48}$ . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x12A | DDSM_ACC_DELTA0 | [7:0] | DDSM_ACC_<br>DELTA[7:0] | | Sets DDSM_ACC_DELTA. If DDSM_MODULUS_EN is high, main datapath NCO frequency = f <sub>DAC</sub> × (DDSM_FTW + DDSM_ACC_DELTA/DDSM_ACC_MODULUS)/2 <sup>48</sup> . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x12B | DDSM_ACC_DELTA1 | [7:0] | DDSM_ACC_<br>DELTA[15:8] | | Sets DDSM_ACC_DELTA. If DDSM_ MODULUS_EN is high, main datapath NCO frequency = f <sub>DAC</sub> × (DDSM_FTW + DDSM_ACC_DELTA/DDSM_ACC_MODULUS)/2 <sup>48</sup> . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x12C | DDSM_ACC_DELTA2 | [7:0] | DDSM_ACC_<br>DELTA[23:16] | | Sets DDSM_ACC_DELTA. If DDSM_ MODULUS_EN is high, main datapath NCO frequency = f <sub>DAC</sub> × (DDSM_FTW + DDSM_ACC_DELTA/DDSM_ACC_MODULUS)/2 <sup>48</sup> . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------------|-------|---------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x12D | DDSM_ACC_DELTA3 | [7:0] | DDSM_ACC_<br>DELTA[31:24] | | Sets DDSM_ACC_DELTA. If DDSM_MODULUS_EN is high, main datapath NCO frequency = $f_{DAC} \times (DDSM_FTW + DDSM_ACC_DELTA/DDSM_ACC_MODULUS)/2^{48}$ . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x12E | DDSM_ACC_DELTA4 | [7:0] | DDSM_ACC_<br>DELTA[39:32] | | Sets DDSM_ACC_DELTA. If DDSM_ MODULUS_EN is high, main datapath NCO frequency = fDAC × (DDSM_FTW + DDSM_ACC_DELTA/DDSM_ACC_MODULUS)/2 <sup>48</sup> . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x12F | DDSM_ACC_DELTA5 | [7:0] | DDSM_ACC_<br>DELTA[47:40] | | Sets DDSM_ACC_DELTA. If DDSM_ MODULUS_EN is high, main datapath NCO frequency = f <sub>DAC</sub> × (DDSM_FTW + DDSM_ACC_DELTA/DDSM_ACC_MODULUS)/2 <sup>48</sup> . DDSM_ACC_DELTA must be > 0. DDSM_ACC_DELTA must be > DDSM_ACC_MODULUS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x130 | DDSC_DATAPATH_ | 7 | RESERVED | | Reserved. | 0x0 | R | | | CFG | 6 | DDSC_NCO_EN | 0 | Channel datapath modulation enable. If the JESD204B mode chosen is a complex mode (channel interpolation >1×), this bit must be set to 1 for each channel datapath being used. If no modulation is desired, set the FTW to 0. This control is paged by the CHANNEL_PAGE bits in Register 0x008. Disable channel NCO. | 0x0 | R/W | | | | | | 1 | Enable channel NCO. | | | | | | [5:3] | RESERVED | | Reserved. | 0x0 | R/W | | | | 2 | DDSC_MODULUS_<br>EN | 0 | Enable channel modulus DDS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. Disable modulus DDS. | 0x0 | R/W | | | | | | 1 | Enable modulus DDS. | | | | | | 1 | DDSC_SEL_<br>SIDEBAND | 0 | Selects upper or lower sideband from modulation result. This control is paged by the CHANNEL_PAGE bits in Register 0x008. Use upper sideband. | 0x0 | R/W | | | | 0 | DDSC_EN_DC_<br>INPUT | 0 1 | Use lower sideband = spectral flip. Enable test tone generation by sending dc to input level to channel DDS. Set the amplitude in the DC_TEST_INPUT_ AMPLITUDE control (Register 0x148 and Register 0x149). This control is paged by the CHANNEL_PAGE bits in Register 0x008. Disable test tone generation. Enable test tone generation. | 0x0 | R/W | | 0x131 | DDSC_FTW_UPDATE | [7:3] | RESERVED | | Reserved. | 0x0 | R | | | | 2 | DDSC_FTW_<br>LOAD_SYSREF | | Use next rising edge of SYSREF± to trigger FTW load and reset. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------|-------|-----------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 1 | DDSC_FTW_<br>LOAD_ACK | 0 | Frequency tuning word update acknow-ledge bit. This bit reads back 1 if the FTW and phase offset word is loaded properly. This control is paged by the CHANNEL_PAGE bits in Register 0x008. FTW is not loaded. | 0x0 | R | | | | 0 | DDSC_FTW_ | 1 | FTW is loaded. Frequency tuning word update request | 0x0 | R/W | | | | | LOAD_REQ | | from the SPI. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | OXO | 11/ VV | | | | | | 0 | No FTW update. 0 to 1 transition loads the FTW. | | | | 0x132 | DDSC_FTW0 | [7:0] | DDSC_FTW[7:0] | | Sets the channel datapath NCO FTW. If DDSC_MODULUS_EN is low, the main datapath NCO frequency = $f_{DAC} \times$ (DDSC_FTW/2 <sup>48</sup> ). If DDSC_MODULUS_EN is high, main datapath NCO frequency = $f_{DAC} \times$ (DDSC_FTW + DDSC_ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x133 | DDSC_FTW1 | [7:0] | DDSC_FTW[15:8] | | Sets the channel datapath NCO FTW. If DDSC_MODULUS_EN is low, the main datapath NCO frequency = $f_{DAC} \times$ (DDSC_FTW/2 <sup>48</sup> ). If DDSC_MODULUS_EN is high, main datapath NCO frequency = $f_{DAC} \times$ (DDSC_FTW + DDSC_ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x134 | DDSC_FTW2 | [7:0] | DDSC_FTW[23:16] | | Sets the channel datapath NCO FTW. If DDSC_MODULUS_EN is low, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSC_FTW/2 <sup>48</sup> ). If DDSC_MODULUS_EN is high, main datapath NCO frequency = f <sub>DAC</sub> × (DDSC_FTW + DDSC_ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x135 | DDSC_FTW3 | [7:0] | DDSC_FTW[31:24] | | Sets the channel datapath NCO FTW. If DDSC_MODULUS_EN is low, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSC_FTW/2 <sup>48</sup> ). If DDSC_MODULUS_EN is high, main datapath NCO frequency = f <sub>DAC</sub> × (DDSC_FTW + DDSC_ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|------------------------|-------|-------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x136 | DDSC_FTW4 | [7:0] | DDSC_FTW[39:32] | | Sets the channel datapath NCO FTW. If DDSC_MODULUS_EN is low, the main datapath NCO frequency = f_DAC × (DDSC_FTW/2 <sup>48</sup> ). If DDSC_MODULUS_EN is high, main datapath NCO frequency = f_DAC × (DDSC_FTW + DDSC_ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x137 | DDSC_FTW5 | [7:0] | DDSC_FTW[47:40] | | Sets the channel datapath NCO FTW. If DDSC_MODULUS_EN is low, the main datapath NCO frequency = f_DAC × (DDSC_FTW/2 <sup>48</sup> ). If DDSC_MODULUS_EN is high, main datapath NCO frequency = f_DAC × (DDSC_FTW + DDSC_ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x138 | DDSC_PHASE_<br>OFFSET0 | [7:0] | DDSC_NCO_<br>PHASE_OFFSET[7:0] | | Sets the channel NCO phase offset. Code is in 16-bit, twos complement format. Degrees offset = $180 \times (\text{code}/2^{15})$ . This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x139 | DDSC_PHASE_<br>OFFSET1 | [7:0] | DDSC_NCO_<br>PHASE_<br>OFFSET[15:8] | | Sets the channel NCO phase offset. Code is in 16-bit, twos complement format. Degrees offset = $180 \times (\text{code}/2^{15})$ . This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x13A | DDSC_ACC_<br>MODULUS0 | [7:0] | DDSC_ACC_<br>MODULUS[7:0] | | Sets DDSC_ACC_MODULUS. If DDSC_MODULUS_EN is high, the main datapath NCO frequency = fDAC × (DDSC_FTW + DDSC_ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_DELTA must be > DDSC_ACC_DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x13B | DDSC_ACC_<br>MODULUS1 | [7:0] | DDSC_ACC_<br>MODULUS[15:8] | | Sets DDSC_ACC_MODULUS. If DDSC_MODULUS_EN is high, the main datapath NCO frequency = fDAC × (DDSC_FTW + DDSC_ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x13C | DDSC_ACC_<br>MODULUS2 | [7:0] | DDSC_ACC_<br>MODULUS[23:16] | | Sets DDSC_ACC_MODULUS. If DDSC_MODULUS_EN is high, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSC_FTW + DDSC_ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------------------|-------|-----------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x13D | DDSC_ACC_<br>MODULUS3 | [7:0] | DDSC_ACC_<br>MODULUS[31:24] | | Sets DDSC_ACC_MODULUS. If DDSC_MODULUS_EN is high, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSC_FTW + DDSC_ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x13E | DDSC_ACC_<br>MODULUS4 | [7:0] | DDSC_ACC_<br>MODULUS[39:32] | | Sets DDSC_ACC_MODULUS. If DDSC_MODULUS_EN is high, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSC_FTW + DDSC_ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x13F | DDSC_ACC_<br>MODULUS5 | [7:0] | DDSC_ACC_<br>MODULUS[47:40] | | Sets DDSC_ACC_MODULUS. If DDSC_ MODULUS_EN is high, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSC_FTW + DDSC_ ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_ DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_ PAGE bits in Register 0x008. | 0x0 | R/W | | 0x140 | DDSC_ACC_DELTA0 | [7:0] | DDSC_ACC_<br>DELTA[7:0] | | Sets DDSC_ACC_DELTA. If DDSC_MODULUS_EN is high, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSC_FTW + DDSC_ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x141 | DDSC_ACC_<br>DELTA1 | [7:0] | DDSC_ACC_<br>DELTA[15:8] | | Sets DDSC_ACC_DELTA. If DDSC_ MODULUS_EN is high, the main datapath NCO frequency = f_DAC × (DDSC_FTW + DDSC_ ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ ACC_DELTA must be > DDSC_ACC_ MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x142 | DDSC_ACC_DELTA2 | [7:0] | DDSC_ACC_<br>DELTA[23:16] | | Sets DDSC_ACC_DELTA. If DDSC_MODULUS_EN is high, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSC_FTW + DDSC_ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ACC_DELTA must be > DDSC_ACC_MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x143 | DDSC_ACC_DELTA3 | [7:0] | DDSC_ACC_<br>DELTA[31:24] | | Sets DDSC_ACC_DELTA. If DDSC_ MODULUS_EN is high, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSC_FTW + DDSC_ ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ ACC_DELTA must be > DDSC_ACC_ MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------------|-------|-----------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x144 | DDSC_ACC_DELTA4 | [7:0] | DDSC_ACC_<br>DELTA[39:32] | | Sets DDSC_ACC_DELTA. If DDSC_<br>MODULUS_EN is high, the main datapath<br>NCO frequency = f <sub>DAC</sub> × (DDSC_FTW + DDSC_<br>ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> .<br>DDSC_ACC_DELTA must be > 0. DDSC_<br>ACC_DELTA must be > DDSC_ACC_<br>MODULUS. This control is paged by the<br>CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x145 | DDSC_ACC_DELTA5 | [7:0] | DDSC_ACC_<br>DELTA[47:40] | | Sets DDSC_ACC_DELTA. If DDSC_ MODULUS_EN is high, the main datapath NCO frequency = f <sub>DAC</sub> × (DDSC_FTW + DDSC_ ACC_DELTA/DDSC_ACC_MODULUS)/2 <sup>48</sup> . DDSC_ACC_DELTA must be > 0. DDSC_ ACC_DELTA must be > DDSC_ACC_ MODULUS. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x146 | CHNL_GAIN0 | [7:0] | CHNL_GAIN[7:0] | | Sets the scalar channel gain value. This control is paged by the CHANNEL_PAGE bits in Register 0x008. Channel gain = CHNL_GAIN/2 <sup>11</sup> . | 0x0 | R/W | | 0x147 | CHNL_GAIN1 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | [3:0] | CHNL_GAIN[11:8] | | Sets the scalar channel gain value. This control is paged by the CHANNEL_PAGE bits in Register 0x008. Channel gain = CHNL_GAIN/2 <sup>11</sup> . | 0x8 | R/W | | 0x148 | DC_CAL_TONE0 | [7:0] | DC_TEST_INPUT_<br>AMPLITUDE[7:0] | | DC test tone amplitude. This amplitude goes to both I and Q paths. Set these bits to 0x7FFF for a full-scale tone and ensure DDSC_EN_DC_INPUT in Register 0x130 Bit 0 is set to 1. This control is paged by the CHANNEL_PAGE control in Register 0x008. | 0x0 | R/W | | 0x149 | DC_CAL_TONE1 | [7:0] | DC_TEST_INPUT_<br>AMPLITUDE[15:8] | | DC test tone amplitude. This amplitude goes to both I and Q paths. Set to 0x7FFF for a full-scale tone and ensure that DDSC_EN_DC_INPUT (Register 0x130, Bit 0) is set to 1. This control is paged by the CHANNEL_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x14B | PRBS | 7 | PRBS_GOOD_Q | 1 0 | DAC1 good data indicator. Correct PRBS sequence detected. Incorrect sequence detected. Sticky; reset to 1 by PRBS_RESET. | 0x0 | R | | | | 6 | PRBS_GOOD_I | 0 | DACO good data indicator. Incorrect sequence detected. Sticky; reset to 1 by PRBS_RESET. Correct PRBS sequence detected. | 0x0 | R | | | | 5 | RESERVED | † | Reserved. | 0x0 | R | | | | 4 | PRBS_INV_Q | 1 | DAC1 data inversion. | 0x1 | R/W | | | | | | 0 | Expect normal data. | | | | | | | | 1 | Expect inverted data. | | | | | | 3 | PRBS_INV_I | | DAC0 data inversion. | 0x0 | R/W | | | | | | 0 | Expect inverted data | | | | | | 2 | PRBS_MODE | 1 | Expect inverted data. Select which PRBS polynomial is used for | 0x0 | R/W | | | | 2 | LKD2_MODE | 0 | the datapath PRBS test. 7-bit: $x^7 + x^6 + 1$ . | UXU | K/VV | | | | | | 1 | 15-bit: $x^{15} + x^{14} + 1$ . | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|---------------|-------|-------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 1 | PRBS_RESET | | Reset error counters. | 0x0 | R/W | | | | | | 0 | Normal operation. | | | | | | | | 1 | Reset counters. | | | | | | 0 | PRBS_EN | | Enable PRBS checker. | 0x0 | R/W | | | | | | 0 | Disable. | | | | | | | | 1 | Enable. | | | | 0x14C | PRBS_ERROR_I | [7:0] | PRBS_COUNT_I | | DAC0 PRBS error count. | 0x0 | R | | 0x14D | PRBS_ERROR_Q | [7:0] | PRBS_COUNT_Q | | DAC1 PRBS error count. | 0x0 | R | | 0x14E | PRBS_CHANSEL | [7:3] | RESERVED | | Reserved. | 0x0 | R | | | | [2:0] | PRBS_CHANSEL | 0 | Selects the channel to which the PRBS_<br>GOOD_x and PRBS_COUNT_x bit field<br>readbacks correspond.<br>Select Channel 0 for PRBS_COUNT_x and | 0x7 | R/W | | | | | | 1 | PRBS_GOOD_x (Channel 0, DAC0). Select Channel 1 for PRBS_COUNT_x and PRBS_GOOD_x (Channel 1, DAC0). | | | | | | | | 2 | Select Channel 2 for PRBS_COUNT_x and PRBS_GOOD_x (Channel 2, DAC0). | | | | | | | | 3 | Select Channel 3 for PRBS_COUNT_x and PRBS_GOOD_x (Channel 0, DAC1). | | | | | | | | 4 | Select Channel 4 for PRBS_COUNT_x and PRBS_GOOD_x (Channel 1, DAC1). | | | | | | | | 5 | Select Channel 5 for PRBS_COUNT_x and PRBS_GOOD_x (Channel 2, DAC1). | | | | | | | | 6 | OR all channels for PRBS_GOOD_x, sum all channels for PRBS_COUNT_x. | | | | 0x151 | DECODE_MODE | [7:6] | RESERVED | | Reserved. | 0x0 | R/W | | | | [5:4] | MSB_MODE | | MSB shuffling control. | 0x0 | R/W | | | | [3:0] | RESERVED | | Reserved. | 0x0 | R | | 0x1DE | SPI_ENABLE | [7:2] | RESERVED | | Reserved. | 0x0 | R | | | | 1 | SPI_EN1 | | Enable SPI control. | 0x1 | R/W | | | | 0 | SPI_EN0 | | Enable SPI control. | 0x1 | R/W | | 0x1E2 | DDSM_CAL_FTW0 | [7:0] | DDSM_CAL_<br>FTW[7:0] | | FTW of the calibration accumulator. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x1E3 | DDSM_CAL_FTW1 | [7:0] | DDSM_CAL_<br>FTW[15:8] | | FTW of the calibration accumulator. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x1E4 | DDSM_CAL_FTW2 | [7:0] | DDSM_CAL_<br>FTW[23:16] | | FTW of the calibration accumulator. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x1E5 | DDSM_CAL_FTW3 | [7:0] | DDSM_CAL_<br>FTW[31:24] | | FTW of the calibration accumulator. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x1E6 | DDSM_CAL_ | [7:3] | RESERVED | | Reserved. | 0x0 | R | | | MODE_DEF | 2 | DDSM_EN_CAL_<br>ACC | 0 | Enable clock calibration accumulator. This bit must be first set high, and then must load the calibration FTW into Register 0x1E2 to Register 0x1E5 to take effect. This control is paged by the MAINDAC_PAGE bits in Register 0x008. Disabled (does not clock the calibration frequency accumulator). Enables (turns on the clock to the calibration frequency accumulator). | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|---------------------------|-------|---------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 1 | DDSM_EN_CAL_<br>DC_INPUT | | Enable dc input to calibration DDS. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | | | | | 0 | Mux in datapath signal to the input of the final DDS. | | | | | | | | 1 | Mux in dc to the input of the final DDS. | | | | | | 0 | DDSM_EN_CAL_<br>FREQ_TUNE | | Enable tuning of the signal to calibration frequency for DAC0 only. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | | | | | 0 | Disable calibration frequency tuning. | | | | | | | | 1 | Enable calibration frequency tuning. | | | | 0x1E7 | DATAPATH_NCO_<br>SYNC_CFG | [7:2] | RESERVED | | Reserved. | 0x0 | R | | | | 1 | ALL_NCO_SYNC_<br>ACK | | Acknowledge signal that all the active NCOs are loaded. This bit is the acknowledge indicator for both the START_NCO_SYNC bit (Bit 0 of this register) and the NCORST_AFTER_ROT_EN bit (Register 0x03B, Bit 4) method of resetting the NCOs. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R | | | | 0 | START_NCO_SYNC | | Used to start the sync of the NCOs on a rising edge of the SPI bit or SYSREF± signal, depending on which is chosen as the update trigger. Upon receiving a trigger, the FTWs are loaded first, and then a synchronization occurs. This control is paged by the MAINDAC_PAGE bits in Register 0x008. | 0x0 | R/W | | 0x200 | MASTER_PD | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | SERDES_MASTER_<br>PD | | Powers down the entire JESD204B Rx analog (all eight channels and bias). | 0x1 | R/W | | 0x201 | PHY_PD | [7:0] | PHY_PD | | SPI override to power down the individual PHYs. Bit 0 controls the SERDIN0± PHY. Bit 1 controls the SERDIN1± PHY. Bit 2 controls the SERDIN2± PHY. Bit 3 controls the SERDIN3± PHY. Bit 4 controls the SERDIN4± PHY. Bit 5 controls the SERDIN5± PHY. | OxEE | R/W | | | | | | | Bit 6 controls the SERDING± PHY. | | | | | | | | | Bit 7 controls the SERDIN7± PHY. | | | | 0x203 | GENERIC_PD | [7:2] | RESERVED | | Reserved. | 0x0 | R | | | | 1 | PD_SYNCOUT0 | | Powers down the SYNCOUT0± driver. | 0x0 | R/W | | | | | | 0 | Enables the SYNCOUT0± output pins. | | | | | | | | 1 | Powers down the SYNCOUT0± output pins. | | | | | | 0 | PD_SYNCOUT1 | | Powers down the SYNCOUT1± driver. | 0x1 | R/W | | | | | _ | 0 | Enables the SYNCOUT1± output pins. | | | | | | | | 1 | Powers down the SYNCOUT1± output pins. | | | | 0x206 | CDR_RESET | [7:1] | RESERVED | <u> </u> | Reserved. | 0x0 | R | | 0A200 | CDIL_ILIDE1 | 0 | CDR_PHY_RESET | | PHY reset control bit. Set this bit to 1 to | 0x0 | R/W | | | | | CDIL_I III_IILDL1 | | take the PHYs out of reset during device operation. | | 10, 44 | | 0x210 | CBUS_ADDR | [7:0] | SERDES_CBUS_<br>ADDR | | SERDES configuration control register to set SERDES configuration address controls. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------------------|-------|-------------------------------------|----------|--------------------------------------------------------------------------------------------------|-------|--------| | 0x212 | CBUS_WRSTROBE_<br>PHY | [7:0] | SERDES_CBUS_<br>WR0 | | SERDES configuration control register to commit the SERDES configuration controls written. | 0x0 | R/W | | 0x213 | CBUS_WRSTROBE_ | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | OTHER | 0 | SERDES_CBUS_<br>WR1 | | SERDES configuration control register to commit the SERDES configuration controls written. | 0x0 | R/W | | 0x216 | CBUS_WDATA | [7:0] | SERDES_CBUS_<br>DATA | | SERDES configuration control register to set the SERDES configuration control data. | 0x0 | R/W | | 0x240 | EQ_BOOST_PHY_<br>3_0 | [7:6] | EQ_BOOST_PHY3 | | Equalizer setting for PHY 3 based on insertion loss of the system. | 0x3 | R/W | | | | | | 10 | Insertion loss ≤ 11 dB. | | | | | | [[.4] | FO BOOKE BLIVE | 11 | Insertion loss > 11 dB. | 0.42 | D/M/ | | | | [5:4] | EQ_BOOST_PHY2 | 10 | Equalizer setting for PHY 2 based on insertion loss of the system. Insertion loss < 11 dB. | 0x3 | R/W | | | | | | 10<br>11 | Insertion loss ≤ 11 dB. Insertion loss > 11 dB. | | | | | | [3:2] | EQ_BOOST_PHY1 | 11 | Equalizer setting for PHY 1 based on | 0x3 | R/W | | | | [3.2] | EQ_BOOSI_PHII | | insertion loss of the system. | UXS | IN/ VV | | | | | | 10 | Insertion loss ≤ 11 dB. | | | | | | | | 11 | Insertion loss > 11 dB. | | | | | | [1:0] | EQ_BOOST_PHY0 | | Equalizer setting for PHY 0 based on insertion loss of the system. | 0x3 | R/W | | | | | | 10 | Insertion loss ≤ 11 dB. | | | | | | | | 11 | Insertion loss > 11 dB. | | | | 0x234 | CDR_BITINVERSE | | SEL_IF_<br>PARDATAINV_DES_<br>RC_CH | | Output data inversion bit controls. Set Bit x corresponding to PHY x to invert the bit polarity. | 0x66 | R/W | | | | | INC_CIT | 0 | Not inverted. | | | | | | | | 1 | Inverted. | | | | 0x241 | EQ_BOOST_PHY_<br>7_4 | [7:6] | EQ_BOOST_PHY7 | | Equalizer setting for PHY 7 based on insertion loss of the system. | 0x3 | R/W | | | | | | 10 | Insertion loss ≤ 11 dB. | | | | | | | | 11 | Insertion loss > 11 dB. | | | | | | [5:4] | EQ_BOOST_PHY6 | | Equalizer setting for PHY 6 based on insertion loss of the system. | 0x3 | R/W | | | | | | 10 | Insertion loss ≤ 11 dB. | | | | | | | | 11 | Insertion loss > 11 dB. | | | | | | [3:2] | EQ_BOOST_PHY5 | | Equalizer setting for PHY 5 based on insertion loss of the system. | 0x3 | R/W | | | | | | 10 | Insertion loss ≤ 11 dB. | | | | | | | | 11 | Insertion loss > 11 dB. | | | | | | [1:0] | EQ_BOOST_PHY4 | | Equalizer setting for PHY 4 based on insertion loss of the system. | 0x3 | R/W | | | | | | 10 | Insertion loss ≤ 11 dB. | | | | | | | | 11 | Insertion loss > 11 dB. | - | - | | 0x242 | EQ_GAIN_PHY_3_0 | [7:6] | EQ_GAIN_PHY3 | | Equalizer gain for PHY 3 based on insertion loss of the system. | 0x3 | R/W | | | | | | 01 | Insertion loss ≤ 11 dB. | | | | | | [[ 43 | FO CAIN DUNG | 11 | Insertion loss > 11 dB. | 02 | D/A/ | | | | [5:4] | EQ_GAIN_PHY2 | 01 | Equalizer gain for PHY 2 based on insertion loss of the system. | 0x3 | R/W | | | | | | 01 | Insertion loss ≤ 11 dB. | | | | | | | | 11 | Insertion loss > 11 dB. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------------|-------|----------------------|----------|---------------------------------------------------------------------------------------------|-------|--------| | | | [3:2] | EQ_GAIN_PHY1 | | Equalizer gain for PHY 1 based on insertion loss of the system. | 0x3 | R/W | | | | | | 01 | Insertion loss ≤ 11 dB. | | | | | | | | 11 | Insertion loss > 11 dB. | | | | | | [1:0] | EQ_GAIN_PHY0 | | Equalizer gain for PHY 0 based on insertion loss of the system. | 0x3 | R/W | | | | | | 01 | Insertion loss ≤ 11 dB. | | | | | | | | 11 | Insertion loss > 11 dB. | | | | 0x243 | EQ_GAIN_PHY_7_4 | [7:6] | EQ_GAIN_PHY7 | | Equalizer gain for PHY 7 based on insertion loss of the system. | 0x3 | R/W | | | | | | 01 | Insertion loss ≤ 11 dB. | | | | | | | | 11 | Insertion loss > 11 dB. | | | | | | [5:4] | EQ_GAIN_PHY6 | | Equalizer gain for PHY 6 based on insertion loss of the system. | 0x3 | R/W | | | | | | 01 | Insertion loss ≤ 11 dB. | | | | | | | | 11 | Insertion loss > 11 dB. | | | | | | [3:2] | EQ_GAIN_PHY5 | | Equalizer gain for PHY 5 based on insertion loss of the system. | 0x3 | R/W | | | | | | 01 | Insertion loss ≤ 11 dB. | | | | | | | | 11 | Insertion loss > 11 dB. | | | | | | [1:0] | EQ_GAIN_PHY4 | | Equalizer gain for PHY 4 based on insertion loss of the system. | 0x3 | R/W | | | | | | 01 | Insertion loss ≤ 11 dB. | | | | | | | | 11 | Insertion loss > 11 dB. | | | | 0x244 | EQ_FB_PHY_0 | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | EQ_PHY_0 | | SERDES equalizer setting for PHY0. Set this control to 0x1F for optimal performance. | 0x19 | R/W | | 0x245 | EQ_FB_PHY_1 | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | EQ_PHY1 | | SERDES equalizer setting for PHY1. Set this control to 0x1F for optimal performance. | 0x19 | R/W | | 0x246 | EQ_FB_PHY_2 | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | EQ_PHY2 | | SERDES equalizer setting for PHY2. Set this control to 0x1F for optimal performance. | 0x19 | R/W | | 0x247 | EQ_FB_PHY_3 | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | EQ_PHY3 | | SERDES equalizer setting for PHY3. Set this control to 0x1F for optimal performance. | 0x19 | R/W | | 0x248 | EQ_FB_PHY_4 | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | EQ_PHY4 | | SERDES equalizer setting for PHY4. Set this control to 0x1F for optimal performance. | 0x19 | R/W | | 0x249 | EQ_FB_PHY_5 | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | EQ_PHY5 | | SERDES equalizer setting for PHY5. Set this control to 0x1F for optimal performance. | 0x19 | R/W | | 0x24A | EQ_FB_PHY_6 | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | EQ_PHY6 | | SERDES equalizer setting for PHY6. Set this control to 0x1F for optimal performance. | 0x19 | R/W | | 0x24B | EQ_FB_PHY_7 | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | EQ_PHY7 | | SERDES equalizer setting for PHY7. Set this control to 0x1F for optimal performance. | 0x19 | R/W | | 0x250 | LBT_REG_CNTRL_0 | [7:0] | EN_LBT_DES_RC_<br>CH | | Enable loopback test for desired physical lanes per PHY, with Bit x corresponding to PHY x. | 0x0 | R/W | | 0x251 | LBT_REG_CNTRL_1 | [7:2] | RESERVED | 1 | Reserved. | 0x0 | R | | | _ = = = | | 1 | 1 | l . | 1 | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------------|-------|-----------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 1 | EN_LBT_<br>HALFRATE_DES_RC | | Enables half rate mode for the loopback test. If this bit is set to 1, the output data rate = 2× the input clock frequency. If this bit is set to 0, the output data rate = the input clock frequency. | 0x1 | R/W | | | | 0 | INIT_LBT_SYNC_<br>DES_RC | | Initiate the loopback test by toggling this bit from 0 to 1, then back to 0. | 0x0 | R/W | | 0x253 | SYNCOUTO_CTRL | [7:1] | RESERVED | | Reserved. | 0x0 | R/W | | | | 0 | SEL_SYNCOUTO_<br>MODE | 0 | This control determines the output driver mode for the SYNCOUTO± pin operation. Both SYNCOUTO± and SYNCOUT1± must be set to the same mode of operation. SYNCOUTO± is set to CMOS output. SYNCOUTO± is set to LVDS output. | 0x0 | R/W | | 0x254 | SYNCOUT1_CTRL | [7:1] | RESERVED | | Reserved. | 0x0 | R/W | | | | 0 | SEL_SYNCOUT1_<br>MODE | 0 | This control determines the output driver mode for the SYNCOUT1± pin operation. Both SYNCOUT0± and SYNCOUT1± must be set to the same mode of operation. SYNCOUT1± is set to CMOS output. SYNCOUT1± is set to LVDS output. | 0x0 | R/W | | 0x280 | PLL_ENABLE_CTRL | [7:3] | RESERVED | | Reserved. | 0x0 | R | | | | 2 | LOLSTICKYCLEAR_<br>LCPLL_RC | | Clears out loss of lock bit. | 0x0 | R/W | | | | 1 | LDSYNTH_LCPLL_<br>RC | | Pulse high to start VCO calibration (without restarting the regulator or remeasuring the temperature). | 0x0 | R/W | | | | 0 | SERDES_PLL_<br>STARTUP | | SERDES circuitry blocks are powered off when this bit is set to 0. Set this bit to 1 at the end of the SERDES configuration writes. When this bit is set to 1, it powers up the SERDES PLL blocks and starts the LDO and calibration routine to lock the PLL automatically to the appropriate lane rate based on the JESD204B mode and interpolation options programmed in the device. The SERDES_PLL_LOCK bit (Register 0x281, Bit 0) reads 1 when the PLL achieves lock. | 0x1 | R/W | | 0x281 | PLL_STATUS | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | SERDES_PLL_LOCK | | PLL is locked when this bit is high. | 0x0 | R | | 0x300 | GENERAL_JRX_ | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | CTRL_0 | 3 | LINK_MODE | | Reads back 0 when in single-link mode and 1 when in dual-link mode. | 0x0 | R/W | | | | 2 | LINK_PAGE | 0 | Link paging. This bit selects which link register map is used. This paging affects Register 0x400 to Register 0x4BB. Page QBD0 for Link 0. Page QBD1 for Link 1. | 0x0 | R/W | | | | [1:0] | LINK_EN | | These bits bring up the JESD204B digital Rx when all link parameters are programmed and all clocks are ready. Bit 0 applies to Link 0, whereas Bit 1 applies to Link 1. Link 1 is only available in dual-link mode. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|--------------|-------|------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x302 | DYN_LINK_ | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | LATENCY_0 | [5:0] | DYN_LINK_<br>LATENCY_0 | | Dynamic link latency, Link 0. Latency between the LMFC Rx for Link 0 and the last arriving LMFC boundary in units of PCLK cycles. | 0x0 | R | | 0x303 | DYN_LINK_ | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | LATENCY_1 | [5:0] | DYN_LINK_<br>LATENCY_1 | | Dynamic link latency, Link 1. Latency between the LMFC Rx for Link 1 and the last arriving LMFC boundary in units of PCLK cycles. | 0x0 | R | | 0x304 | LMFC_DELAY_0 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | [5:0] | LMFC_DELAY_0 | | LMFC delay, Link 0. Delay from the LMFC to the LMFC Rx for Link 0 in units of PCLK cycles. | 0x0 | R/W | | 0x305 | LMFC_DELAY_1 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | [5:0] | LMFC_DELAY_1 | | LMFC delay, Link 1. Delay from the LMFC to the LMFC Rx for Link 1 in units of PCLK cycles. | 0x0 | R/W | | 0x306 | LMFC_VAR_0 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | [5:0] | LMFC_VAR_0 | | Variable delay buffer, Link 0. These bits set when data is read from a buffer to be consistent across links and power cycles (in units of PCLK cycles). The maximum value is 0xC. | 0x3F | R/W | | 0x307 | LMFC_VAR_1 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | [5:0] | LMFC_VAR_1 | | Variable delay buffer, Link 1. These bits set when data is read from a buffer to be consistent across links and power cycles (in units of PCLK cycles). The maximum value is 0xC. | 0x3F | R/W | | 0x308 | XBAR_LN_0_1 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | [5:3] | LOGICAL LANEO | 000<br>001<br>010<br>011<br>100<br>101<br>110 | Logical Lane 1 source. These bits select a physical lane to be mapped onto Logical Lane 1. Data is from SERDIN0±. Data is from SERDIN1±. Data is from SERDIN2±. Data is from SERDIN3±. Data is from SERDIN4±. Data is from SERDIN5±. Data is from SERDIN5±. Data is from SERDIN5±. | 0x1 | R/W | | | | [2:0] | SRC | 000<br>001<br>010<br>011<br>100<br>101<br>110 | Logical Lane 0 source. These bits select a physical lane to be mapped onto Logical Lane 0. Data is from SERDIN0±. Data is from SERDIN1±. Data is from SERDIN2±. Data is from SERDIN3±. Data is from SERDIN4±. Data is from SERDIN5±. Data is from SERDIN6±. Data is from SERDIN6±. Data is from SERDIN7±. | 0x0 | R/W | | 0x309 | XBAR_LN_2_3 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | [5:3] | LOGICAL_LANE3_<br>SRC | 000 | Logical Lane 3 source. These bits select a physical lane to be mapped onto Logical Lane 3. Data is from SERDINO±. | 0x3 | R/W | | | | | | 001 | Data is from SERDIN1±. | | | | | | 1 | 1 | 010 | Data is from SERDIN2±. | | 1 | | SRC physical lane to be mapped onto Logical Lane 2. | 0x2<br>0x0<br>0x5 | R/W R/W | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------| | 101 Data is from SERDIN5±. 110 Data is from SERDIN5±. 111 Data is from SERDIN7±. 111 Data is from SERDIN7±. 111 Data is from SERDIN7±. 111 Data is from SERDIN7±. 111 Data is from SERDIN0±. 111 Data is from SERDIN0±. 111 Data is from SERDIN3±. 100 Data is from SERDIN3±. 100 Data is from SERDIN3±. 101 Data is from SERDIN5±. 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. 111 Data is from SERDIN7±. 112 Data is from SERDIN7±. 113 Data is from SERDIN7±. 114 Data is from SERDIN7±. 115 Data is from SERDIN7±. 116 Data is from SERDIN1±. 117 Data is from SERDIN1±. 118 Data is from SERDIN1±. 119 Data is from SERDIN1±. 110 Data is from SERDIN1±. 110 Data is from SERDIN1±. 110 Data is from SERDIN1±. 110 Data is from SERDIN1±. 110 Data is from SERDIN1±. 110 Data is from SERDIN7±. 111 Data is from SERDIN7±. 111 Data is from SERDIN7±. 111 Data is from SERDIN7±. 111 Data is from SERDIN7±. 111 Data is from SERDIN7±. 111 Data is from SERDIN7±. 112 Data is from SERDIN7±. 113 Data is from SERDIN7±. 114 Data is from SERDIN7±. 115 Data is from SERDIN7±. 116 Data is from SERDIN7±. 117 Data is from SERDIN7±. 118 Data is from SERDIN7±. 119 Data is from SERDIN7±. 110 Data is from SERDIN7±. 111 | 0x0 | R | | Data is from SERDIND*±. | 0x0 | R | | Data is from SERDIN7±. | 0x0 | R | | [2:0] LOGICAL_LANE2_ SRC LOGICAL_LANE2_ SRC Logical Lane 2 source. These bits select a physical lane to be mapped onto Logical Lane 2. Data is from SERDIN0±. | 0x0 | R | | SRC physical lane to be mapped onto Logical Lane 2. | 0x0 | R | | Lane 2. Data is from SERDINO±. | | | | 001 Data is from SERDIN1±. 010 Data is from SERDIN3±. 100 Data is from SERDIN4±. 101 Data is from SERDIN5±. 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. 0x30A XBAR_LN_4_5 [7:6] RESERVED Reserved. [5:3] LOGICAL_LANE5_ SRC 100 Data is from SERDIN0±. 001 Data is from SERDIN1±. 001 Data is from SERDIN1±. 001 Data is from SERDIN1±. 001 Data is from SERDIN3±. 001 Data is from SERDIN3±. 100 Data is from SERDIN4±. 101 Data is from SERDIN5±. 110 Data is from SERDIN5±. 110 Data is from SERDIN5±. 110 Data is from SERDIN7±. [2:0] LOGICAL_LANE4_ SRC 12:0] LOGICAL_LANE4_ SRC 000 Data is from SERDIN7±. 000 Data is from SERDIN7±. 000 Data is from SERDIN7±. 000 Data is from SERDIN7±. 000 Data is from SERDIN7±. 000 Data is from SERDIN7±. 000 Data is from SERDIN1±. | | | | 010 Data is from SERDIN2±. 011 Data is from SERDIN3±. 100 Data is from SERDIN4±. 101 Data is from SERDIN5±. 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. 0x30A XBAR_LN_4_5 [7:6] RESERVED Reserved. [5:3] LOGICAL_LANE5_ SRC 000 Data is from SERDIN0±. 001 Data is from SERDIN0±. 001 Data is from SERDIN0±. 010 Data is from SERDIN1±. 010 Data is from SERDIN3±. 100 Data is from SERDIN4±. 101 Data is from SERDIN5±. 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. [2:0] LOGICAL_LANE4_ SRC 111 Data is from SERDIN7±. 112 Data is from SERDIN7±. 113 Data is from SERDIN7±. 114 Data is from SERDIN7±. 115 Data is from SERDIN7±. 116 Data is from SERDIN7±. 117 Data is from SERDIN7±. 118 Data is from SERDIN7±. 119 Data is from SERDIN7±. 110 Data is from SERDIN7±. 110 Data is from SERDIN0±. 111 | | | | 011 Data is from SERDIN3±. 100 Data is from SERDIN4±. 101 Data is from SERDIN5±. 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. 0x30A XBAR_LN_4_5 [7:6] RESERVED Reserved. [5:3] LOGICAL_LANE5_ SRC Logical Lane 5 source. These bits select a physical lane to be mapped onto Logical Lane 5. 000 Data is from SERDIN0±. 001 Data is from SERDIN0±. 010 Data is from SERDIN3±. 100 Data is from SERDIN4±. 101 Data is from SERDIN5±. 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. 110 Data is from SERDIN7±. 111 Data is from SERDIN7±. 112 Data is from SERDIN7±. 113 Data is from SERDIN7±. 14 Data is from SERDIN7±. 15 Data is from SERDIN7±. 16 Data is from SERDIN7±. 17 Data is from SERDIN7±. 18 Data is from SERDIN7±. 19 Data is from SERDIN0±. 10 Data is from SERDIN0±. 11 | | | | Data is from SERDIN4±. Data is from SERDIN5±. Data is from SERDIN5±. Data is from SERDIN7±. Data is from SERDIN7±. Data is from SERDIN7±. Data is from SERDIN7±. Data is from SERDIN7±. Data is from SERDIN7±. Data is from SERDIN0±. Data is from SERDIN1±. Data is from SERDIN1±. Data is from SERDIN1±. Data is from SERDIN3±. Data is from SERDIN3±. Data is from SERDIN5±. Data is from SERDIN5±. Data is from SERDIN5±. Data is from SERDIN6±. Data is from SERDIN6±. Data is from SERDIN7±. SERDIN0±. SERDIN | | | | Data is from SERDIN5±. Data is from SERDIN5±. | | | | Data is from SERDIN6±. Data is from SERDIN7±. [7:6] RESERVED [5:3] LOGICAL_LANE5_ SRC Data is from SERDIN0±. Data is from SERDIN0±. Data is from SERDIN0±. Data is from SERDIN1±. Data is from SERDIN3±. Data is from SERDIN3±. Data is from SERDIN5±. Data is from SERDIN5±. Data is from SERDIN6±. Data is from SERDIN5±. Data is from SERDIN7±. [2:0] LOGICAL_LANE4_ SRC Data is from SERDIN7±. Data is from SERDIN7±. Data is from SERDIN7±. Data is from SERDIN7±. Data is from SERDIN7±. Data is from SERDIN7±. Data is from SERDIN0±. | | | | 0x30A XBAR_LN_4_5 [7:6] RESERVED Reserved. (5:3] LOGICAL_LANE5_ SRC Logical Lane 5 source. These bits select a physical lane to be mapped onto Logical Lane 5. 000 Data is from SERDIN0±. 001 Data is from SERDIN1±. 010 Data is from SERDIN3±. 100 Data is from SERDIN4±. 101 Data is from SERDIN5±. 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. [2:0] LOGICAL_LANE4_ SRC LOGICAL_LANE4_ SRC Logical Lane 4 source. These bits select a physical lane to be mapped onto Logical Lane 4. 000 Data is from SERDIN0±. 001 Data is from SERDIN0±. 002 Data is from SERDIN0±. 003 Data is from SERDIN0±. 004 Data is from SERDIN0±. 005 Data is from SERDIN0±. 007 Data is from SERDIN0±. 008 Data is from SERDIN0±. 009 Data is from SERDIN0±. | | | | Time | | | | [5:3] LOGICAL_LANE5_ SRC Logical Lane 5 source. These bits select a physical lane to be mapped onto Logical Lane 5. 000 Data is from SERDIN0±. 001 Data is from SERDIN1±. 010 Data is from SERDIN3±. 100 Data is from SERDIN4±. 101 Data is from SERDIN5±. 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. [2:0] LOGICAL_LANE4_ SRC Logical Lane 4 source. These bits select a physical lane to be mapped onto Logical Lane 4. 000 Data is from SERDIN0±. 001 Data is from SERDIN0±. | | | | SRC physical lane to be mapped onto Logical Lane 5. 000 Data is from SERDIN0±. 001 Data is from SERDIN1±. 010 Data is from SERDIN3±. 100 Data is from SERDIN4±. 101 Data is from SERDIN5±. 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. [2:0] LOGICAL_LANE4_ SRC LOGICAL_LANE4_ SRC Data is from SERDIN0±. 000 Data is from SERDIN0±. | 0x5 | R/W | | 001 Data is from SERDIN1±. 010 Data is from SERDIN2±. 011 Data is from SERDIN3±. 100 Data is from SERDIN4±. 101 Data is from SERDIN5±. 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. [2:0] LOGICAL_LANE4_ SRC 100 Data is from SERDIN7±. 100 Data is from SERDIN7±. 100 Data is from SERDIN7±. 100 Data is from SERDIN1±. | | | | 010 Data is from SERDIN2±. 011 Data is from SERDIN3±. 100 Data is from SERDIN4±. 101 Data is from SERDIN5±. 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. [2:0] LOGICAL_LANE4_ SRC 12:0] LOGICAL_LANE4_ SRC 000 Data is from SERDIN0±. 001 Data is from SERDIN1±. | | | | 011 Data is from SERDIN3±. 100 Data is from SERDIN4±. 101 Data is from SERDIN5±. 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. [2:0] LOGICAL_LANE4_ SRC [2:0] LOGICAL_LANE4_ SRC 000 Data is from SERDIN0±. 001 Data is from SERDIN1±. | | | | 100 Data is from SERDIN4±. 101 Data is from SERDIN6±. 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. [2:0] LOGICAL_LANE4_ SRC Logical Lane 4 source. These bits select a physical lane to be mapped onto Logical Lane 4. 000 Data is from SERDIN0±. 001 Data is from SERDIN1±. | | | | Data is from SERDIN5±. Data is from SERDIN6±. Data is from SERDIN6±. Data is from SERDIN7±. Data is from SERDIN7±. Logical Lane 4 source. These bits select a physical lane to be mapped onto Logical Lane 4. Data is from SERDIN0±. Data is from SERDIN1±. | | | | 110 Data is from SERDIN6±. 111 Data is from SERDIN7±. [2:0] LOGICAL_LANE4_ SRC Logical Lane 4 source. These bits select a physical lane to be mapped onto Logical Lane 4. 000 Data is from SERDIN0±. 001 Data is from SERDIN1±. | | | | [2:0] LOGICAL_LANE4_ SRC LOGICAL_LANE4_ O00 Data is from SERDIN7±. Data is from SERDIN7±. | | | | [2:0] LOGICAL_LANE4_ SRC Logical Lane 4 source. These bits select a physical lane to be mapped onto Logical Lane 4. 000 Data is from SERDIN0±. Data is from SERDIN1±. | | | | SRC physical lane to be mapped onto Logical Lane 4. 000 Data is from SERDIN0±. 001 Data is from SERDIN1±. | | | | 001 Data is from SERDIN1±. | 0x4 | R/W | | | | | | | | | | 010 Data is from SERDIN2±. | | | | 011 Data is from SERDIN3±. | | | | 100 Data is from SERDIN4±. | | | | 101 Data is from SERDIN5±. | | | | 110 Data is from SERDIN6±. | | | | 111 Data is from SERDIN7±. | | | | 0x30B XBAR_LN_6_7 [7:6] RESERVED Reserved. | 0x0 | R | | [5:3] LOGICAL_LANE7_ Logical Lane 7 source. These bits select a physical lane to be mapped onto Logical Lane 7. | 0x7 | R/W | | 000 Data is from SERDIN0±. | | | | 001 Data is from SERDIN1±. | | | | 010 Data is from SERDIN2±. | | | | 011 Data is from SERDIN3±. | | | | 100 Data is from SERDIN4±. | 1 | | | 101 Data is from SERDIN5±. | 1 | | | 110 Data is from SERDIN6±. | | | | 111 Data is from SERDIN7±. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-------------------|-------|-----------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | [2:0] | LOGICAL_LANE6_<br>SRC | | Logical Lane 6 source. These bits select a physical lane to be mapped onto Logical Lane 6. | 0x6 | R/W | | | | | | 000 | Data is from SERDIN0±. | | | | | | | | 001 | Data is from SERDIN1±. | | | | | | | | 010 | Data is from SERDIN2±. | | | | | | | | 011 | Data is from SERDIN3±. | | | | | | | | 100 | Data is from SERDIN4±. | | | | | | | | 101 | Data is from SERDIN5±. | | | | | | | | 110 | Data is from SERDIN6±. | | | | | | | | 111 | Data is from SERDIN7±. | | | | 0x30C | FIFO_STATUS_REG_0 | [7:0] | LANE_FIFO_FULL | | Bit x corresponds to FIFO full flag for data from SERDINx±. | 0x0 | R | | 0x30D | FIFO_STATUS_REG_1 | [7:0] | LANE_FIFO_EMPTY | | Bit x corresponds to FIFO empty flag for data from SERDINx±. | 0x0 | R | | 0x311 | SYNCOUT_GEN_0 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | EOMF_MASK_1 | | Mask end of multiframe (EOMF) from QBD1. Assert SYNCOUT1± based on the loss of the multiframe synchronization. | 0x0 | R/W | | | | | | 0 | Do not assert SYNCOUT1± on loss of | | | | | | | | | multiframe. | | | | | | | | 1 | Assert $\overline{\text{SYNCOUT1}}\pm \text{ on loss of multiframe.}$ | | | | | | 2 | EOMF_MASK_0 | | Mask EOMF from QBD0. Assert SYNCOUT0± based on the loss of the multiframe synchronization. | 0x0 | R/W | | | | | | 0 | Do not assert SYNCOUTO± on loss of | | | | | | | | | multiframe. | | | | | | | | 1 | Assert SYNCOUT0± on loss of multiframe. | | | | | | 1 | EOF_MASK_1 | | Mask EOF from QBD1. Assert SYNCOUT1± | 0x0 | R/W | | | | | LOI _W/\S\\_1 | | based on loss of frame synchronization. | 0.00 | 10, 00 | | | | | | 0 | Do not assert SYNCOUT1± on loss of frame. | | | | | | | | 1 | Assert SYNCOUT1± on loss of frame. | | | | | | 0 | EOF_MASK_0 | ' | Mask EOF from QBD0. Assert SYNCOUT0± | 0x0 | R/W | | | | 0 | EOF_MASK_U | | based on loss of frame synchronization. | UXU | K/VV | | | | | | 0 | Do not assert SYNCOUT0± on loss of frame. | | | | | | | | | Assert SYNCOUTO± on loss of frame. | | | | | CONTROLLE CENT 4 | F= 43 | <u> </u> | 1 | | | D 044 | | 0x312 | SYNCOUT_GEN_1 | [7:4] | SYNC_ERR_DUR | | Duration of SYNCOUTx± low for the purposes of the synchronization error report. Duration = (0.5 + code) PCLK cycles. To most closely match the specified value, set these bits as close as possible to f/2 PCLK cycles. These bits are shared between SYNCOUT0± and SYNCOUT1±. | 0x0 | R/W | | | | [3:0] | RESERVED | | Reserved. | 0x0 | R/W | | 0x315 | PHY_PRBS_TEST_EN | [7:0] | PHY_TEST_EN | | Enable PHY BER by ungating the clocks. | 0x0 | R/W | | | | | | 0 | PHY test disable. | | | | | | | | 1 | PHY test enable. | | | | 0x316 | PHY_PRBS_TEST_ | 7 | RESERVED | | Reserved. | 0x0 | R | | | CTRL | [6:4] | PHY_SRC_ERR_CNT | | | 0x0 | R/W | | | | | | 000 | Report Lane 0 error count. | | | | | | | | 001 | Report Lane 1 error count. | | | | | | | | 010 | Report Lane 2 error count. | | | | | | | | 011 | Report Lane 3 error count. | | | | | | | | 100 | Report Lane 4 error count. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |----------|---------------------------------|-------|-----------------------------|----------|------------------------------------------------------------------------------|-------|----------| | | | | | 101 | Report Lane 5 error count. | | | | | | | | 110 | Report Lane 6 error count. | | | | | | | | 111 | Report Lane 7 error count. | | | | | | [3:2] | PHY_PRBS_PAT_SEL | | Select PRBS pattern for PHY BER test. | 0x0 | R/W | | | | | | 00 | PRBS7. | | | | | | | | 01 | PRBS15. | | | | | | | | 10 | PRBS31. | | | | | | | | 11 | Not used. | | | | | | 1 | PHY_TEST_START | | Starts and stops the PHY PRBS test. | 0x0 | R/W | | | | | | 0 | Test not started. | 0,10 | ' ' ' | | | | | | 1 | Test started. | | | | | | 0 | PHY_TEST_RESET | <u> </u> | Resets PHY PRBS test state machine and | 0x0 | R/W | | | | U | TITI_TEST_NESET | | error counters. | UNU | 11/ VV | | | | | | 0 | Not reset. | | | | | | | | 1 | Reset. | | | | 0x317 | PHY_PRBS_TEST_ | [7:0] | PHY_PRBS_ | ' | Bits[7:0] of the 24-bit threshold value to set | 0x0 | R/W | | JA317 | THRESHOLD_<br>LOBITS | [7.0] | THRESHOLD_<br>LOBITS | | the error flag for the PHY PRBS test. | OXO | 10,00 | | 0x318 | PHY_PRBS_TEST_ | [7:0] | PHY_PRBS_ | | Bits[15:8] of the 24-bit threshold value to | 0x0 | R/W | | | THRESHOLD_ | | THRESHOLD_ | | set the error flag for the PHY PRBS test. | | | | | MIDBITS | | MIDBITS | | | | | | 0x319 | PHY_PRBS_TEST_ | [7:0] | PHY_PRBS_ | | Bits[23:16] of the 24-bit threshold value to | 0x0 | R/W | | | THRESHOLD_HIBITS | | THRESHOLD_<br>HIBITS | | set the error flag for the PHY PRBS test. | | | | ) 2 1 A | DLIV DDDC TECT | [7.0] | | | District Ol of the 224 his many outsid DLIV DED | 00 | - | | )x31A | PHY_PRBS_TEST_<br>ERRCNT_LOBITS | [7:0] | PHY_PRBS_ERR_<br>CNT_LOBITS | | Bits[7:0] of the 24-bit reported PHY BER error count from the selected lane. | 0x0 | R | | 0x31B | PHY_PRBS_TEST_ | [7:0] | PHY_PRBS_ERR_ | | Bits[15:8] of the 24-bit reported PHY BER | 0x0 | R | | JXSID | ERRCNT_MIDBITS | [7:0] | CNT_MIDBITS | | error count from the selected lane. | UXU | l n | | 0x31C | PHY_PRBS_TEST_ | [7:0] | PHY_PRBS_ERR_ | | Bits[23:16] of the 24-bit reported PHY BER | 0x0 | R | | ),,,,,,, | ERRCNT_HIBITS | [7.0] | CNT_HIBITS | | error count from the selected lane. | OXO | ' | | 0x31D | PHY_PRBS_TEST_ | [7:0] | PHY_PRBS_PASS | | Reports PHY BER pass/fail for each lane. | 0xFF | R | | | STATUS | | | | Bit x is high when Lane x passes. | | | | 0x31E | PHY_DATA_ | [7:2] | RESERVED | | Reserved. | 0x0 | R | | | SNAPSHOT_CTRL | 1 | PHY_GRAB_MODE | | This bit determines whether to use the | 0x0 | R/W | | | | | | | trigger to grab data. | | | | | | | | 0 | Grab data when PHY_GRAB_DATA is set. | | | | | | | | 1 | Grab data upon bit error. | | | | | | 0 | PHY_GRAB_DATA | | Transitioning this bit from 0 to 1 causes the | 0x0 | R/W | | | | | | | logic to store current receive data from one | | | | | | | | | lane. | | | | 0x31F | PHY_SNAPSHOT_ | [7:0] | PHY_SNAPSHOT_ | | Current data received. Represents | 0x0 | R | | | DATA_BYTE0 | | DATA_BYTE0 | | PHY_SNAPSHOT_DATA[7:0]. | | | | 0x320 | PHY_SNAPSHOT_ | [7:0] | PHY_SNAPSHOT_ | | Current data received. Represents | 0x0 | R | | | DATA_BYTE1 | r= -1 | DATA_BYTE1 | | PHY_SNAPSHOT_DATA[15:8]. | | | | 0x321 | PHY_SNAPSHOT_ | [7:0] | PHY_SNAPSHOT_ | | Current data received. Represents | 0x0 | R | | 2222 | DATA_BYTE2 | [7.0] | DATA_BYTE2 | | PHY_SNAPSHOT_DATA[23:16]. | 00 | <u> </u> | | )x322 | PHY_SNAPSHOT_<br>DATA_BYTE3 | [7:0] | PHY_SNAPSHOT_<br>DATA_BYTE3 | | Current data received. Represents PHY_SNAPSHOT_DATA[31:24]. | 0x0 | R | | 0x323 | _ | [7.0] | | | | 0.40 | R | | JAJ23 | PHY_SNAPSHOT_<br>DATA_BYTE4 | [7:0] | PHY_SNAPSHOT_<br>DATA_BYTE4 | | Current data received. Represents PHY_SNAPSHOT_DATA[39:32]. | 0x0 | l v | | 0x32C | SHORT_TPL_TEST_0 | [7:4] | SHORT_TPL_SP_ | | Short transport layer sample select. Selects | 0x0 | R/W | | المعالا | SHOWI_IFE_IESI_0 | [/.4] | SEL | | which sample to check from a specific DAC. | 0.00 | 11/ 44 | | | | | | 0000 | Sample 0. | | | | | | | | 0000 | Sample 1. | | 1 | | | | | | 0001 | Sample 1. | | | | | | | | | · · · · · · · · · · · · · · · · · · · | | 1 | | | | | | 0011 | Sample 3. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|---------------------------|-------|-----------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | | | 0100 | Sample 4. | | | | | | | | 0101 | Sample 5. | | | | | | | | 0110 | Sample 6. | | | | | | | | 0111 | Sample 7. | | | | | | | | 1000 | Sample 8. | | | | | | | | 1001 | Sample 9. | | | | | | | | 1010 | Sample 10. | | | | | | | | 1011 | Sample 11. | | | | | | | | 1100 | Sample 12. | | | | | | | | 1101 | Sample 13. | | | | | | | | 1110 | Sample 14. | | | | | | | | 1111 | Sample 15. | | | | | | [3:2] | SHORT_TPL_M_SEL | | Short transport layer test channel select. Select which channel of the DAC to check. | 0x0 | R/W | | | | | | 00 | Channel 0. | | | | | | | | 01 | Channel 1. | | | | | | | | 10 | Channel 2. | | | | | | 1 | SHORT_TPL_TEST_<br>RESET | - | Short transport layer test reset. Resets the result of short transport layer test. | 0x0 | R/W | | | | | | 0 | Not reset. | | | | | | | | 1 | Reset. | | | | | | 0 | SHORT_TPL_TEST_<br>EN | | Short transport layer test enable. Enable short transport layer test. | 0x0 | R/W | | | | | | 0 | Disable. | | | | | | | | 1 | Enable. | | | | 0x32D | SHORT_TPL_TEST_1 | [7:0] | SHORT_TPL_REF_ | | Short transport layer reference sample, | 0x0 | R/W | | 0,025 | 3.10.11. <u>-</u> 1.23.1 | [7.0] | SP_LSB | | LSB. This bit field is the lower eight bits of the expected DAC sample during the short transport layer test and is used to compare with the received sample at the JESD204B Rx output. | o.ko | | | 0x32E | SHORT_TPL_TEST_2 | [7:0] | SHORT_TPL_REF_<br>SP_MSB | | Short transport layer test reference sample, MSB. This bit field is the upper eight bits of the expected DAC sample during the short transport layer test and is used to compare with the received sample at the JESD204B Rx output. | 0x0 | R/W | | 0x32F | SHORT_TPL_TEST_3 | 7 | RESERVED | | Reserved. | 0x0 | R/W | | | | 6 | SHORT_TPL_IQ_<br>SAMPLE_SEL | 0 | Selects I or Q of the DAC to check the testing of the short transport layer. Select I data to test. | | | | | | [5.1] | DECEDVED | 1 | Select Q data to test. Reserved. | 0.0 | D/M | | | | [5:1] | RESERVED | | | 0x0 | R/W | | | | 0 | SHORT_TPL_FAIL | 0 | Short transport layer test fail. This bit shows if the selected DAC sample matches the expected sample for the short transport layer test. If they match, the test passes; otherwise, the test fails. Test pass. Test fail. | 0x0 | R | | 0x334 | JESD_BIT_INVERSE_<br>CTRL | [7:0] | JESD_BIT_INVERSE | | Logical lane invert. Each bit of this control inverses the JESD204B deserialized data from one specific JESD204B Rx PHY. Set Bit x high to invert the JESD204B deserialized data on Logical Lane x. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------|-------|--------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x400 | DID_REG | [7:0] | DID_RD | | Received ILAS configuration on Lane 0.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x401 | BID_REG | [7:0] | BID_RD | | Received ILAS configuration on Lane 0.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x402 | LID0_REG | 7 | RESERVED | | Reserved. | 0x0 | R | | | | 6 | ADJDIR_RD | | Received ILAS configuration on Lane 0.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | | | 5 | PHADJ_RD | | Received ILAS configuration on Lane 0.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | | | [4:0] | LL_LID0 | | Received ILAS LID configuration on Lane 0.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x403 | SCR_L_REG | 7 | SCR_RD | 0 | Received ILAS configuration on Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. Scrambling is disabled. Scrambling is enabled. | 0x0 | R | | | | [6:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | L_RD-1 | 00000<br>00001<br>00010<br>00011 | Received ILAS configuration on Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. 1 lane per converter device. 2 lanes per converter device. 3 lanes per converter device. 4 lanes per converter device. | 0x0 | R | | 0x404 | F_REG | [7:0] | F_RD-1 | 0 1 10 11 | Received ILAS configuration on Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. 1 octet per frame. 2 octets per frame. 3 octets per frame. 4 octets per frame. | 0x0 | R | | 0x405 | K_REG | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | K_RD-1 | 00000 | Received ILAS configuration on Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. Default value. 32 frames per multiframe. | 0x0 | R | | 0x406 | M_REG | [7:0] | M_RD-1 | | Received ILAS configuration on Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x407 | CS_N_REG | [7:6] | CS_RD | | Received ILAS configuration on Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | 5 | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | N_RD-1 | | Received ILAS configuration on Lane 0.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x408 | NP_REG | [7:5] | SUBCLASSV_RD | | Received ILAS configuration on Lane 0.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|---------------|-------|------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | [4:0] | NP_RD-1 | | Received ILAS configuration on Lane 0.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x409 | S_REG | [7:5] | JESDV_RD-1 | 000<br>001 | Received ILAS configuration on Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. JESD204A. JESD204B. | 0x0 | R | | | | [4:0] | S_RD-1 | | Received ILAS configuration on Lane 0.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x40A | HD_CF_REG | 7 | HD_RD | 0 | Received ILAS configuration on Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. Low density mode. High density mode. | 0x0 | R | | | | [6:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | CF_RD | | Received ILAS configuration on Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x40B | RES1_REG | [7:0] | RES1_RD | | Received ILAS configuration on Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x40C | RES2_REG | [7:0] | RES2_RD | | Received ILAS configuration on Lane 0.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x40D | CHECKSUM0_REG | [7:0] | LL_FCHK0 | | Received checksum during ILAS on Lane 0.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x40E | COMPSUM0_REG | [7:0] | LL_FCMP0 | | Computed checksum on Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x412 | LID1_REG | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | LL_LID1 | | Received ILAS LID configuration on Lane 1.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x415 | CHECKSUM1_REG | [7:0] | LL_FCHK1 | | Received checksum during ILAS on Lane 1.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x416 | COMPSUM1_REG | [7:0] | LL_FCMP1 | | Computed checksum on Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x41A | LID2_REG | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | LL_LID2 | | Received ILAS LID configuration on Lane 2.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x41D | CHECKSUM2_REG | [7:0] | LL_FCHK2 | | Received checksum during ILAS on Lane 2.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x41E | COMPSUM2_REG | [7:0] | LL_FCMP2 | | Computed checksum on Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x422 | LID3_REG | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | LL_LID3 | | Received ILAS LID configuration on Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|---------------|-------|----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x425 | CHECKSUM3_REG | [7:0] | LL_FCHK3 | | Received checksum during ILAS on Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x426 | COMPSUM3_REG | [7:0] | LL_FCMP3 | | Computed checksum on Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x42A | LID4_REG | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | LL_LID4 | | Received ILAS LID configuration on Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x42D | CHECKSUM4_REG | [7:0] | LL_FCHK4 | | Received checksum during ILAS on Lane 4.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x42E | COMPSUM4_REG | [7:0] | LL_FCMP4 | | Computed checksum on Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x432 | LID5_REG | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | LL_LID5 | | Received ILAS LID configuration on Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x435 | CHECKSUM5_REG | [7:0] | LL_FCHK5 | | Received checksum during ILAS on Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x436 | COMPSUM5_REG | [7:0] | LL_FCMP5 | | Computed checksum on Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x43A | LID6_REG | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | LL_LID6 | | Received ILAS LID configuration on Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x43D | CHECKSUM6_REG | [7:0] | LL_FCHK6 | | Received checksum during ILAS on Lane 6.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x43E | COMPSUM6_REG | [7:0] | LL_FCMP6 | | Computed checksum on Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x442 | LID7_REG | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | LL_LID7 | | Received ILAS LID configuration on Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x445 | CHECKSUM7_REG | [7:0] | LL_FCHK7 | | Received checksum during ILAS on Lane 7.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | 0x446 | COMPSUM7_REG | [7:0] | LL_FCMP7 | | Computed checksum on Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x450 | ILS_DID | [7:0] | DID | | Device (link) identification number. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | 0x451 | ILS_BID | [7:0] | BID | | Bank ID, extension to DID. This control is paged by the LINK_PAGE control in Register 0x300. This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------|-------|-----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x452 | ILS_LID0 | 7 | RESERVED | | Reserved. | 0x0 | R | | | | 6 | ADJDIR | | Direction to adjust the DAC LMFC. Link information is received on Link Lane 0 as specified in Section 8.3 of JESD204B. Only Link 0 is supported. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 5 | PHADJ | | Phase adjustment request to the DAC. Only Link 0 is supported. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | [4:0] | LID0 | | Lane identification number (within link). This control is paged by the LINK_PAGE control in Register 0x300. This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | 0x0 | R/W | | 0x453 | ILS_SCR_L | 7 | SCR | | Scramble enabled for the link. This control is paged by the LINK_PAGE control in Register 0x300. | 0x1 | R/W | | | | | | 0 | Descrambling is disabled. | | | | | | [6:5] | RESERVED | 1 | Descrambling is enabled. Reserved. | 0x0 | R | | | | [4:0] | L-1 | | Number of lanes per converter (minus 1). This control is paged by the LINK_PAGE control in Register 0x300. | 0x7 | R/W | | 0x454 | ILS_F | [7:0] | F-1 | | Number of octets per frame per lane<br>(minus 1). This control is paged by the<br>LINK_PAGE control in Register 0x300. | 0x0 | R/W | | 0x455 | ILS_K | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | K-1 | | Number of frames per multiframe (minus 1). This control is paged by the LINK_PAGE control in Register 0x300. | 0x1F | R/W | | | | | | 11111 | 32 frames per multiframe. | | | | 0x456 | ILS_M | [7:0] | M-1 | | Number of subchannels per link (minus 1).<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x1 | R/W | | 0x457 | ILS_CS_N | [7:6] | CS | | Number of control bits per sample. Only Link 0 is supported. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | 5 | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | N-1 | | Converter resolution (minus 1). This control is paged by the LINK_PAGE control in Register 0x300. | 0xF | R/W | | 0x458 | ILS_NP | [7:5] | SUBCLASSV | 000 | Device subclass version. This control is paged by the LINK_PAGE control in Register 0x300. Subclass 0. | 0x0 | R/W | | | | | 1 | 001 | Subclass 1. | | | | | | [4:0] | NP-1 | | Total number of bits per sample (minus 1). This control is paged by the LINK_PAGE control in Register 0x300. | 0xF | R/W | | 0x459 | ILS_S | [7:5] | JESDV | 000 | JESD204 version. This control is paged by the LINK_PAGE control in Register 0x300. JESD204A. | 0x0 | R/W | | | | | | 000 | JESD204A.<br>JESD204B. | | | | | | [4:0] | S-1 | 301 | Number of samples per converter per frame cycle (minus 1). This control is paged by the LINK_PAGE control in Register 0x300. | 0x1 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|--------------|-------|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------| | 0x45A | ILS_HD_CF | 7 | HD | 0 | High density format, always set to 1. This control is paged by the LINK_PAGE control in Register 0x300. Low density mode. | 0x1 | R | | | | | | 1 | High density mode. | | | | | | [6:5] | RESERVED | | Reserved. | 0x0 | R | | | | [4:0] | CF | | Number of control bits per sample. Only Link 0 is supported. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | 0x45B | ILS_RES1 | [7:0] | RES1 | | Reserved field 1. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | 0x45C | ILS_RES2 | [7:0] | RES2 | | Reserved field 2. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | 0x45D | ILS_CHECKSUM | [7:0] | FCHK0 | | Calculated link configuration checksum. This control is paged by the LINK_PAGE control in Register 0x300. This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | 0x0 | R/W | | 0x46C | LANE_DESKEW | 7 | ILD7 | 0 | Interlane deskew status for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. Deskew failed. Deskew achieved. | 0x0 | R | | | | 6 | ILD6 | 0 | Interlane deskew status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. Deskew failed. | 0x0 | R | | | | 5 | ILD5 | 1 | Deskew achieved. Interlane deskew status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Deskew failed. | | | | | | 4 | ILD4 | 0 | Deskew achieved. Interlane deskew status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. Deskew failed. Deskew achieved. | 0x0 | R | | | | 3 | ILD3 | 0 | Interlane deskew status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. Deskew failed. Deskew achieved. | 0x0 | R | | | | 2 | ILD2 | | Interlane deskew status for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Deskew failed. | | | | | | | II D1 | 1 | Deskew achieved. | 0.0 | <u> </u> | | | | 1 | ILD1 | | Interlane deskew status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Deskew failed. | | | | | | | | 1 | Deskew achieved. | | | | 0x46D | BAD_DISPARITY | 0 | ILD0 | | Interlane deskew status for Lane 0. This control is paged by the LINK_PAGE control | 0x0 | R | |-------|---------------|---|------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---| | 0x46D | BAD_DISPARITY | | | 0 | in Register 0x300.<br>Deskew failed. | | | | | | 7 | BDE7 | 0 | Deskew achieved. Bad disparity errors status for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | | | 6 | BDE6 | 0 | Error count ≥ ETH[7:0] value. Bad disparity errors status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | | | 5 | BDE5 | 0 | Error count ≥ ETH[7:0] value. Bad disparity errors status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | | | 4 | BDE4 | 0 | Error count ≥ ETH[7:0] value. Bad disparity errors status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | | | 3 | BDE3 | 0 | Error count ≥ ETH[7:0] value. Bad disparity errors status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | | | 2 | BDE2 | 0 | Error count ≥ ETH[7:0] value. Bad disparity errors status for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | | | 1 | BDE1 | 0 | Error count ≥ ETH[7:0] value. Bad disparity errors status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. Error count ≥ ETH[7:0] value. | 0x0 | R | | | | 0 | BDE0 | 0 | Bad disparity errors status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | 0x46E | NOT_IN_TABLE | 7 | NIT7 | 0 | Error count ≥ ETH[7:0] value. Not in table errors status for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | | | 6 | NIT6 | 0 | Error count ≥ ETH[7:0] value. Not in table errors status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|----------------------|------|----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 5 | NIT5 | 0 | Not in table errors status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value.<br>Error count ≥ ETH[7:0] value. | | | | | | 4 | NIT4 | | Not in table errors status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | 3 | NIT3 | 1 | Error count ≥ ETH[7:0] value. Not in table errors status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 2 | NIT2 | | Not in table errors status for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 1 | NIT1 | | Not in table errors status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | - | NUTO | 1 | Error count ≥ ETH[7:0] value. | 0.0 | | | | | 0 | NIT0 | | Not in table errors status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value.<br>Error count ≥ ETH[7:0] value. | | | | 0x46F | UNEXPECTED_<br>KCHAR | 7 | UEK7 | | Unexpected K character errors status, Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 6 | UEK6 | | Unexpected K character errors status, Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | 1 | | | | 5 | UEK5 | | Unexpected K character errors status, Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 4 | UEK4 | | Unexpected K character errors status, Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 3 | UEK3 | | Unexpected K character errors status, Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|---------------|------|----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 2 | UEK2 | 0 | Unexpected K character errors status, Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | | | 1 | UEK1 | 0 | Error count ≥ ETH[7:0] value. Unexpected K character errors status, Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. Error count ≥ ETH[7:0] value. | 0x0 | R | | | | 0 | UEK0 | 0 | Unexpected K character errors status, Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. Error count ≥ ETH[7:0] value. | 0x0 | R | | 0x470 | CODE_GRP_SYNC | 7 | CGS7 | 0 | Code group synchronization status for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. Synchronization achieved. | 0x0 | R | | | | 6 | CGS6 | 0 | Code group synchronization status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. Synchronization achieved. | 0x0 | R | | | | 5 | CGS5 | 0 | Code group synchronization status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. | 0x0 | R | | | | 4 | CGS4 | 0 | Synchronization achieved. Code group synchronization status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. Synchronization achieved. | 0x0 | R | | | | 3 | CGS3 | 0 | Code group synchronization status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. Synchronization achieved. | 0x0 | R | | | | 2 | CGS2 | 0 | Code group synchronization status for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. | 0x0 | R | | | | 1 | CGS1 | 0 | Synchronization achieved. Code group synchronization status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. | 0x0 | R | | | | 0 | CGS0 | 1 | Synchronization achieved. Code group synchronization status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. Synchronization achieved. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|---------------|------|----------|----------|----------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x471 | FRAME_SYNC | 7 | FS7 | 0 | Frame synchronization status for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. | 0x0 | R | | | | | | 1 | Synchronization achieved. | | | | | | 6 | FS6 | 0 | Frame synchronization status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. | 0x0 | R | | | | | | 1 | Synchronization achieved. | | | | | | 5 | FS5 | | Frame synchronization status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 4 | FS4 | | Frame synchronization status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 3 | FS3 | | Frame synchronization status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 2 | FS2 | | Frame synchronization status for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization achieved | | | | | | 1 | FS1 | | Synchronization achieved. | 0x0 | R | | | | 1 | F31 | | Frame synchronization status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. | UXU | K | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 0 | FS0 | | Frame synchronization status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | 0x472 | GOOD_CHECKSUM | 7 | CKS7 | | Computed checksum status for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Checksum is incorrect. | | | | | | | | 1 | Checksum is correct. | | | | | | 6 | CKS6 | | Computed checksum status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Checksum is incorrect. | | | | | | | | 1 | Checksum is correct. | | | | | | 5 | CKS5 | | Computed checksum status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Checksum is incorrect. | | | | | | | | 1 | Checksum is correct. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|----------------|------|----------|----------|-------------------------------------------------------------------------------------------------------------------------------|----------|--------------| | | | 4 | CKS4 | 0 | Computed checksum status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. Checksum is incorrect. | 0x0 | R | | | | | | 1 | Checksum is correct. | | | | | | 3 | CKS3 | 0 | Computed checksum status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. Checksum is incorrect. | 0x0 | R | | | | | | 1 | Checksum is correct. | | | | | | 2 | CKS2 | | Computed checksum status for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Checksum is incorrect. | | | | | | | 01101 | 1 | Checksum is correct. | | <del> </del> | | | | 1 | CKS1 | | Computed checksum status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Checksum is incorrect. | | | | | | | | 1 | Checksum is correct. | | | | | | 0 | CKS0 | | Computed checksum status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Checksum is incorrect. | | | | | | | | 1 | Checksum is correct. | | | | 0x473 | INIT_LANE_SYNC | 7 | ILS7 | | Initial lane synchronization status for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. Synchronization achieved. | | | | | | 6 | ILS6 | | Initial lane synchronization status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 5 | ILS5 | | Initial lane synchronization status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 4 | ILS4 | | Initial lane synchronization status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 3 | ILS3 | | Initial lane synchronization status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | <u> </u> | | | | | 2 | ILS2 | | Initial lane synchronization status for Lane 2.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|----------|-------|--------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 1 | ILS1 | 0 | Initial lane synchronization status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. | 0x0 | R | | | | | | 1 | Synchronization achieved. | | | | | | 0 | ILS0 | | Initial lane synchronization status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | 0x475 | CTRLREG0 | [7:4] | RESERVED | 1 | Synchronization achieved. Reserved. | 0x0 | R/W | | 0,473 | CINENEGO | 3 | SOFTRST | | QBD soft reset. Active high synchronous reset. Resets all hardware to power-on state. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 2 | FORCESYNCREQ | | Command from application to assert a synchronization request. Active high. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 1 | RESERVED | | Reserved. | 0x0 | R | | | | 0 | REPL_FRM_ENA | | When this level input is set, it enables the replacement of frames received in error. This control is paged by the LINK_PAGE control in Register 0x300. This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | 0x1 | R/W | | 0x476 | CTRLREG1 | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | | 4 | QUAL_RDERR | 0 | Error reporting behavior for concurrent not in table (NIT) and running disparity (RD) errors. This control is paged by the LINK_PAGE control in Register 0x300. Set this bit to 1. This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. NIT has no effect on RD error. NIT error masks concurrent with RD error. | 0x1 | R/W | | | | [3:1] | RESERVED | | Reserved. | 0x0 | R/W | | | | 0 | FCHK_N | 0 | Checksum calculation method. This control is paged by the LINK_PAGE control in Register 0x300. This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. Checksum is calculated by summing the individual fields in the link configuration table as defined in Section 8.3, Table 20 of the JESD204B standard. Checksum is calculated by summing the registers containing the packed link configuration fields (sum of Register 0x450 to Register 0x45A, modulo 256). | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|------------|-------|-------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x477 | CTRLREG2 | 7 | ILS_MODE | 0 | Data link layer test mode is enabled when this bit is set to 1. CGS pattern is followed by a perpetual ILAS sequence. This control is paged by the LINK_PAGE control in Register 0x300. This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. Normal mode. | 0x0 | R/W | | | | | | 1 | CGS pattern is followed by a perpetual ILAS sequence. | | | | | | 6 | RESERVED | | Reserved. | 0x0 | R/W | | | | 5 | REPDATATEST | | Repetitive data test enable using the JTSPAT pattern. To enable the test, Bit 7 of this register must = 0. This control is paged by the LINK_PAGE control in Register 0x300. This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | 0x0 | R/W | | | | 4 | QUETESTERR | 0 | Queue test error mode. This control is paged by the LINK_PAGE control in Register 0x300. This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. When this bit = 0, simultaneous errors on | 0x0 | R/W | | | | | | 1 | multiple lanes are reported as one error. Selected when this bit = 1 and when REPDATATEST = 1. Detected errors from all lanes are trapped in a counter and sequentially signaled on SYNCOUTx±. | | | | | | 3 | AR_ECNTR | | Automatic reset of error counter. The error counter that causes assertion of SYNCOUTx± is automatically reset to 0 when AR_ECNTR = 1. All other counters are unaffected. This control is paged by the LINK_PAGE control in Register 0x300. This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | 0x0 | R/W | | | | [2:0] | RESERVED | | Reserved. | 0x0 | R | | 0x478 | KVAL | [7:0] | KSYNC | | Number of 4 × K multiframes during ILAS. This control is paged by the LINK_PAGE control in Register 0x300. This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | 0x1 | R/W | | 0x47C | ERRORTHRES | [7:0] | ETH | | Error counter threshold value. These bits set when a SYNCOUTx± error or IRQx interrupt is sent due to BD, NIT, or UEK errors. This control is paged by the LINK_PAGE control in Register 0x300. This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | 0xFF | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|--------------|-------|----------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x47D | SYNC_ASSERT_ | [7:3] | RESERVED | | Reserved. | 0x0 | R | | | MASK | [2:0] | SYNC_ASSERT_<br>MASK | | SYNCOUTx± assertion enable mask for BD, NIT, and UEK error conditions. This control is paged by the LINK_PAGE control in Register 0x300. Active high, SYNCOUTx± assertion enable mask for BD, NIT, and UEK error conditions, respectively. When an error counter, in any lane, has reached the error threshold count, ETH[7:0], and the corresponding SYNC_ASSERT_MASK bit is set, SYNCOUTx± is asserted. The mask bits are as follows (note that the bit sequence is reversed with respect to the other error count controls and the error counters): Bit 2 = bad disparity error (BDE). Bit 1 = not in table error (NIT). | 0x7 | R/W | | | | | | | Bit 0 = unexpected K character error (UEK). | | | | 0x480 | ECNT_CTRL0 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | [5:3] | ECNT_ENA0 | | Error counter enables for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: Bit 5 = unexpected K character error (UEK). Bit 4 = not in table error (NIT). Bit 3 = bad disparity error (BDE). | 0x7 | R/W | | | | [2:0] | ECNT_RST0 | | Reset error counters for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: Bit 2 = bad disparity error (BDE). Bit 1 = not in table error (NIT). Bit 0 = unexpected K character error (UEK). | 0x7 | R/W | | 0x481 | ECNT_CTRL1 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | [5:3] | ECNT_ENA1 | | Error counter enables for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: Bit 5 = unexpected K character error (UEK). Bit 4 = not in table error (NIT). Bit 3 = bad disparity error (BDE). | 0x7 | R/W | | | | [2:0] | ECNT_RST1 | | Reset error counters for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). | 0x7 | R/W | | 0x482 | ECNT_CTRL2 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | [5:3] | ECNT_ENA2 | | Error counter enables for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: Bit 5 = unexpected K character error (UEK). Bit 4 = not in table error (NIT). Bit 3 = bad disparity error (BDE). | 0x7 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |--------|------------|-------|------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | [2:0] | ECNT_RST2 | | Reset error counters for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: | 0x7 | R/W | | | | | | | Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). | | | | | | | | | Bit 0 = bad disparity error (BDE). | | | | 0x483 | ECNT_CTRL3 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | C/1.00 | | [5:3] | ECNT_ENA3 | | Error counter enables for Lane 3. This | 0x7 | R/W | | | | [5.5] | ECHT_ENVIO | | control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: Bit 5 = unexpected K character error (UEK). Bit 4 = not in table error (NIT). Bit 3 = bad disparity error (BDE). | | | | | | [2:0] | ECNT_RST3 | + | Reset error counters for Lane 3. This control | 0x7 | R/W | | | | [2.0] | ECINI_N313 | | is paged by the LINK_PAGE control in<br>Register 0x300. Counters of each lane are<br>addressed as follows:<br>Bit 2 = unexpected K character error (UEK). | 0x7 | n/ vv | | | | | | | Bit $1 = \text{not in table error (NIT)}$ . | | | | | | | | | Bit 0 = bad disparity error (BDE). | | | | 0x484 | ECNT_CTRL4 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | [5:3] | ECNT_ENA4 | | Error counter enables for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: Bit 5 = unexpected K character error (UEK). Bit 4 = not in table error (NIT). Bit 3 = bad disparity error (BDE). | 0x7 | R/W | | | | [2:0] | ECNT_RST4 | | Reset error counters for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). | 0x7 | R/W | | 0x485 | ECNT_CTRL5 | [7:6] | RESERVED | | Reserved. | 0x0 | R | | | | [5:3] | ECNT_ENA5 | | Error counter enables for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: Bit 5 = unexpected K character error (UEK). Bit 4 = not in table error (NIT). Bit 3 = bad disparity error (BDE). | 0x7 | R/W | | | | [2:0] | ECNT_RST5 | | Reset error counters for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). | 0x7 | R/W | | | | | | | | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |--------------------|------------|----------------|-------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--------| | | | [5:3] | ECNT_ENA6 | | Error counter enables for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: | 0x7 | R/W | | | | | | | Bit 5 = unexpected K character error (UEK). Bit 4 = not in table error (NIT). | | | | | | | | | Bit 3 = bad disparity error (BDE). | | | | | | [2:0] | ECNT_RST6 | | Reset error counters for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: | 0x7 | R/W | | | | | | | Bit 2 = unexpected K character error (UEK). | | | | | | | | | Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). | | | | 0x487 | ECNT_CTRL7 | [7,6] | RESERVED | | Reserved. | 0x0 | R | | 0x467 | ECNI_CIRL/ | [7:6]<br>[5:3] | ECNT_ENA7 | | Error counter enables for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: | 0x7 | R/W | | | | | | | Bit 5 = unexpected K character error (UEK).<br>Bit 4 = not in table error (NIT). | | | | | | | | | Bit 3 = bad disparity error (BDE). | | | | | | [2:0] | ECNT_RST7 | | Reset error counters for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. Counters of each lane are addressed as follows: | 0x7 | R/W | | | | | | | Bit 2 = unexpected K character error (UEK). | | | | | | | | | Bit $1 = \text{not in table error (NIT)}$ . | | | | | | | | | Bit 0 = bad disparity error (BDE). | | | | 0x488 | ECNT_TCH0 | [7:3] | RESERVED | | Reserved. | 0x0 | R | | | | [2:0] | ECNT_TCH0 | | Terminal count hold enable of error counters for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. When set, the designated counter is to hold the terminal count value of 0xFF when it is reached until the counter is reset by the user. Otherwise, the designated counter rolls over. Counters of each lane are addressed as follows: | 0x7 | R/W | | | | | | | Bit 2 = unexpected K character error (UEK). | | | | | | | | | Bit 1 = not in table error (NIT). | | | | | | | | | Bit 0 = bad disparity error (BDE). | | | | | | | | | This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | | | | 0x489 | ECNT_TCH1 | [7:3] | RESERVED | | Reserved. | 0x0 | R | | UA <del>1</del> 07 | ECIVI_ICHI | [2:0] | ECNT_TCH1 | | Terminal count hold enable of error counters | 0x0<br>0x7 | R/W | | | | [2.0] | ZCIVI_ICIII | | for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. When set, the designated counter is to hold the terminal count value of 0xFF when it is reached until the counter is reset by the user. Otherwise, the designated counter rolls over. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). | | 10 00 | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------|-------|-----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | | | | Bit 0 = bad disparity error (BDE). This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | | | | 0x48A | ECNT_TCH2 | [7:3] | RESERVED | | Reserved. | 0x0 | R | | | | [2:0] | ECNT_TCH2 | | Terminal count hold enable of error counters for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. When set, the designated counter is to hold the terminal count value of 0xFF when it is reached until the counter is reset by the user. Otherwise, the designated counter rolls over. Counters of each lane are addressed as follows: | 0x7 | R/W | | | | | | | Bit $2 = \text{unexpected K character error (UEK)}$ . | | | | | | | | | Bit $1 = \text{not in table error (NIT)}$ . | | | | | | | | | Bit 0 = bad disparity error (BDE). This signal must only be programmed while the QBD is held in soft reset (Register 0x475, | | | | | | | | | Bit 3), and must not be changed during | | | | | | r= -1 | 256521/52 | | normal operation. | | | | 0x48B | ECNT_TCH3 | [7:3] | RESERVED | | Reserved. | 0x0 | R | | | | [2:0] | ECNT_TCH3 | | Terminal count hold enable of error counters for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. When set, the designated counter is to hold the terminal count value of 0xFF when it is reached until the counter is reset by the user. Otherwise, the designated counter rolls over. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | 0x7 | R/W | | 0x48C | ECNT_TCH4 | [7:3] | RESERVED | | Reserved. | 0x0 | R | | | | [2:0] | ECNT_TCH4 | | Terminal count hold enable of error counters for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. When set, the designated counter is to hold the terminal count value of 0xFF when it is reached until the counter is reset by the user. Otherwise, the designated counter rolls over. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | 0x7 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |--------|------------|-------|-----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x48D | ECNT_TCH5 | [7:3] | RESERVED | | Reserved. | 0x0 | R | | | | [2:0] | ECNT_TCH5 | | Terminal count hold enable of error counters for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. When set, the designated counter is to hold the terminal count value of 0xFF when it is reached until the counter is reset by the user. Otherwise, the designated counter rolls over. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | 0x7 | R/W | | 0x48E | ECNT_TCH6 | [7:3] | RESERVED | | Reserved. | 0x0 | R | | OX IOE | ZGM_TGM | [2:0] | ECNT_TCH6 | | Terminal count hold enable of error counters for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. When set, the designated counter is to hold the terminal count value of 0xFF when it is reached until the counter is reset by the user. Otherwise, the designated counter rolls over. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | 0x7 | R/W | | 0x48F | ECNT_TCH7 | [7:3] | RESERVED | | Reserved. | 0x0 | R | | | | [2:0] | ECNT_TCH7 | | Terminal count hold enable of error counters for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. When set, the designated counter is to hold the terminal count value of 0xFF when it is reached until the counter is reset by the user. Otherwise, the designated counter rolls over. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). This signal must only be programmed while the QBD is held in soft reset (Register 0x475, Bit 3), and must not be changed during normal operation. | 0x7 | R/W | | 0x490 | ECNT_STAT0 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | LANE_ENA0 | | This output indicates if Lane 0 is enabled. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|------------|-------|-----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | [2:0] | ECNT_TCR0 | | Terminal count reached indicator of error counters for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. Set these bits to 1 when the corresponding counter terminal count value of 0xFF is reached. If ECNT_TCHx is set, the terminal count value for the corresponding counter is held until the counter is reset by the user; otherwise, the counter rolls over and continues counting. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). | 0x0 | R | | | | | | | Bit 1 = not in table error (NIT). | | | | | | | | | Bit 0 = bad disparity error (BDE). | | | | 0x491 | ECNT_STAT1 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | LANE_ENA1 | | This output indicates if Lane 1 is enabled. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | [2:0] | ECNT_TCR1 | | Terminal count reached indicator of error counters for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. Set these bits to 1 when the corresponding counter terminal count value of 0xFF is reached. If ECNT_TCHx is set, the terminal count value for the corresponding counter is held until the counter is reset by the user; otherwise, the counter rolls over and continues counting. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). | 0x0 | R | | 0x492 | ECNT_STAT2 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | LANE_ENA2 | | This output indicates if Lane 2 is enabled.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | | | [2:0] | ECNT_TCR2 | | Terminal count reached indicator of error counters for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. Set these bits to 1 when the corresponding counter terminal count value of 0xFF is reached. If ECNT_TCHx is set, the terminal count value for the corresponding counter is held until the counter is reset by the user; otherwise, the counter rolls over and continues counting. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). | 0x0 | R | | 0x493 | ECNT_STAT3 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | LANE_ENA3 | | This output indicates if Lane 3 is enabled. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|------------|-------|-----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | [2:0] | ECNT_TCR3 | | Terminal count reached indicator of error counters for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. Set these bits to 1 when the corresponding counter terminal count value of 0xFF is reached. If ECNT_TCHx is set, the terminal count value for the corresponding counter is held until the counter is reset by the user; otherwise, the counter rolls over and continues counting. Counters of each lane are addressed as follows: | 0x0 | R | | | | | | | Bit 2 = unexpected K character error (UEK). | | | | | | | | | Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). | | | | 0x494 | ECNT_STAT4 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | LANE_ENA4 | | This output indicates if Lane 4 is enabled. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | [2:0] | ECNT_TCR4 | | Terminal count reached indicator of error counters for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. Set these bits to 1 when the corresponding counter terminal count value of 0xFF is reached. If ECNT_TCHx is set, the terminal count value for the corresponding counter is held until the counter is reset by the user; otherwise, the counter rolls over and continues counting. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). | 0x0 | R | | 0x495 | ECNT_STAT5 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | LANE_ENA5 | | This output indicates if Lane 5 is enabled.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | | | [2:0] | ECNT_TCR5 | | Terminal count reached indicator of error counters for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. Set these bits to 1 when the corresponding counter terminal count value of 0xFF is reached. If ECNT_TCHx is set, the terminal count value for the corresponding counter is held until the counter is reset by the user; otherwise, the counter rolls over and continues counting. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). | 0x0 | R | | 0x496 | ECNT_STAT6 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | LANE_ENA6 | | This output indicates if Lane 6 is enabled.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|--------------|-------|-----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | [2:0] | ECNT_TCR6 | | Terminal count reached indicator of error counters for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. Set these bits to 1 when the corresponding counter terminal count value of 0xFF is reached. If ECNT_TCHx is set, the terminal count value for the corresponding counter is held until the counter is reset by the user; otherwise, the counter rolls over and continues counting. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). | 0x0 | R | | 0x497 | ECNT_STAT7 | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | LANE_ENA7 | | This output indicates if Lane 7 is enabled.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | | | [2:0] | ECNT_TCR7 | | Terminal count reached indicator of error counters for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. Set these bits to 1 when the corresponding counter terminal count value of 0xFF is reached. If ECNT_TCHx is set, the terminal count value for the corresponding counter is held until the counter is reset by the user; otherwise, the counter rolls over and continues counting. Counters of each lane are addressed as follows: Bit 2 = unexpected K character error (UEK). Bit 1 = not in table error (NIT). Bit 0 = bad disparity error (BDE). | 0x0 | R | | 0x4B0 | LINK_STATUS0 | 7 | BDE0 | 0 | Bad disparity errors status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 6 | NIT0 | 0 | Not in table errors status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 5 | UEK0 | 0 | Unexpected K character errors status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 4 | ILD0 | | Interlane deskew status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. Deskew failed. | 0x0 | R | | | | | | 0 | Deskew achieved. | | | | | | 3 | ILS0 | 0 | Initial lane synchronization status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. Synchronization achieved. | 0x0 | R | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|--------------|------|----------|----------|--------------------------------------------------------------------------------------------------------------------|-------|--------------| | | | 2 | CKS0 | | Computed checksum status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Checksum is incorrect. Checksum is correct. | | | | | | 1 | FS0 | ' | Frame synchronization status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. Synchronization achieved. | | | | | | 0 | CGS0 | ı ı | Code group synchronization status for Lane 0. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | 2071 | 1 | Synchronization achieved. | | <del> </del> | | 0x4B1 | LINK_STATUS1 | 7 | BDE1 | | Bad disparity errors status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 6 | NIT1 | | Not in table errors status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 5 | UEK1 | | Unexpected K character errors status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value.<br>Error count ≥ ETH[7:0] value. | | | | | | 4 | ILD1 | | Interlane deskew status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Deskew failed. | | | | | | | | 1 | Deskew achieved. | | | | | | 3 | ILS1 | | Initial lane synchronization status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 2 | CKS1 | | Computed checksum status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Checksum is incorrect. | | | | | | | | 1 | Checksum is correct. | | | | | | 1 | FS1 | | Frame synchronization status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 0 | CGS1 | | Code group synchronization status for Lane 1. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|--------------|------|----------|----------|------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x4B2 | LINK_STATUS2 | 7 | BDE2 | 0 | Bad disparity errors status for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | | | | | 1 | Error count $\geq$ ETH[7:0] value. | | | | | | 6 | NIT2 | | Not in table errors status for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | LIEIKO | 1 | Error count ≥ ETH[7:0] value. | | | | | | 5 | UEK2 | | Unexpected K character errors status for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 4 | ILD2 | | Interlane deskew status for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Deskew failed. | | | | | | | | 1 | Deskew achieved. | | | | | | 3 | ILS2 | | Initial lane synchronization status for Lane 2.<br>This control is paged by the LINK_PAGE<br>control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 2 | CKS2 | | Computed checksum status for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Checksum is incorrect. | | | | | | | | 1 | Checksum is correct. | | | | | | 1 | FS2 | | Frame synchronization status for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 0 | CGS2 | | Code group synchronization status for Lane 2. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | 0x4B3 | LINK_STATUS3 | 7 | BDE3 | | Bad disparity errors status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 6 | NIT3 | | Not in table errors status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 5 | UEK3 | | Unexpected K character errors status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|--------------|------|----------|----------|--------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 4 | ILD3 | | Interlane deskew status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Deskew failed. Deskew achieved. | | | | | | 3 | ILS3 | 1 | Initial lane synchronization status for Lane 3. This control is paged by the LINK_PAGE | 0x0 | R | | | | | | 0 | control in Register 0x300. Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 2 | CKS3 | | Computed checksum status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Checksum is incorrect. | | | | | | | | 1 | Checksum is correct. | | | | | | 1 | FS3 | | Frame synchronization status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 0 | CGS3 | | Code group synchronization status for Lane 3. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | )x4B4 | LINK_STATUS4 | 7 | BDE4 | | Bad disparity errors status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value.<br>Error count ≥ ETH[7:0] value. | | | | | | 6 | NIT4 | | Not in table errors status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 5 | UEK4 | | Unexpected K character errors status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 4 | ILD4 | | Interlane deskew status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Deskew failed. | | | | | | | | 1 | Deskew achieved. | | | | | | 3 | ILS4 | | Initial lane synchronization status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 2 | CKS4 | | Computed checksum status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. | | R | | | | | | 0 | Checksum is incorrect. | | | | | | | | 1 | Checksum is correct. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|--------------|------|----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 1 | FS4 | 0 | Frame synchronization status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. Synchronization achieved. | 0x0 | R | | | | 0 | CGS4 | 0 | Code group synchronization status for Lane 4. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. Synchronization achieved. | 0x0 | R | | 0x4B5 | LINK_STATUS5 | 7 | BDE5 | 0 | Bad disparity errors status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. Error count ≥ ETH[7:0] value. | s 0x0 | R | | | | 6 | NIT5 | 0 | Not in table errors status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. Error count ≥ ETH[7:0] value. | 0x0 | R | | | | 5 | UEK5 | 0 | Unexpected K character errors status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. Error count ≥ ETH[7:0] value. | 0x0 | R | | | | 4 | ILD5 | 0 | Interlane deskew status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. Deskew failed. | 0x0 | R | | | | 3 | ILS5 | 0 | Deskew achieved. Initial lane synchronization status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. Synchronization achieved. | 0x0 | R | | | | 2 | CKS5 | 0 | Computed checksum status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. Checksum is incorrect. Checksum is correct. | 0x0 | R | | | | 1 | FS5 | 0 | Frame synchronization status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. | 0x0 | R | | | | 0 | CGS5 | 0 | Synchronization achieved. Code group synchronization status for Lane 5. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. | 0x0 | R | | | | | | 1 | Synchronization achieved. | | | | 0x4B6 | LINK_STATUS6 | 7 | BDE6 | | Bad disparity errors status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value.<br>Error count ≥ ETH[7:0] value. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|--------------|------|----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------| | | | 6 | NIT6 | | Not in table errors status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value.<br>Error count ≥ ETH[7:0] value. | | | | | | 5 | UEK6 | 0 | Unexpected K character errors status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. Error count < ETH[7:0] value. | 0x0 | R | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 4 | ILD6 | | Interlane deskew status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Deskew failed. | | | | | | | | 1 | Deskew achieved. | | <del>-</del> | | | | 3 | ILS6 | | Initial lane synchronization status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 2 | CKS6 | | Computed checksum status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Checksum is incorrect. | | | | | | | | 1 | Checksum is correct. | | | | | | 1 | FS6 | | Frame synchronization status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. Synchronization achieved. | | | | | | 0 | CGS6 | | Code group synchronization status for Lane 6. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | 0x4B7 | LINK_STATUS7 | 7 | BDE7 | | Bad disparity errors status for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 6 | NIT7 | | Not in table errors status for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 5 | UEK7 | | Unexpected K character errors status Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Error count < ETH[7:0] value. | | | | | | | | 1 | Error count ≥ ETH[7:0] value. | | | | | | 4 | ILD7 | | Interlane deskew status for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Deskew failed. | | | | | | | | 1 | Deskew achieved. | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|------------------|-------|----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 3 | ILS7 | 0 | Initial lane synchronization status for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. | 0x0 | R | | | | 2 | CKS7 | 1 | Synchronization achieved. Computed checksum status for Lane 7. This | 0x0 | R | | | | 2 | CKS/ | | control is paged by the LINK_PAGE control in Register 0x300. | UXU | K | | | | | | 0 | Checksum is incorrect. | | | | | | | | 1 | Checksum is correct. | | | | | | 1 | FS7 | | Frame synchronization status for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R | | | | | | 0 | Synchronization lost. | | | | | | | | 1 | Synchronization achieved. | | | | | | 0 | CGS7 | 0 | Code group synchronization status for Lane 7. This control is paged by the LINK_PAGE control in Register 0x300. Synchronization lost. Synchronization achieved. | 0x0 | R | | 0x4B8 | JESD_IRQ_ENABLEA | 7 | EN_BDE | | Bad disparity error counter. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 6 | EN_NIT | | Not in table error counter. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 5 | EN_UEK | | Unexpected K error counter. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 4 | EN_ILD | | Interlane deskew. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 3 | EN_ILS | | Initial lane synchronization. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 2 | EN_CKS | | Good checksum. This bit compares two checksums: the checksum that the transmitter sent over the link during the ILAS and the checksum that the receiver calculated from the ILAS data that the transmitter sent over the link. Note that the checksum IRQ only looks at data sent by the transmitter and not the checksum programmed into Register 0x45D. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 1 | EN_FS | | Frame synchronization. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 0 | EN_CGS | | Code group synchronization. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | 0x4B9 | JESD_IRQ_ENABLEB | [7:1] | RESERVED | | Reserved. | 0x0 | R | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|---------------------------|----------|-----------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 0 | EN_ILAS | | Configuration mismatch (checked for Lane 0 only). The ILAS IRQ compares the two sets of ILAS data obtained by the receiver. The first set of data is the ILAS data sent over the JESD204B link by the transmitter. The second set of data is the ILAS data programmed into the receiver via the SPI (Register 0x450 to Register 0x45D). If any of the data differs, the IRQ is triggered. Note that all of the ILAS data, including the checksum, is compared. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | 0x4BA | JESD_IRQ_STATUSA | 7 | IRQ_BDE | | Bad disparity error counter. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 6 | IRQ_NIT | | Not in table error counter. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 5 | IRQ_UEK | | Unexpected K error counter. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 4 | IRQ_ILD | | Interlane deskew. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 3 | IRQ_ILS | | Initial lane synchronization. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 2 | IRQ_CKS | | Good checksum. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 1 | IRQ_FS | | Frame synchronization. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | | | 0 | IRQ_CGS | | Code group synchronization. This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | 0x4BB | JESD_IRQ_STATUSB | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | IRQ_ILAS | | Configuration mismatch (checked for Lane 0 only). This control is paged by the LINK_PAGE control in Register 0x300. | 0x0 | R/W | | 0x4BC | IRQ_OUTPUT_MUX_ | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | JESD | 0 | MUX_JESD_IRQ | | Selects which IRQ pin is connected to the JESD204B IRQx sources. | 0x0 | R/W | | | | | | 0 | Route the IRQ trigger signal to the IRQ0 pin. | | | | | DE 00 5 | <u> </u> | DE 00 1 | 1 | Route the IRQ trigger signal to the IRQ1 pin. | | 1 | | 0x580 | BE_SOFT_OFF_<br>GAIN_CTRL | 7 | BE_SOFT_OFF_<br>GAIN_EN | | Must be 1 to use soft off/on. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | | | [6:3] | RESERVED | | Reserved. | 0x0 | R | | | | [2:0] | BE_GAIN_RAMP_<br>RATE | | Sets ramp rate. The gain ramps from 0 to 1 (or 1 to 0) in 32 steps over 2 <sup>(CODE+8)</sup> DAC clock periods. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | 0x581 | BE_SOFT_OFF_<br>ENABLE | 7 | ENA_SHORT_<br>PAERR_SOFTOFF | | Enable short PA error soft off. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x1 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|-----------------------|-------|-----------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 6 | ENA_LONG_<br>PAERR_SOFTOFF | | Enable long PA error soft off. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x1 | R/W | | | | [5:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | ENA_JESD_ERR_<br>SOFTOFF | | Enable JESD204B side error soft off. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | | | 2 | ROTATE_SOFT_<br>OFF_EN | | When set to 1, the synchronization logic rotation triggers the DAC output soft off. Note that Register 0x03B, Bit 0 must also be high. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x1 | R/W | | | | 1 | TXEN_SOFT_OFF_<br>EN | | When set to 1, a TXENx falling edge triggers the DAC output soft off. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x1 | R/W | | | | 0 | SPI_SOFT_OFF_EN | | Force a soft off when gain is 1. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | 0x582 | BE_SOFT_ON_<br>ENABLE | 7 | SPI_SOFT_ON_EN | | Force a soft on when gain is 0. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | | | 6 | LONG_LEVEL_<br>SOFTON_EN | | When set to 1, this bit enables the long level soft on. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x1 | R/W | | | | [5:0] | RESERVED | | Reserved. | 0x0 | R/W | | 0x583 | LONG_PA_THRES_<br>LSB | [7:0] | LONG_PA_<br>THRESHOLD[7:0] | | Long average power threshold for comparison. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | 0x584 | LONG_PA_THRES_ | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | MSB | [4:0] | LONG_PA_<br>THRESHOLD[12:8] | | Long average power threshold for comparison. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | 0x585 | LONG_PA_CONTROL | 7 | LONG_PA_ENABLE | | Enable long average power calculation and error detection. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | | | [6:4] | RESERVED | | Reserved. | 0x0 | R | | | | [3:0] | LONG_PA_AVG_<br>TIME | | Sets length of long PA averaging time. This control is paged by the MAINDAC_PAGE control in Register 0x008. Averaging time = 29 + LONG_PA_AVG_TIME (PA clock periods). A PA clock period is calculated by the following: | 0x0 | R/W | | | | | | | If the main interpolation is >1×, PA clock period = 4 × main interpolation × DAC clock period. If channel interpolation is >1×, PA clock period = 8 × main interpolation × DAC clock period. | | | | | | | | | Otherwise, PA clock period = 32 × DAC clock period. | | | | 0x586 | LONG_PA_POWER_<br>LSB | [7:0] | LONG_PA_<br>POWER[7:0] | | Long average power readback. Power detected at data bus = I2 + Q2. The data bus calculation only uses the 6 MSBs of the I and Q data bus samples. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|------------------------|-------|------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | 0x587 | LONG_PA_POWER_ | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | MSB | [4:0] | LONG_PA_<br>POWER[12:8] | | Long average power readback. Power detected at data bus = I2 + Q2. The data bus calculation only uses the 6 MSBs of the I and Q data bus samples. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R | | 0x588 | SHORT_PA_THRES_<br>LSB | [7:0] | SHORT_PA_<br>THRESHOLD[7:0] | | Short average power threshold for comparison. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | 0x589 | SHORT_PA_THRES_ | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | MSB | [4:0] | SHORT_PA_<br>THRESHOLD[12:8] | | Short average power threshold for comparison. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | 0x58A | SHORT_PA_<br>CONTROL | 7 | SHORT_PA_ENABLE | | Enable short average power calculation and error detection. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | | | [6:2] | RESERVED | | Reserved. | 0x0 | R | | | | [1:0] | SHORT_PA_AVG_<br>TIME | | Sets length of short PA averaging. This control is paged by the MAINDAC_PAGE control in Register 0x008. Averaging time = 2 <sup>SHORT_PA_AVG_TIME</sup> (PA clock periods). A PA clock period is calculated by the following: If the main interpolation is >1×, PA clock period = 4 × main interpolation × DAC clock period. If channel interpolation is >1×, PA clock period = 8 × main interpolation × DAC | 0x0 | R/W | | | | | | | clock period. Otherwise, PA clock period = 32 × DAC clock period. | | | | 0x58B | SHORT_PA_POWER_<br>LSB | [7:0] | SHORT_PA_<br>POWER[7:0] | | Short average power readback. Power detected at data bus = I2 + Q2. The data bus calculation only uses the 6 MSBs of the I and Q data bus samples. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R | | 0x58C | SHORT_PA_POWER_ | [7:5] | RESERVED | | Reserved. | 0x0 | R | | | MSB | [4:0] | SHORT_PA_<br>POWER[12:8] | | Short average power readback. Power detected at data bus = I2 + Q2. The data bus calculation only uses the 6 MSBs of the I and Q data bus samples. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R | | 0x58D | TXEN_SM_0 | [7:1] | RESERVED | | Reserved. | 0x1 | R/W | | | | 0 | ENA_TXENSM | | Enable TXEN state machine. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | 0x596 | BLANKING_CTRL | [7:4] | RESERVED | | Reserved. | 0x0 | R | | | | 3 | SPI_TXEN | | If ENA_SPI_TXEN (Bit 2 of this register) = 1, the value of this register is the value of the TXENx status. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | | | 2 | ENA_SPI_TXEN | | Enable TXENx control via the SPI by setting this bit to 1. This control is paged by the MAINDAC_PAGE control in Register 0x008. | 0x0 | R/W | | | | [1:0] | RESERVED | | Reserved. | 0x0 | R | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |--------|---------------------|-------|-----------------|----------|-----------------------------------------------------------------------------|----------|--------| | 0x597 | JESD_PA_INT0 | [7:0] | JESD_PA_INT_ | | Each bit enables a JESD204B PA interrupt. | 0x0 | R/W | | | | | CNTRL[7:0] | | Bit 8 = CGS. | | | | | | | | | Bit 7 = frame sync. | | | | | | | | | Bit 6 = good check sum. | | | | | | | | | Bit 5 = initial lane sync. | | | | | | | | | Bit 4 = interlane deskew. | | | | | | | | | Bit 3 = bad disparity error counter. | | | | | | | | | Bit 2 = NIT error counter. | | | | | | | | | Bit 1= UEK error counter. | | | | | | | | | Bit 0 = lane FIFO overflow or underflow. | | | | 0x598 | JESD_PA_INT1 | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | JESD_PA_INT_ | | Each bit enables a JESD204B PA interrupt. | 0x0 | R/W | | | | | CNTRL[8] | | Bit 8 = CGS | | - | | | | | | | Bit 7 = frame sync. | | | | | | | | | Bit 6 = good check sum. | | | | | | | | | Bit 5 = initial lane sync. | | | | | | | | | Bit 4 = interlane deskew. | | | | | | | | | Bit 3 = bad disparity error counter. | | | | | | | | | Bit 2 = NIT error counter. | | | | | | | | | Bit 1= UEK error counter. | | | | | | | | | Bit 0 = lane FIFO overflow or underflow. | | | | 0,4500 | TVEN FILICH CTDIO | [7.1] | DECEDVED | | Reserved. | 0.0 | R | | 0x599 | TXEN_FLUSH_CTRL0 | [7:1] | RESERVED | | | 0x0 | | | | | 0 | SPI_FLUSH_EN | | Enable datapath flush. This control is paged by the MAINDAC_PAGE control in | 0x1 | R/W | | | | | | | Register 0x008. | | | | 0x705 | NVM_LOADER_EN | [7:1] | RESERVED | | Reserved. | 0x0 | R | | 0,7,05 | IVVIII_EO/IDEII_EIV | 0 | NVM_BLR_EN | | Enable bootloader. This bit self clears when | 0x0 | R/W | | | | ١ | INVIVI_DEIX_EIN | | the boot loader completes or fails. | OXO | 11/ VV | | 0x790 | DACPLL_PDCTRL0 | 7 | PLL_PD5 | | PLL power-down control. Write this bit to 1 | 0x0 | R/W | | 0,7,70 | DACTEL_T DETREE | , | 1 22_1 03 | | if bypassing the PLL. If using the PLL, keep | OXO | 1000 | | | | | | | this value at default (0). | | | | | | [6:4] | PLL_PD4 | | PLL power-down control. Write this bit to 1 | 0x0 | R/W | | | | | | | if bypassing the PLL. If using the PLL, keep | | | | | | | | | this value at default (0). | | | | | | 3 | PLL_PD3 | | PLL power-down control. Write this bit to 1 | 0x0 | R/W | | | | | | | if bypassing the PLL. If using the PLL, keep | | | | | | | 211 222 | | this value default (0). | | 5011 | | | | 2 | PLL_PD2 | | PLL power-down control. Write this bit to 1 | 0x0 | R/W | | | | | | | if bypassing the PLL. If using the PLL, keep this value at default (0). | | | | | | 1 | PLL_PD1 | | PLL power-down control. Write this bit to 1 | 0x1 | R/W | | | | ' | FLL_FUI | | if bypassing the PLL. If using the PLL, write | UXI | IT/ VV | | | | | | | this bit to 0. | | | | | | 0 | PLL_PD0 | | PLL power-down control. Write this bit to 1 | 0x0 | R/W | | | | | | | if bypassing the PLL. If using the PLL, keep | | | | | | | | | this value at default (0). | <u> </u> | | | 0x791 | DACPLL_PDCTRL1 | [7:5] | RESERVED | | Reserved. | 0x0 | R/W | | | | 4 | PLL_PD10 | | PLL power-down control. Write this bit to 1 | 0x0 | R/W | | | | | | | if bypassing the PLL. If using the PLL, keep | | | | | | | | | this value at default (0). | | | | | | 3 | PLL_PD9 | | PLL power-down control. Write this bit to 1 | 0x0 | R/W | | | | | | | if bypassing the PLL. If using the PLL, keep | | | | | | | 211 226 | | this value at default (0). | 1 | 5 | | | | 2 | PLL_PD8 | 1 | PLL power-down control. Write this bit to 1 | 0x0 | R/W | | | | | | | if bypassing the PLL. If using the PLL, keep | | | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|--------------|-------|-------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------| | | | 1 | PLL_PD7 | | PLL power-down control. Write this bit to 1 if bypassing the PLL. If using the PLL, keep this value at default (0). | 0x0 | R/W | | | | 0 | PLL_PD6 | | PLL power-down control. Write this bit to 1 if bypassing the PLL. If using the PLL, keep this value at default (0). | 0x0 | R/W | | 0x792 | DACPLL_CTRL0 | [7:2] | RESERVED | | Reserved. | 0x0 | R | | | | 1 | D_CAL_RESET | | Resets VCO calibration. | 0x1 | R/W | | | | 0 | D_RESET_VCO_DIV | | Setting this high holds the VCO output divider in reset. This has the effect of turning off the input (and output) of the ADC clock driver. | 0x0 | R/W | | 0x793 | DACPLL_CTRL1 | [7:2] | RESERVED | | Reserved. | 0x0 | R | | | | [1:0] | M_DIVIDER-1 | 0<br>1<br>10 | Programmable predivider value for PFD (in n − 1 notation). M_DIVIDER = PLL reference clock/PFD frequency. For optimal spectral performance, choose an M divider setting that selects a high PFD frequency within the allowable PFD range. For 9.96 GHz ≤ VCO frequency ≤ 10.87 GHz, 25 MHz ≤ PFD frequency ≤ 225 MHz. For 9.96 GHz > VCO frequency > 10.87 GHz, 25 MHz ≤ PFD frequency ≤ 770 MHz. Divide by 1. Divide by 2. Divide by 3. Divide by 4. | 0x0 | R/W | | 0x794 | DACPLL_CTRL2 | [7:6] | RESERVED | | Reserved. | 0x0 | R/W | | | | [5:0] | DACPLL_CP | | Charge pump current control. Charge pump current = $100 \mu A + code \times 100 \mu A$ . | 0x4 | R/W | | 0x795 | DACPLL_CTRL3 | [7:4] | RESERVED | | Reserved. | 0x0 | R/W | | | | [3:0] | D_CP_CALBITS | | DAC PLL optimization control. | 0x8 | R/W | | 0x796 | DACPLL_CTRL4 | [7:4] | PLL_CTRL0 | | DAC PLL optimization control. | 0xD | R/W | | | | [3:0] | RESERVED | | Reserved. | 0x2 | R/W | | 0x797 | DACPLL_CTRL5 | [7:6] | RESERVED | | Reserved. | 0x0 | R/W | | | | [5:0] | PLL_CTRL1 | | DAC PLL optimization control. | 0x20 | R/W | | 0x798 | DACPLL_CTRL6 | 7 | RESERVED | | Reserved. | 0x0 | R | | | | 6 | PLL_CTRL3 | | DAC PLL optimization control. | 0x0 | R/W | | | | [5:0] | PLL_CTRL2 | | DAC PLL optimization control. | 0x1C | R/W | | 0x799 | DACPLL_CTRL7 | [7:6] | ADC_CLK_DIVIDER | 0<br>1<br>10<br>11 | ADC clock output divider. Divide by 1. Divide by 2. Divide by 3. Divide by 4. | 0x0 | R/W | | | | [5:0] | N_DIVIDER | | Programmable divide by N value from 2 to 50. N_DIVIDER = (DAC frequency × M_DIVIDER)/(8 × reference clock frequency). | 0x8 | R/W | | 0x7A0 | DACPLL_CTRL9 | [7:6] | RESERVED | | Reserved. | 0x2 | R/W | | | | 5 | D_EN_VAR_FINE_<br>PRE | | DAC PLL control. | 0x0 | R/W | | | | [4:3] | RESERVED | | Reserved. | 0x2 | R/W | | | | 2 | D_EN_VAR_<br>COARSE_PRE | | DAC PLL control. | 0x0 | R/W | | | | [1:0] | RESERVED | | Reserved. | 0x0 | R/W | | Addr. | Name | Bits | Bit Name | Settings | Description | Reset | Access | |-------|---------------|-------|--------------------------|----------|-------------------------------|-------|--------| | 0x7A2 | DACPLL_CTRL10 | 7 | RESERVED | | Reserved. | 0x0 | R | | | | [6:5] | D_REGULATOR_<br>CAL_WAIT | | DAC PLL optimization control. | 0x1 | R/W | | | | [4:3] | D_VCO_CAL_WAIT | | DAC PLL optimization control. | 0x2 | R/W | | | | [2:1] | D_VCO_CAL_<br>CYCLES | | DAC PLL optimization control. | 0x2 | R/W | | | | 0 | RESERVED | | Reserved. | 0x1 | R/W | | 0x7B5 | PLL_STATUS | [7:1] | RESERVED | | Reserved. | 0x0 | R | | | | 0 | PLL_LOCK | | DAC PLL lock status. | 0x0 | R | ## **OUTLINE DIMENSIONS** Figure 88. 144-Ball Ball Grid Array, Thermally Enhanced [BGA\_ED] (BP-144-1) Dimensions shown in millimeters ## **ORDERING GUIDE** | Model <sup>1</sup> | Temperature Range | Package Description | Package Option | |--------------------|-------------------|-------------------------------------------------------|----------------| | AD9172BBPZ | -40°C to +85°C | 144-Ball Ball Grid Array, Thermally Enhanced [BGA_ED] | BP-144-1 | | AD9172BBPZRL | -40°C to +85°C | 144-Ball Ball Grid Array, Thermally Enhanced [BGA_ED] | BP-144-1 | | AD9172-FMC-EBZ | | Evaluation Board | | <sup>&</sup>lt;sup>1</sup> Z = RoHS Compliant Part.