# Low-Power Audio Codec with SoundWire®-I2S/TDM and Audio Processing ## **System Features** - Stereo headphone (HP) output with 114-dB dynamic range - Class H HP amplifier with four-level automatic or manual supply adjust - Power output 2 x 35 mW into 30 Ω - –101 dB THD+N (30 Ω, A-weighted) stereo output mode - –106 dB THD+N (30 Ω, A-weighted) mono output mode - Mono mic input with 114-dB dynamic range - Low-noise headset bias with integrated bias resistor - 1-V<sub>RMS</sub> input voltage - Integrated AC-coupling capacitors - · Integrated detect features - OMTP (Open Mobile Terminal Platform) and AHJ (American headset jack) headset-type detection and configuration with low-impedance internal switches - Mic short (S0 Button) detect with ADC automute - Automatic Hi-Z of headset bias output to ground on headset bias current rise or HP/headset unplug - System wake from headset/headphone plug/unplug or S0 button press - Interrupt output - · Mono equalizer for side-tone mix - MIPI<sup>®</sup> SoundWire® or I<sup>2</sup>C/I<sup>2</sup>S/TDM control and audio interface - S/PDIF transmit (Sony/Philips digital interface format) - · Integrated fractional-N PLL - Increases system-clock flexibility for audio processing - Reference clock sourced from either I<sup>2</sup>S/TDM bit clock or MIPI SoundWire clock - Audio serial port (ASP) - I<sup>2</sup>S (two channels) or TDM (up to four channels) - Slave or Hybrid-Master Mode (bit-clock slave and LRCK/FSYNC derived from bit clock) - Sample-rate converter (SRC) for two input channels, with bypass - SRC for one output channel, with bypass - User isochronous audio transport support - Supports up to 192-kHz sample rate to S/PDIF output - Sample rate support for 8 to 192 kHz - · Integrated power management - Digital core operates from either an external 1.2-V supply or LDO from a 1.8-V supply. - Step-down charge pump improves HP efficiency - Independent peripheral power-down controls - Standby operation from VP with all other supplies powered off - VP monitor to detect and report brownout conditions - Low-impedance switching suppresses ground-noise ## **Applications** - Ultrabooks, tablets, and smartphones - · Digital headsets #### **General Description** The CS42L42 is a low-power audio codec with integrated MIPI SoundWire interface or I<sup>2</sup>C/I<sup>2</sup>S/TDM interfaces designed for portable applications. It provides a high-dynamic range, stereo DAC for audio playback and a mono high-dynamic-range ADC for audio capture. The CS42L42 provides high performance (up to 24-bit) audio for ADC and DAC audio playback and capture functions as well as for the S/PDIF transmitter. The CS42L42 architecture includes bypassable SRCs and a bypassable, three-band, 32-bit parametric equalizer that allows processing of digital audio data. A digital mixer is used to mix the ADC or serial ports to the DACs. There is independent attenuation on each mixer input. The processing along the output paths from the ADC or serial port to the two stereo DACs includes volume adjustment and mute control. The CS42L42 is available in a 49-ball WLCSP package and a 48-pin QFN package for extended temperature range grade of –40°C to +85°C. # **Table Of Contents** | 1 Pin Assignments and Descriptions | 6 | |-----------------------------------------------------------------------------------------------------------|------| | 1.1 This section shows pin assignments and describes pin functions.WLCSP Pin Out (Through-Package View) . | 6 | | 1.2 Pin Descriptions | 8 | | 1.3 Electrostatic Discharge (ESD) Protection Circuitry | 10 | | 2 Typical Connections | 12 | | 2.1 Electromagnetic Compatibility (EMC) Circuitry | 14 | | 3 Characteristics and Specifications | | | Table 3-1. Parameter Definitions | . 15 | | Table 3-2. Recommended Operating Conditions | . 15 | | Table 3-3. Absolute Maximum Ratings | . 15 | | Table 3-4. Output Fault Rating | . 16 | | Table 3-6. ADC High-Pass Filter (HPF) Characteristics | 16 | | Table 3-6. ADC High-Pass Filter (HPF) Characteristics | . 16 | | Table 3-8. DAC High-Pass Filter (HPF) Characteristics | 17 | | Table 3-9. HSINx to SDOUT with SRC-Enabled Datapath Characteristics | 17 | | Table 3-10. SDIN to HPOUTx with SRC-Enabled Datapath Characteristics | . 17 | | Table 3-11. Wind-Noise Digital Filter Characteristics | . 10 | | Table 3-13. Serial Data In-to-HPOUTx Characteristics | . 13 | | Table 3-14. HSBIAS Characteristics | . 21 | | Table 3-15. Switching Specifications—HSBIAS | 23 | | Table 3-16. DC Characteristics | . 25 | | Table 3-17. Power-Supply Rejection Ratio (PSRR) Characteristics | . 25 | | Table 3-18. Power Consumption | | | Table 3-20. S0 Button Detect Characteristics | . 28 | | Table 3-21. Switching Specifications—SoundWire Port | . 28 | | Table 3-22. Digital Aŭdio Interface Timing Characteristics | . 30 | | Table 3-23. Switching Characteristics—S/PDIF Transmitter | . 31 | | Table 3-24. I <sup>2</sup> C Slave Port Characteristics | . 31 | | Table 3-25. Digital Interface Specifications and Characteristics | 33 | | 4.1 Analog Input | | | 4.2 Digital Mixer | | | 4.3 Three-Band Equalizer | | | 4.4 Analog Output | | | 4.5 System Headphone Parasitic Resistances | | | 4.6 Class H Amplifier | | | 4.7 Clocking Architecture | | | 4.8 SoundWire Interface | | | 4.9 Audio Serial Port (ASP) | 70 | | 4.10 S/PDIF Tx Port | | | 4.11 Sample-Rate Converters (SRCs) | | | 4.12 Headset Interface | | | 4.13 Headset Type Detect | | | 4.14 Plug Presence Detect | | | 4.15 Power-Supply Considerations | | | 4.16 Control-Port Operation | | | 4.17 Reset | | | 4.18 Interrupts | | | 4.19 FILT+ Operation | | | 5 System Applications | | | 5.1 Power-Up Sequence | | | · · | | | 5.2 Power-Down Sequence | | | 5.3 SoundWire Power Sequences | | | 5.4 Page 0x30 Read Sequence | | | 5.5 PLL Clocking | | | 5.6 Standby Mode and Headset Clamps | 101 | | | | | • | |-----|----------------------------------------------|-----|---| | | 5.7 Detection Sequence from Wake | 102 | , | | | 5.8 VD_FILT/VL ESD Diode | 105 | ) | | | 5.9 External Output Switch Considerations | 106 | į | | 3 F | egister Quick Reference | 107 | , | | | 6.1 SoundWire Address Maps | 108 | į | | | 6.2 Slave Control Port Registers | 109 | j | | | 6.3 Slave Data Port 1–3, 15 Registers | 110 | j | | | 6.4 Global Registers | | | | | 6.5 Power-Down and Headset-Detect Registers | | | | | 6.6 Clocking Registers | | | | | 6.7 Interrupt Registers | | | | | 6.8 Fractional-N PLL Registers | | | | | 6.9 HP Load Detect Registers | | | | | 6.10 Headset Interface Registers | | | | | 6.11 Headset Bias Registers | | | | | 6.12 ADC Registers | | | | | 6.13 DAC Registers | | | | | 6.14 HP Control Registers | | | | | 6.15 Class H Registers | | | | | 6.16 Mixer Volume Registers | | | | | 6.17 Equalizer Registers | | | | | 6.18 AudioPort Interface Registers | | | | | 6.19 SRC Registers | | | | | 6.20 DMA Registers | | | | | 6.21 S/PDIF Registers | | | | | 6.22 Serial Port Transmit Registers | | | | | 6.23 Serial Port Receive Registers | | | | | 6.24 ID Registers | | | | 7 F | egister Descriptions | | | | | 7.1 SoundWire Control Port 0 Registers | | | | | 7.2 SoundWire Data Port (1–3) Descriptions | | | | | 7.3 Global Registers | | | | | 7.4 Power Down and Headset Detects | | | | | 7.5 Clocking Registers | | | | | 7.6 Interrupt Registers | | | | | 7.7 Fractional-N PLL Registers | | | | | 7.8 HP Load-Detect Registers | | | | | 7.9 Headset Interface Registers | | | | | 7.10 Headset Bias Registers | | | | | 7.11 ADC Registers | | | | | 7.12 DAC Control Registers | | | | | 7.13 HP Control Register | | | | | 7.14 Class H Register | | | | | 7.15 Mixer | | | | | 7.16 Equalizer | | | | | 7.17 AudioPort Interface Registers | | | | | 7.18 SRC Registers | | | | | 7.19 DMA Registers | | | | | 7.20 S/PDIF | | | | | 7.21 Serial Port Register Transmit Registers | | | | | 7.22 Serial Port Receive Registers | | | | | 7.23 ID Registers | | | | 3 P | CB Layout Considerations | | | | • | 8.1 Power Supply | | | | | 8.2 Grounding | | | | | 8.3 QFN Thermal Pad | | | | | | | | | 9 Plots | 175 | |----------------------------------------------------------|-----| | 9.1 Digital Filter Response | | | 9.2 Windnoise Filter Responses | | | 9.3 HSBIAS Current Sense vs. VP Voltage per Trip Setting | | | 10 Package Dimensions | | | 10.1 WLCSP Package Dimensions | 184 | | 10.2 QFN Package Dimensions | 185 | | 11 Thermal Characteristics | 186 | | 12 Ordering Information | | | 13 References | | | 14 Revision History | 187 | | | | ## 1 Pin Assignments and Descriptions This section shows pin assignments and describes pin functions. ## 1.1 WLCSP Pin Out (Through-Package View) Figure 1-1. WLCSP Pin Diagram (Through-Package View) ## 1.2 QFN Pin Out (Through-Package View) Figure 1-2. QFN Pin Diagram # 1.3 Pin Descriptions Table 1-1. Pin Descriptions | Pin Name | CSP<br>Pin # | QFN<br>Pin# | Power<br>Supply | I/O | Pin Description | Internal<br>Connection | Driver | Receiver | State at<br>Reset | |------------------------|--------------|-------------|-----------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|------------------------------|--------------------------------|-------------------| | | | | | | Microphone 🛝 | <u> </u> | | | | | HS_CLAMP1<br>HS_CLAMP2 | F2<br>E2 | 26<br>27 | VP | I | Headset Depletion FET Connections. Input to drain of integrated depletion FET for ground-noise rejection. | _ | _ | _ | Input | | HS3_REF<br>HS4_REF | G4<br>F4 | 19<br>20 | VP | I | Headset Connection Reference. Input to pseudodifferential HP output reference | _ | _ | _ | Input | | HS3<br>HS4 | G2<br>F1 | 24<br>28 | VP | I | Headset Connections. Input to headset and mic-button detection functions | _ | _ | _ | Input | | HSBIAS_FILT | F3 | 22 | VP | ı | Headset Bias Source Voltage Filter. Filter connection for the internal quiescent voltage used for headset bias generation. | _ | _ | _ | Input | | HSBIAS_FILT_<br>REF | E3 | 23 | VP | I | Headset Bias Source Voltage Filter Reference. Input of filter connection for the internal quiescent voltage used for headset-bias generation. | _ | _ | _ | Input | | HSIN- | D1 | 30 | VP | Τ | Inverting Mic Inputs. Inverting analog input for the ADC. | _ | _ | _ | Input | | HSIN+ | E1 | 29 | VP | I | <b>Noninverting Mic Inputs.</b> Noninverting analog input for the ADC. | _ | _ | _ | Input | | RING_SENSE | G3 | 21 | VP | I | <b>Ring Sense Input.</b> Sense pin to detect S/PDIF or headphone plug. Can be configured to be debounced on plug and unplug events independently. | _ | _ | _ | Input | | | | | | | Headphone ( ) | | | | | | HPOUTA<br>HPOUTB | E5<br>G5 | 15<br>16 | ±VCP_<br>FILT | 0 | Headphone Audio Output. Ground-centered audio output. | _ | _ | _ | _ | | HPSENSA<br>HPSENSB | D5<br>F5 | 14<br>17 | ±VCP_<br>FILT | I | Headphone Audio Sense Input. Audio sense input. | _ | | _ | Input | | TIP_SENSE | E4 | 18 | VP | I | <b>Tip Sense.</b> Output can be set to wake the system. Independently configurable to be debounced on plug and unplug events. | _ | Hi-Z | _ | _ | | | | | | | Digital I/O | | | | | | AD0<br>AD1 | C3<br>B2 | 35<br>34 | VL | I | I2C Address Input/SoundWire Instance ID Input.<br>Address pins for I2C or SoundWire Instance ID [1:0] input. | _ | _ | Hysteresis<br>on CMOS<br>input | Input | | ASP_LRCK/<br>FSYNC | B5 | 43 | VL | I/O | ASP Left/Right Clock or Frame Sync. Left or right word select, or frame start sync for the ASP interface. | _ | CMOS<br>output | Hysteresis<br>on CMOS<br>input | Input | | ASP_SCLK/<br>SWIRE_CLK | B4 | 42 | VL | I | ASP/SoundWire Serial Data Clock. SoundWire data-shift clock in SoundWire Mode or serial data-shift clock for the ASP interface in I <sup>2</sup> S/TDM Mode. Source clock used for internal master clock generation. | _ | _ | Hysteresis<br>on CMOS<br>input | Input | | ASP_SDIN/<br>SWIRE_SD | A5 | 44 | VL | I/O | ASP Serial Data Input/SoundWire Serial Data Input and Output. Serial data input and output in SoundWire mode or serial data input for the ASP interface in I2S/TDM mode. | _ | CMOS<br>output | Hysteresis<br>on CMOS<br>input | Input | | ASP_SDOUT | A4 | 41 | VL | 0 | <b>ASP Serial Data Output.</b> Serial data output for the ASP interface. | Weak<br>pull-down | CMOS<br>output | _ | Output | | DIGLDO_PDN | D4 | 4 | VP | I | <b>Digital LDO Power Down.</b> Digital core logic LDO power down. | _ | <u>-</u> | Hysteresis<br>on CMOS<br>input | Input | | ĪNT | В7 | 2 | VP | 0 | Interrupt output. Programmable, open-drain, active-low programmable interrupt output. | _ | CMOS<br>open-drain<br>output | <u>.</u> | Output | | RESET | C5 | 1 | VP | I | Reset. Hardware reset. | _ | <u>.</u> | Hysteresis<br>on CMOS<br>input | Input | | SCL | A2 | 37 | VL | I | I <sup>2</sup> C Clock. Clock input for the I <sup>2</sup> C interface. | _ | _ | Hysteresis<br>on CMOS<br>input | Input | Table 1-1. Pin Descriptions (Cont.) | Pin Name | CSP<br>Pin # | QFN<br>Pin# | Power Supply | I/O | Pin Description | Internal<br>Connection | Driver | Receiver | State at<br>Reset | |-----------|--------------|-------------|-------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------------------------------------|--------------------------------|-------------------| | SDA | A1 | 36 | VL | I/O | I <sup>2</sup> C Input/Output. I <sup>2</sup> C input and output. | _ | CMOS<br>open-drain<br>output | Hysteresis<br>on CMOS<br>input | Input | | SPDIF_TX | A6 | 45 | VL | 0 | <b>S/PDIF Audio Serial Data Output.</b> Serial data output for S/PDIF interface. | _ | CMOS<br>output | _ | Output | | SWIRE_SEL | D3 | 40 | VL | I | <b>SoundWire Select.</b> SoundWire interface selection input. Defines the serial and audio interface type. If asserted, SoundWire is the control and audio interface, otherwise I2C is control and TDM/I2S is used for audio data. | _ | _ | Hysteresis<br>on CMOS<br>input | Input | | VL_SEL | C4 | 48 | VP | I | VL Supply Voltage Select. Select for VL power supply voltage level. Connect to VP for 1.8-V VL supply, connect to GNDD for 1.2-V VL supply | _ | _ | Hysteresis<br>on CMOS<br>input | Input | | WAKE | C6 | 3 | VP | 0 | Wake up. Programmable, open-drain, active-low output. This outputs the state of the Mic S0 or HP wake detect. | _ | Hi-Z,<br>CMOS<br>open-drain<br>output | _ | Output | | | | | | | Charge Pump 🛑 | | | | | | -VCP_FILT | G6 | 13 | VCP/<br>VP <sup>1</sup> | 0 | <b>Inverting Charge Pump Filter Connection.</b> Power supply for the inverting charge pump that provides the negative rail for the HP amplifier. | _ | _ | _ | _ | | +VCP_FILT | E6 | 10 | VCP/<br>VP <sup>1</sup> | 0 | Step Down Charge Pump Filter Connection. Power supply for the step down charge pump that provides the positive rail for the HP amplifier. | _ | _ | _ | _ | | FLYC | F7 | 9 | VCP/<br>VP <sup>1</sup> | 0 | Charge Pump Cap Common Node. Common positive node for the HP amplifiers' step-down and inverting charge pumps' flying capacitors. | _ | _ | _ | _ | | FLYN | G7 | 11 | VCP/<br>VP <sup>1</sup> | 0 | <b>Charge Pump Cap Negative Node.</b> Negative node for the inverting charge pump's flying capacitor. | _ | _ | _ | _ | | FLYP | E7 | 8 | VCP/<br>VP <sup>1</sup> | 0 | <b>Charge Pump Cap Positive Node.</b> Positive node for HP amps' step-down charge pump's flying capacitor. | _ | _ | _ | _ | | | | | | | Power | | | | | | FILT+ | C1 | 32 | VA | I | Positive Voltage Reference. Positive reference voltage for internal sampling circuits. | _ | _ | _ | _ | | VA | B1 | 33 | N/A | I | <b>Analog Power Supply.</b> Power supply for the internal analog section. | _ | _ | _ | _ | | VCP | D6 | 7 | N/A | I | <b>Charge Pump Power.</b> Power supply for the internal HP amplifiers charge pump. | _ | _ | _ | _ | | VD_FILT | A7 | 47 | N/A | I | <b>1.2-V Digital Core Power Supply.</b> Power supply for internal digital logic. | _ | _ | _ | _ | | VL | A3 | 39 | N/A | ı | I/O Power Supply. Power supply for external interface and internal digital logic. | _ | _ | _ | _ | | VP | D7 | 6 | N/A | ı | <b>High Voltage Interface Supply.</b> Power supply for high voltage interface. | _ | _ | _ | _ | | | | | | | Ground 🔘 | | | | | | GNDA | C2 | 31 | N/A | I | <b>Analog Ground.</b> Ground reference for the internal analog section. | _ | _ | _ | _ | | GNDL | В3 | 38 | N/A | I | <b>Digital Ground.</b> Ground reference for interface section. | _ | | | | | GNDHS | G1 | 25 | N/A | I | <b>Headset Ground.</b> Ground reference for the internal analog section. | _ | _ | _ | <u> </u> | | GNDCP | F6 | 12 | N/A | I | <b>Charge Pump Ground.</b> Ground reference for the internal HP amplifiers charge pump. | _ | | | | | GNDD | В6 | 46 | N/A | ı | <b>Digital Ground.</b> Ground reference for the internal digital circuits. | _ | _ | _ | _ | | | | | | | Test | | | <u></u> | | | TSTI | D2, C7 | _ | N/A | I | Test input. Connect to GNDA. | _ | _ | _ | _ | <sup>1.</sup> The power supply is determined by ADPTPWR setting (see Section 7.14.1). VP is used if ADPTPWR = 001 (VP\_CP Mode) or when necessary for ADPTPWR = 111 (Adapt-to-Signal Mode). ## 1.4 Electrostatic Discharge (ESD) Protection Circuitry VA/ **GNDA** 10 FILT+ **GNDA** VA ESD-sensitive device. The CS42L42 is manufactured on a CMOS process. Therefore, it is generically susceptible to damage from excessive static voltages. Proper ESD precautions must be taken while handling and storing this device. This device is qualified to current JEDEC ESD standards. Fig. 1-3 provides a composite view of the ESD domains showing the ESD protection paths between each pad and the substrate (GNDA) and the interrelations between some domains. Note that this figure represents the structure for the internal protection devices and that additional protections can be implemented as part of the integration into the board. Figure 1-3. Composite ESD Topology Table 1-2 shows the individual ESD domains and lists the pins associated with each domain. **ESD** Signal Name (CSP/QFN) **Topology** (See \* in Topology Figures for Pad) **Domain** VL/ AD0 GNDA 1 AD1 ASP LRCK/FSYNC Ø VL Ø VD\_FILT GNDL SCL SDA ASP SDOUT SPDIF\_TX SWIRE\_SEL Substrate ASP\_SCLK/SWIRE\_CLK (GNDA) SWIRE SD/ASP SDIN VD\_FILT VD FILT/ VD FILT GNDD **GNDA** ☑ VD\_FILT VL 🔯 TSTI Table 1-2. ESD Domains Ø ⊠ VA **GNDD** Substrate (GNDA) Substrate (GNDA) ### Table 1-2. ESD Domains (Cont.) | ESD<br>Domain | Signal Name (CSP/QFN)<br>(See * in Topology Figures for Pad) | Topology | |---------------------------------|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------| | VCP/<br>GNDA | VCP | Substrate (GNDA) | | VP/<br>GNDA | GNDHS HS3 HS4 HS_CLAMP1 HS_CLAMP2 HSBIAS_FILT HSBIAS_FILT_REF HSIN+ HSIN- VP VL_SEL INT WAKE_ RESET_ DIGLDO_PDN | VP/GNDA Domain VP GNDHS W* GNDCP W* GNDCP W* GNDCP | | +VCP_<br>FILT/<br>-VCP_<br>FILT | +VCP_FILT<br>-VCP_FILT<br>FLYN<br>HPSENSA<br>HPSENSB<br>HPOUTA<br>HPOUTB<br>GNDCP | Substrate (GNDA) Substrate (GNDA) | | VP/<br>-VCP_<br>FILT | FLYC<br>FLYP<br>HS3_REF<br>HS4_REF<br>RING_SENSE<br>TIP_SENSE | VP/–VCP_FILT Domain | <sup>1.</sup> See Section 5.8 for additional information regarding VD\_FILT and VL. ## 2 Typical Connections Figure 2-1. Typical Connection Diagram for I<sup>2</sup>C, I<sup>2</sup>S, or TDM Figure 2-2. Typical Connection Diagram for SoundWire - $\overline{\text{1.}}$ R<sub>P\_I</sub> and R<sub>P\_W</sub> values can be determined by the $\overline{\text{INT}}$ and $\overline{\text{WAKE}}$ pin specifications in Table 3-25. - 2. R<sub>P I2C</sub> values can be determined by the I2C pull-up resistance specification in Table 3-24. - 3. The headphone amplifier's output power and distortion ratings use the nominal capacitances shown. Larger capacitance reduces ripple on the internal amplifiers' supplies and, in turn, reduces distortion at high-output power levels. Smaller capacitance may not reduce ripple enough to achieve output power and distortion ratings. Because actual values of typical X7R/X5R ceramic capacitors deviate from nominal values by a percentage specified in the manufacturer's data sheet, capacitors must be selected for minimum output power and maximum distortion required. Higher value capacitors than those shown may be used, however lower value capacitors must not (values can vary from the nominal by ±20%). See Section 2.1.2 for additional details. - 4. Series resistance in the path of the power supplies must be avoided. Any voltage drop on VCP directly affects the negative charge-pump supply (–VCP\_FILT) and clips the audio output. 5. Lowering capacitance below the value shown affects PSRR, THD+N performance, ADC–DAC isolation and intermodulation, and interchannel isolation and intermodulation. ## 2.1 Electromagnetic Compatibility (EMC) Circuitry The circuit in Fig. 2-3 may be applied to signals not local to the CS42L42 (i.e., that traverse significant distances) for EMC. Figure 2-3. Optional EMC Circuit ## 2.1.1 Low-Profile Charge-Pump Capacitors In the typical connection for analog mics (Fig. 2-1), the recommended capacitor values for the charge-pump circuitry are $2.2 \,\mu\text{F}$ , rated as X7R/X5R or better. The following low-profile versions of these capacitors are suitable for the application: - Description: 2.2 µF ±20%, 6.3 V, X5R, 0201 - Manufacturer, Part Number: Murata, GRM033R60J225ME47, nominal height = 0.3 mm - Manufacturer, Part Number: AVX, 02016D225MAT2A, nominal height = 0.33 mm **Note:** Although the 0201 capacitors described are suitable, larger capacitors such as 0402 or larger may provide acceptable performance. ## 2.1.2 Ceramic Capacitor Derating Note 3 in Fig. 2-1 highlights that ceramic capacitor derating factors can significantly affect in-circuit capacitance values and, in turn, CS42L42 performance. Under typical conditions, numerous types and brands of large-value ceramic capacitors in small packages exhibit effective capacitances well below their ±20% tolerance, with some being derated by as much as –50%. These same capacitors, when tested by a multimeter, read much closer to their rated value. A similar derating effect has not been observed with tantalum capacitors. The derating observed varied with manufacturer and physical size: Larger capacitors performed better, as did ones from Kemet Electronics Corp. and TDK Corp. of any size. This derating effect is described in data sheets and in applications notes from capacitor manufacturers. For instance, as DC and AC voltages are varied from the standard test points (applied DC and AC voltages for standard test points versus PSRR test are 0 and 1 V<sub>RMS</sub> @ 1 kHz versus 0.9 V and ~1 mV<sub>RMS</sub> @ 20 Hz–20 kHz), it is documented that the capacitances vary significantly. ## **Characteristics and Specifications** Table 3-1 defines parameters as they are characterized in this section. Table 3-1. Parameter Definitions | Parameter | Definition | |-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Dynamic range | The ratio of the rms value of the signal to the rms sum of all other spectral components over the specified bandwidth. A signal-to-noise ratio measurement over the specified bandwidth made with a –60 dB signal; 60 dB is added to resulting measurement to refer the measurement to full scale. This technique ensures that distortion components are below the noise level and do not affect the measurement. This measurement technique has been accepted by the Audio Engineering Society, AES17–1991, and the Electronic Industries Association of Japan, EIAJ CP–307. Dynamic range is expressed in decibel units. | | Idle channel noise | The rms value of the signal with no input applied (properly back-terminated analog input, digital zero, or zero modulation input). Measured over the specified bandwidth. | | Interchannel isolation | A measure of cross talk between the left and right channel pairs. Interchannel isolation is measured for each channel at the converter's output with no signal to the input under test and a full-scale signal applied to the other channel. Interchannel isolation is expressed in decibel units. | | Load resistance and capacitance | The recommended minimum resistance and maximum capacitance required for the internal op-amp's stability and signal integrity. The load capacitance effectively moves the band-limiting pole of the amp in the output stage. Increasing load capacitance beyond the recommended value can cause the internal op-amp to become unstable. | | Offset error | The deviation of the midscale transition (111111 to 000000) from the ideal. | | Output offset voltage | The DC offset voltage present at the amplifier's output when its input signal is in a mute state. The offset exists due to CMOS process limitations and is proportional to analog volume settings. When measuring the offset out the headphone amplifier, the headphone amplifier is ON. | | Total harmonic distortion + noise (THD+N) | The ratio of the rms sum of distortion and noise spectral components across the specified bandwidth (typically 20 Hz–20 kHz) relative to the rms value of the signal. THD+N is measured at –1 and –20 dBFS for the analog input and at 0 and –20 dB for the analog output, as suggested in AES17–1991 Annex A. THD+N is expressed in decibel units. | #### Table 3-2. Recommended Operating Conditions Test conditions: GNDA = GNDL = GNDCP = 0 V; voltages are with respect to ground. | | Parameters | Symbol | Minimum | Maximum | Unit | |-----------------------------------|-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------|-----------------------------------|------------------| | DC power | Charge pump | VCP | 1.66 | 1.94 | V | | supply | LDO regulator for digital <sup>1</sup> DIGLDO_PDN = 0 and VL_SEL = 0 | VD_FILT | 1.10 | 1.30 | V | | | Serial interface control port DIGLDO_PDN = 0 and VL_SEL = 0 and S/PDIF transmitter VL_SEL = 1 | VL<br>VL | 1.10<br>1.66 | 1.30<br>1.94 | V | | | Analog | VA | 1.66 | 1.94 | V | | | Battery supply | VP | 2.50 <sup>2</sup> | 5.25 | V | | External voltaç<br>applied to pin | | V <sub>INHI</sub><br>V <sub>V</sub> CPF<br>V <sub>V</sub> L<br>V <sub>V</sub> P | -VCP_FILT<br>-VCP_FILT<br>0<br>0<br>0 | VP<br>+VCP_FILT<br>VL<br>VA<br>VP | V<br>V<br>V<br>V | | Ambient temp | erature | T <sub>A</sub> | -40 | +85 | °C | Note: The device is fully functional and meets all parametric specifications in this section if operated within the specified conditions. Functionality and parametric performance is not guaranteed or implied outside of these limits. Operation outside of these limits may adversely affect device reliability. - 1.If DIGLDO\_PDN is deasserted, no external voltage must be applied to VD\_FILT. - 2. Although device operation is guaranteed down to 2.5 V, device performance is guaranteed only down to 3.0 V. The following are affected when VP < 3.0 V: HSBIAS, charge pump LDO, TIP\_SENSE threshold, RING\_SENSE threshold. 3.The maximum over/undervoltage is limited by the input current. - 4. Table 1-1 lists the power supply domain in which each CS42L42 pin resides. - 5.±VCP\_FILT is specified in Table 3-16. ## Table 3-3. Absolute Maximum Ratings Test conditions: GNDA = GNDL = GNDCP = 0 V; voltages are with respect to ground. | | Parameters | Symbol | Minimum | Maximum | Unit | |----------------------------|-------------------------------------------------------------|-----------------|---------|---------|------| | DC power supply | Charge pump, LDO, serial/control, analog (see Section 4.15) | VL, VA, VCP | -0.3 | 2.33 | V | | | Digital core | VD_FILT | -0.3 | 1.55 | V | | | Battery | VΡ | -0.3 | 6.3 | V | | Input current <sup>1</sup> | | I <sub>in</sub> | _ | ±10 | mΑ | | Ambient operating tempera | T <sub>A</sub> | -50 | +115 | °C | | | Storage temperature | | | -65 | +150 | °C | Caution: Stresses beyond "Absolute Maximum Ratings" levels may cause permanent damage to the device. These levels are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated in Table 3-2, "Recommended Operating Conditions" is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. 1.Any pin except supply pins. Transient currents of up to ±100 mA on analog input pins do not cause SCR latch-up. #### **Table 3-4. Output Fault Rating** Test conditions: GNDA = GNDCP = 0 V; VA = 1.8 V; VP = 3.6 V; voltages are with respect to ground. | Source 1 | Fault Supply | Expected Years <sup>2</sup> | |-----------------------------------------------|-------------------------|-----------------------------| | HPOUT(A,B) | VA | 1.5 | | | GNDA | 2 | | | +VCP_FILT | 0.5 | | | -VCP_FILT | 1.5 | | | VP | 1.5 | | HS3/HS4 (HSx switch to ground) | HPOUT(A,B) <sup>3</sup> | 3.2 | | HS3/HS4 (HSx switches to HSBIAS) | HPOUT(A,B) <sup>3</sup> | 0.75 | | HS3_REF/HS4_REF (HSx connected to ground) | HPOUT(A,B) | 3.2 | | HS3_REF/HS4_REF (HSx not connected to ground) | HPOUT(A,B) | 0.75 | <sup>1.</sup> Each source is individually connected directly to the specified supply during a fault condition. #### Table 3-5. Combined High-Performance ADC On-Chip Analog and Digital Filter Characteristics Test conditions (unless specified otherwise): T<sub>A</sub> = +25°C; MCLK = 12 MHz; MCLK\_SRC\_SEL = 0; Fs<sub>INT</sub> = 48 kHz; path is HSIN to internal routing engine. All gains are set to 0 dB; HPF disabled. | | Parameter <sup>1,2</sup> | Min | Typical | Max | Unit | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------------|------|-------------------| | Notch filter on | Passband (normalized to 0.417x10 <sup>-3</sup> Fs <sub>INT</sub> ) –0.18-dB corner | _ | 0.390 | | Fs <sub>int</sub> | | (ADC_NOTCH_ | -3.0-dB corner | _ | 0.410 | _ | Fs <sub>int</sub> | | DIS = 0) | Passband ripple (0.417x10 <sup>-3</sup> Fs <sub>INT</sub> to 0.390 Fs <sub>INT</sub> ; normalized to 0.417x10 <sup>-3</sup> Fs <sub>int</sub> ) | -0.23 | _ | 0.15 | dB | | | Stopband attenuation 1 (0.5 Fs <sub>INT</sub> to 0.524 Fs <sub>INT</sub> ) | 45 | _ | | dB | | | Stopband attenuation 2 (0.524 Fs <sub>INT</sub> to 3 Fs <sub>INT</sub> ) | 70 | _ | _ | dB | | | Total group delay <sup>3</sup> | _ | 5.6/Fs <sub>int</sub> | _ | s | | Notch filter off | Passband (normalized to 0.417x10 <sup>-3</sup> Fs <sub>INT</sub> ) –0.05-dB corner | _ | 0.390 | _ | Fs <sub>int</sub> | | (ADC_NOTCH_ | -3.0-dB corner | _ | 0.500 | _ | Fs <sub>int</sub> | | DIS = 1) | Passband ripple (0.417x10 <sup>-3</sup> Fs <sub>INT</sub> to 0.417 Fs <sub>INT</sub> ; normalized to 0.417x10 <sup>-3</sup> Fs <sub>INT</sub> ) | -0.29 | _ | 0.15 | dB | | | Stopband attenuation (0.64 Fs <sub>INT</sub> to 3 Fs <sub>INT</sub> ) | 70 | _ | _ | dB | | | Total group delay <sup>3</sup> | _ | 5.6/Fs <sub>int</sub> | _ | s | <sup>1.</sup>Response scales with Fsint (internal sample rate, based on MCLK). Specifications are normalized to Fsint and are denormalized by multiplying by Fsint. #### Table 3-6. ADC High-Pass Filter (HPF) Characteristics Test conditions (unless specified otherwise): ADC\_HPF\_CF = 00; all gains are set to 0 dB; specifications represent the frequency response of the entire path with ADC\_NOTCH\_DIS = 1, SRC\_ADC\_BYPASS = 1, ADC\_WNF\_EN = 0, and ADC\_HPF\_EN = 1. | Parameter <sup>1</sup> | | | Typical | Maximum | Unit | |------------------------------------------------------------------|-------------------------------------------------------------|---|--------------------------|---------|-------------------| | Passband (normalized to 0.2083 FS <sub>INT</sub> ) | -0.05-dB corner | _ | 0.666 x 10 <sup>-3</sup> | _ | Fs <sub>INT</sub> | | · | -3.0-dB corner | _ | 77.0 x 10 <sup>-6</sup> | _ | Fs <sub>INT</sub> | | Phase deviation @ 0.453 x 10 <sup>-3</sup> Fs <sub>INT</sub> [2] | | | 12.37 | _ | Deg | | Filter settling time <sup>3</sup> | ADC_HPF_CF = 00 (38.8 x $10^{-6}$ x Fs <sub>INT</sub> mode) | | 2900/Fs <sub>INT</sub> | _ | S | | | ADC_HPF_CF = 01 (2.5 x $10^{-3}$ x Fs <sub>INT</sub> mode) | _ | 170/Fs <sub>INT</sub> | _ | s | | | ADC_HPF_CF = 10 (4.9 x $10^{-3}$ x Fs <sub>INT</sub> mode) | | 90/Fs <sub>INT</sub> | _ | s | | | ADC_HPF_CF = 11 (9.7 x $10^{-3}$ x $Fs_{INT}$ mode) | _ | 50/Fs <sub>INT</sub> | _ | S | $<sup>1.</sup> Response \ scales \ with \ Fs_{INT} \ (based \ on \ internal \ MCLK). \ Specifications \ are \ normalized \ to \ Fs_{INT} \ and \ are \ denormalized \ by \ multiplying \ by \ Fs_{INT}.$ ### Table 3-7. Combined DAC Digital, On-Chip Analog, and HPOUTx Filter Characteristics Test conditions (unless specified otherwise): $T_A = +25$ °C; MCLK = 12 MHz, MCLK\_SRC\_SEL = 0, $Fs_{INT} = 48$ kHz; path is internal routing engine to HPOUTx, analog and digital gains are all set to 0 dB; HPF disabled. | Parameter <sup>1</sup> | Minimum | Typical | Maximum | Unit | |-------------------------------------------------------------------------------------------------------------------------------------------------|---------|------------------------|---------|-------------------| | Passband –0.05-dB corner | _ | 0.48 | _ | Fs <sub>INT</sub> | | -3.0-dB corner | _ | 0.50 | _ | Fs <sub>INT</sub> | | Passband ripple (0.417x10 <sup>-3</sup> Fs <sub>INT</sub> to 0.417 Fs <sub>INT</sub> ; normalized to 0.417x10 <sup>-3</sup> Fs <sub>INT</sub> ) | -0.04 | _ | 0.063 | dB | | Stopband attenuation (0.545 Fs <sub>INT</sub> to Fs <sub>INT</sub> ) | 60 | _ | _ | dB | | Total group delay <sup>2</sup> | _ | 5.35/Fs <sub>INT</sub> | _ | s | <sup>1.</sup> Response scales with FsINT (based on internal MCLK). Specifications are normalized to FsINT and denormalized by multiplying by FsINT. <sup>2.</sup> The rating is based on foundry electromigration design rules when a perpetual fault exists on the HP outputs. When the specified time expires, analog performance is expected to degrade. <sup>3.</sup>HPOUTx = 1 Vrms. If shorted to HSx, the headphone may be current limited in this configuration. <sup>2.</sup> Measurements with HPF disabled require either differential configuration or single-ended configuration with -30 dBFS input signal. <sup>3.</sup>Informational only; group delay cannot be measured for this block by itself. Total group delay includes delay through the entire ADC and decimator path total-group delay is measured at 1 kHz. <sup>2.</sup>An additional –2° phase deviation may be present through the total path from HSIN to SDOUT. <sup>3.</sup> Required time for the magnitude of the DC component present at the output of the HPF to reach 5% of the applied DC signal. 2.Informational only; group delay cannot be measured for this block by itself. An additional 5.5/Fs<sub>int</sub> group delay may be present through the serial ports and internal audio bus. #### Table 3-8. DAC High-Pass Filter (HPF) Characteristics Test conditions (unless specified otherwise) Analog and digital gains are all set to 0 dB; T<sub>A</sub> = +25°C. | Parameter <sup>1</sup> | Minimum | Typical | Maximum | Unit | |--------------------------------------------------------------------------------------------------------------------------------|---------|-----------------------------------------|---------|-------------------| | Passband –0.05-dB corner | _ | 0.180x10 <sup>-3</sup> | _ | Fs <sub>INT</sub> | | -3.0-dB corner | _ | 19.5x10 <sup>-6</sup> | _ | Fs <sub>INT</sub> | | Passband ripple (0.417x10 <sup>-3</sup> Fs <sub>INT</sub> to 0.417 Fs <sub>INT</sub> ; normalized to 0.417 Fs <sub>INT</sub> ) | _ | _ | 0.01 | dB | | Phase deviation @ 0.453x10 <sup>-3</sup> Fs <sub>INT</sub> | _ | 2.45 | _ | ٥ | | Filter settling time <sup>2</sup> | _ | 24.5x10 <sup>3</sup> /Fs <sub>INT</sub> | _ | S | <sup>1.</sup> Response scales with Fs<sub>INT</sub> (internal sample rate, based on MCLK). Specifications are normalized to Fs<sub>INT</sub> and are denormalized by multiplying by Fs<sub>INT</sub>. #### Table 3-9. HSINx to SDOUT with SRC-Enabled Datapath Characteristics Test conditions (unless specified otherwise): LRCK = Fs<sub>INT</sub> = Fs<sub>EXT</sub> = 48 kHz; MCLK = 12 MHz; HPF disabled; passband/stopband levels normalized to 20 Hz; entire path characteristics including AFE + ADC + SRC + serial port. | | Parameters 1,2 | Minimum | Typical | Maximum | Unit | |----------|-------------------------------------------------------------------------------------------------------------|---------|---------------------------------------------------------|------------------------|-------------------| | ADC | Passband –0.22-dB corner | _ | 0.390 | _ | Fs <sub>EXT</sub> | | notch | -3.0-dB corner | _ | 0.410 | _ | Fs <sub>EXT</sub> | | filter | Passband ripple (0.417x10 <sup>-3</sup> Fs <sub>EXT</sub> to 0.390 Fs <sub>EXT</sub> ; normalized to 20 Hz) | -0.30 | _ | 0.15 | dB | | enabled | Stopband rejection from 0.477 Fs <sub>EXT</sub> to 3 Fs <sub>EXT</sub> | 70 | _ | _ | dB | | | Square wave overshoot | _ | _ | 3.1 | dB | | | Group delay, bark-weighted average | _ | _ | 38.5/Fs <sub>EXT</sub> | S | | | Group delay Fs <sub>EXT</sub> ≤ 44.1 kHz | | 17.4/Fs <sub>INT</sub> + (13.2 ± 1.5)/Fs <sub>EXT</sub> | _ | S | | | Fs <sub>EXT</sub> ≥ 48 kHz) | - | $(12.4 \pm 0.5)/Fs_{INT} + (11.9 \pm 1)/Fs_{EXT}$ | _ | s | | | SRC-disabled group delay <sup>3</sup> | _ | (13.9±1)/Fs | _ | S | | ADC | Passband –0.22-dB corner | _ | 0.444 | _ | Fs <sub>EXT</sub> | | notch | -3.0-dB corner | - | 0.466 | _ | Fs <sub>EXT</sub> | | filter | Passband ripple (0.417x10 <sup>-3</sup> Fs <sub>EXT</sub> to 0.417 Fs <sub>EXT</sub> ; normalized to 20 Hz) | -0.30 | _ | 0.15 | dB | | disabled | Stopband rejection from 0.480 Fs <sub>EXT</sub> to 0.521 Fs <sub>EXT</sub> | 55 | _ | _ | dB | | | Stopband rejection from 0.521 Fs <sub>EXT</sub> to 0.640 Fs <sub>EXT</sub> | 14 | _ | _ | dB | | | Stopband rejection from 0.640 Fs <sub>EXT</sub> to 3 Fs <sub>EXT</sub> | 70 | _ | _ | dB | | | Square wave overshoot | _ | | 3.1 | dB | | | Group delay, bark-weighted average | _ | | 38.5/Fs <sub>EXT</sub> | s | | | Group delay $Fs_{EXT} \le 44.1 \text{ kHz}$ | | 17.4/Fs <sub>INT</sub> + (13.2 ± 1.5)/Fs <sub>EXT</sub> | _ | S | | | Fs <sub>EXT</sub> ≥ 48 kHz) | _ | $(12.4 \pm 0.5)/Fs_{INT} + (11.9 \pm 1)/Fs_{EXT}$ | _ | s | | | SRC disabled group delay <sup>3</sup> | _ | (13.9±1)/Fs | _ | s | <sup>1.</sup>Fs<sub>EXT</sub> is the external sample rate (LRCK/FSYNC frequency). Response scales with Fs<sub>EXT</sub>. #### Table 3-10. SDIN to HPOUTx with SRC-Enabled Datapath Characteristics Test conditions (unless specified otherwise): LRCK = $Fs_{INT}$ = $Fs_{EXT}$ = 48 kHz; MCLK = 12 MHz; HPF disabled; passband/stopband levels normalized to 0.417x10<sup>-3</sup> $Fs_{EXT}$ ; entire path characteristics including serial port + SRC + DAC + HPOUT. | Parameters 1 | Minimum | Typical | Maximum | Unit | |-------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------------------------------------------------|----------------------|-------------------| | Passband –0.2-dB corner | _ | 0.463 | _ | Fs <sub>EXT</sub> | | -3.0-dB corner | _ | 0.466 | _ | Fs <sub>EXT</sub> | | Passband ripple (0.417x10 <sup>-3</sup> Fs <sub>EXT</sub> to 0.417 Fs <sub>EXT</sub> ; normalized to 0.417x10 <sup>-3</sup> Fs <sub>EXT</sub> ) | -0.16 | _ | 0.02 | dB | | Response at 0.5 Fs <sub>EXT</sub> | _ | _ | -54.9 | dB | | Stopband rejection from 0.480 Fs <sub>EXT</sub> to 0.524 Fs <sub>EXT</sub> | 55 | _ | _ | dB | | Stopband rejection from 0.524 Fs <sub>EXT</sub> to 0.545 Fs <sub>EXT</sub> | 39 | _ | _ | dB | | Stopband rejection from 0.545 Fs <sub>EXT</sub> to 3 Fs <sub>EXT</sub> | 60 | _ | _ | dB | | Square wave overshoot | _ | _ | 3.1 | dB | | Group delay, bark-weighted average | _ | _ | 34/Fs <sub>EXT</sub> | s | | Group delay Fs <sub>EXT</sub> ≤ 48 kHz | _ | (15.8 ± 1.5)/Fs <sub>EXT</sub> + 10.3/Fs <sub>INT</sub> | _ | S | | $Fs_{EXT} \ge 88.2 \text{ kHz}$ | _ | $(20.1 \pm 1)/Fs_{EXT} + (11.6 \pm 0.5)/Fs_{INT}$ | _ | s | | SRC disabled group delay <sup>2</sup> | _ | (15±1)/Fs | _ | S | <sup>1.</sup>Fs<sub>EXT</sub> is the external sample rate (LRCK/FSYNC frequency). Response scales with Fs<sub>EXT</sub>. <sup>2.</sup> Required time for the magnitude of the DC component present at the output of the HPF to reach 5% of the applied DC signal. <sup>2.</sup> Measurements with HPF disabled require either differential configuration or single-ended configuration with -30 dBFS input signal. <sup>3.</sup> This value varies by up to 1 Fs. If SRC is disabled, Fs = Fs<sub>OUT</sub> = Fs<sub>IN</sub>. <sup>2.</sup> This value varies by up to 1 Fs. If SRC is disabled, Fs = Fs<sub>OUT</sub> = Fs<sub>IN</sub>. #### Table 3-11. Wind-Noise Digital Filter Characteristics Test conditions (unless specified otherwise): MCLK = 12 MHz; MCLK SRC SEL = 0; Fs<sub>INT</sub> = 48 kHz; ADC HPF disabled. | Parameters 1,2 | | Minimum | Typical | Maximum | Unit | |---------------------------------------------------------------|-----------------------------------------|---------|-----------------------|---------|------| | Passband –3.0-dB corner | ADC_WNF_CF = 000 | _ | 160 | _ | Hz | | | ADC_WNF_CF = 001 | _ | 180 | _ | Hz | | | ADC_WNF_CF = 010 | _ | 200 | _ | Hz | | | ADC_WNF_CF = 011 | _ | 220 | _ | Hz | | | ADC_WNF_CF = 100 | _ | 240 | _ | Hz | | | ADC_WNF_CF = 101 | _ | 260 | _ | Hz | | | ADC_WNF_CF = 110 | _ | 280 | _ | Hz | | | ADC_WNF_CF = 111 | _ | 300 | _ | Hz | | Passband –0.05-dB corner | ADC_WNF_CF = 000 | _ | 280 | _ | Hz | | | ADC_WNF_CF = 001 | _ | 315 | _ | Hz | | | ADC_WNF_CF = 010 | _ | 350 | _ | Hz | | | ADC_WNF_CF = 011 | _ | 385 | _ | Hz | | | ADC_WNF_CF = 100 | _ | 420 | _ | Hz | | | ADC_WNF_CF = 101 | _ | 455 | _ | Hz | | | ADC_WNF_CF = 110 | _ | 490 | _ | Hz | | | ADC_WNF_CF = 111 | _ | 525 | _ | Hz | | Passband ripple (-0.05-dB corner to 0.417 Fs <sub>INT</sub> ; | normalized to 0.417 Fs <sub>INT</sub> ) | _ | _ | 0.15 | dB | | Filter settling time | ADC_WNF_CF = 000 | _ | 731/Fs <sub>INT</sub> | _ | S | | | ADC_WNF_CF = 001 | _ | 650/Fs <sub>INT</sub> | _ | S | | | ADC_WNF_CF = 010 | _ | 585/Fs <sub>INT</sub> | _ | s | | | ADC_WNF_CF = 011 | _ | 532/Fs <sub>INT</sub> | _ | S | | | ADC_WNF_CF = 100 | _ | 487/Fs <sub>INT</sub> | _ | S | | | ADC_WNF_CF = 101 | _ | 450/Fs <sub>INT</sub> | _ | s | | | ADC_WNF_CF = 110 | _ | 418/Fs <sub>INT</sub> | | S | | | ADC_WNF_CF = 111 | _ | 390/Fs <sub>INT</sub> | _ | S | <sup>1.</sup> Responses are clock dependent and scale with $Fs_{INT}$ . The full-band response plot (Fig. 9-28) is normalized to $Fs_{INT}$ and is denormalized by multiplying the x-axis scale by Fs. Passband frequencies above the transition-band response plot (Fig. 9-29) are for a $Fs_{INT}$ of 48 kHz. Frequencies for other $Fs_{INT}$ values are determined by multiplying the x-axis scale shown in the transition band plot and passband frequencies above by a factor of $Fs_{INT}$ /48 kHz. <sup>2.</sup> Wind-noise HPF characteristics apply only if the given filter is enabled (ADC\_WNF\_EN = 1). Otherwise, the signal is unaffected by this block. #### Table 3-12. HSIN-to-Serial Data Out Characteristics Test conditions (unless specified otherwise): Fig. 2-1 and Fig. 2-2 show CS42L42 connections; input is a full-scale 1-kHz sine wave; GNDA = GNDL = GNDCP = 0 V; voltages are with respect to ground; parameters and can vary with VA; typical performance data taken with VL = VA = 1.8 V, VP = 3.6 V; min/max performance data taken with VA = 1.66–1.94 V; VL = 1.8 V, VP = 3.6 V; T<sub>A</sub> = +25°C; measurement bandwidth is 20 Hz–20 kHz; ASP\_LRCK = Fs = 48 kHz; MCLK = 12 MHz; SRC bypassed in data path; mixer attenuation and digital volume = 0 dB. ADC\_HPF\_EN = 1. Specifications valid for pseudodifferential and fully differential inputs. | | Parameter <sup>1</sup> | | Minimum | Typical | Maximum | Unit | |------------------------|---------------------------------------|-----------------------------|---------|---------|---------|--------| | Dynamic range 2 (defin | ned in Table 3-1) | A-weighted | 108 | 114 | _ | dB | | | | Unweighted | 105 | 111 | _ | dB | | THD+N 3 (defined in Ta | able 3-1) | Differential, -1-dBFS input | _ | -85 | -79 | dB | | | | Single-ended, -1-dBFS input | _ | -80 | -74 | dB | | Common-mode rejection | on <sup>4</sup> | | _ | 72 | _ | dB | | DC voltage on HSIN w | ith pin floating | | _ | 1.35 | _ | V | | Accuracy | Offset error (defined in Table 3-1) 5 | | | 127 | | LSB | | | Gain drift | | _ | ±100 | _ | ppm/°C | | Input | HP amp-to-analog input isolation | $R_L = 3 k\Omega$ | _ | 90 | _ | dB | | | | $R_L = 30 \Omega$ | _ | 83 | _ | dB | | | Full-scale signal input voltage 6 | | 1.5•VA | 1.57•VA | 1.64•VA | Vpp | | | Input impedance 7 | | 45 | 50 | _ | kΩ | | | Turn-on time 8 | ADC_SOFTRAMP_EN = 0 | _ | _ | 25 | ms | - 1. Parameters in this table are described in detail in Table 3-1. - (HSIN dynamic range test configuration (pseudodifferential). Input signal is –60 dB down from the corresponding full-scale voltage. - 3. ADC\_HPF\_EN must remain asserted for proper functionality. Failure to do so may cause clipping of the ADC digital output. - 4. HSIN CMRR test configuration - 5.SDOUT code with ADC HPF EN = 1 (see p. 159), ADC DIG BOOST = 0 (see p. 158). - 6.ADC full-scale input voltage is measured on between HSIN+ and HSIN-. This is for single-ended or pseudodifferential input signals. - 7. Measured between HSIN+ and HSIN-. - 8. Turn-on time is measured from the ADC\_PDN = 0 ACK signal to when data comes through the DAO port or SoundWire port. In most cases, enabling the SRC increases the turn-on time and may exceed the maximum value specified. #### Table 3-13. Serial Data In-to-HPOUTx Characteristics Test conditions (unless specified otherwise): Fig. 2-1 and Fig. 2-2 show CS42L42 connections; input test signal is a 24-bit full-scale 997-Hz sine wave with 1 LSB of triangular PDF dither applied; GNDA = GNDL = GNDCP = 0 V; voltages are with respect to ground; parameters can vary with VA; typical performance data taken with VL = VA = 1.8 V, VP = 3.6 V; min/max performance data taken with VA = 1.66–1.94 V; VL = 1.8 V, VP = 3.6 V; VCP Mode; $T_A = +25^{\circ}C$ ; measurement bandwidth is 20 Hz–20 kHz; ASP\_LRCK = $T_{SINT} = T_{SINT} T_{S$ | _ , | Parameter 1 | , - | | Minimum | Typical | Maximum | Unit | |----------------------------------------------------------------|-------------------------------------------|--------------------------|--------------------------|-----------|----------------|---------|-----------------| | $R_L = 3 \text{ k}\Omega$ | Dynamic range | 18-24 bit | A-weighted | 108 | 114 | _ | dB | | VP_CP Mode | (defined in Table 3-1) | | unweighted | 105 | 111 | _ | dB | | Stereo | THD+N <sup>2</sup> (defined in Table 3-1) | 18–24 bit | 0 dB | | -102 | _ | dB | | (Single-ended) | | (A-weighted) | -20 dB | _ | -83<br>40 | _ | dB | | | | 18–24 bit | –60 dB<br>0 dB | _ | _49<br>_90 | | dB<br>dB | | | | (unweighted) | -20 dB | _ | _83 | _ | dB | | | | , | -60 dB | _ | -51 | -48 | dB | | | | 16 bit | 0 dB | _ | -88 | -82 | dB | | | | (unweighted) | −20 dB<br>−60 dB | _ | -73 | _ | dB | | | Idle channel noise (A-weighted) | | -00 db | | -33<br>2.0 | _27<br> | dB | | | Full-scale output voltage <sup>3</sup> | | | 1.50•VA | 1.58•VA | 1.66•VA | μV | | R <sub>I</sub> = 30 Ω | Dynamic range (defined in Table 3-1) | 10 24 bit | A weighted | 1.50•VA | 1.56•VA | 1.00•VA | V <sub>PP</sub> | | VP_CP Mode | Dynamic range (defined in Table 3-1) | 10-24 DIL | A-weighted<br>unweighted | 105 | 114 | | dВ | | Stereo | THD+N <sup>2</sup> (defined in Table 3-1) | A-weighted | Pout = 10 mW | — | -101 | _ | dB | | (Single-ended) | Trib (14 = (defined in Table 5-1) | /-weighted | Pout = 31.25 mW | _ | _99 | _ | dB | | | | Unweighted | Pout = 10 mW | _ | -98 | _ | dB | | | | ] | Pout = 35 mW | _ | -75 | _ | dB | | | Full-scale output voltage 3 | | | 1.50•VA | 1.58•VA | 1.66•VA | V <sub>PP</sub> | | | Output power <sup>2</sup> | | | _ | 35.0 | _ | mW | | R <sub>L</sub> = 15 Ω | Dynamic range (defined in Table 3-1) | 18–24 bit | A-weighted | 102 | 108 | _ | dB | | VCP Mode | , | | unweighted | 99 | 105 | _ | dB | | (FULL_SCALE_ | THD+N <sup>2</sup> (defined in Table 3-1) | | A-weighted, | _ | -95 | -69 | dB | | VOL = 1 [-6 dB])<br>Stereo | | | Pout = 17.3 mW | | | | | | (Single-ended) | Full-scale output voltage <sup>3</sup> | | | 0.71•VA | 0.79•VA | 0.86•VA | V <sub>PP</sub> | | | Output power <sup>2</sup> | | | _ | 17.3 | _ | mW | | $R_L = 15 \Omega$<br>$VP\_CP Mode$<br>Stereo<br>(Single-ended) | Dynamic range | 18–24 bit | A-weighted<br>unweighted | 102<br>99 | 108<br>105 | _ | dB<br>dB | | $R_L = 3 \text{ k}\Omega$ | Dynamic range | 2.0 V <sub>rms</sub> FS | A-weighted | _ | 118 | _ | dB | | VP CP Mode | (defined in Table 3-1) | 2.0 VIIIS I C | unweighted | _ | 115 | _ | dB | | Mono (Differential) | | $1.0 V_{rms} FS$ | A-weighted | _ | 112 | _ | dB | | | | | unweighted | _ | 110 | _ | dB | | | THD+N <sup>2</sup> (defined in Table 3-1) | 2.0 V <sub>rms</sub> FS | A-weighted | _ | -105 | _ | dB | | | | 1.0 V <sub>rms</sub> FS | unweighted<br>A-weighted | _ | -103<br>-103 | _ | dB<br>dB | | | | 1.0 V <sub>rms</sub> 1.3 | unweighted | _ | -103<br>-102 | | dB | | | Idle channel noise (A-weighted) | | 9 | | 2.0 | _ | μV | | | Full-scale output voltage <sup>4</sup> | | | 3•VA | 3.16•VA | 3.32•VA | V <sub>PP</sub> | | R <sub>I</sub> = 30 Ω | Dynamic range (defined in Table 3-1) | | A-weighted | 108 | 112.7 | _ | dB | | VP CP Mode | Jynamic range (demice in rabio e 1) | | unweighted | 105 | 110.2 | _ | dB | | (FULL_SCALE_ | THD+N <sup>2</sup> (defined in Table 3-1) | | A-weighted | _ | -106 | _ | dB | | VOL = 1 [–6 dB])<br>Mono (Differential) | | | unweighted | _ | -103 | -69 | dB | | Mono (Dillerential) | Full-scale output voltage <sup>4</sup> | | | 1.50•VA | 1.58•VA | 1.66•VA | $V_{PP}$ | | | Output power <sup>2</sup> | | | _ | 31.0 | _ | mW | | $R_L = 15 \Omega$<br>VCP Mode | Dynamic range (defined in Table 3-1) | 18–24 bit | A-weighted<br>unweighted | 102<br>99 | 109.8<br>107.4 | _ | dB<br>dB | | (FULL_SCALE_ | THD+N <sup>2</sup> (defined in Table 3-1) | | A-weighted | _ | -101 | _ | dB | | VOL = 1 [–6 dB])<br>Mono (Differential) | | | unweighted | | -100 | -69 | dB | | Iniono (Dilierendal) | Full-scale output voltage <sup>4</sup> | | | 1.5•VA | 1.58•VA | 1.66•VA | V <sub>PP</sub> | | | Output power <sup>2</sup> | | - | _ | 31.0 | _ | mW | | $R_L = 15 \Omega$ | Dynamic range | 18–24 bit | A-weighted | 102 | 108 | _ | dB | | VP_CP Mode<br>Mono (Differential) | | | unweighted | 99 | 105 | _ | dB | | mono (Dinerential) | | | | | | | | #### Table 3-13. Serial Data In-to-HPOUTx Characteristics (Cont.) Test conditions (unless specified otherwise): Fig. 2-1 and Fig. 2-2 show CS42L42 connections; input test signal is a 24-bit full-scale 997-Hz sine wave with 1 LSB of triangular PDF dither applied; GNDA = GNDL = GNDCP = 0 V; voltages are with respect to ground; parameters can vary with VA; typical performance data taken with VL = VA = 1.8 V, VP = 3.6 V; min/max performance data taken with VA = 1.66–1.94 V; VL = 1.8 V, VP = 3.6 V; VCP Mode; $T_A = +25^{\circ}C$ ; measurement bandwidth is 20 Hz–20 kHz; ASP\_LRCK = $T_{SINT} = T_{SINT} T_{S$ | | Parameter <sup>1</sup> | | Minimum | Typical | Maximum | Unit | |------------------|-------------------------------------------------------------------------|--------------------|---------|---------|---------|------| | Other | Interchannel isolation <sup>3</sup> (3 kΩ) | 217 Hz | _ | 90 | _ | dB | | characteristics | | 1 kHz | _ | 90 | | dB | | (Table 3-1 gives | | 20 kHz | _ | 80 | _ | dB | | parameter | Interchannel isolation <sup>3</sup> (30 Ω) | 217 Hz | _ | 90 | _ | dB | | definitions.) | | 1 kHz | _ | 90 | | dB | | | | 20 kHz | _ | 70 | _ | dB | | | Output offset voltage: mute <sup>3,5</sup> (ANA_MUTE_x = 1, see p. 160) | HPOUTx | _ | ±0.5 | ±1.0 | mV | | | Output offset voltage 3,5 | HPOUTx | _ | ±0.5 | ±2.5 | mV | | | Load resistance (R <sub>L</sub> ) | Normal operation 3 | 15 | _ | _ | Ω | | | Load capacitance (C <sub>L</sub> ) <sup>3,6</sup> | HPOUT_LOAD = 0 | l | _ | 1 | nF | | | | HPOUT_LOAD = 1 | _ | _ | 10 | nF | | | Turn-on time <sup>7</sup> SLO | W_START_EN = 000 | _ | _ | 25 | ms | - 1. One LSB of triangular PDF dither is added to data. - 2.Because VCP settings lower than VA reduce the HP amplifier headroom, the specified THD+N performance at full-scale output voltage and power may not be achieved. - 3.HP single-ended output test configuration. Symbolized component values are specified in the test conditions above. 4.HP differential output test configuration. Symbolized component values are specified in the test conditions above. - 5.Assumes no external impedance on HSx/HSx\_REF. External impedance on HSx/HSx\_REF affects the offset and step deviation. See Section 4.4.1. 6.Amplifier is guaranteed to be stable with either headphone load setting. - 7. Turn-on time is measured from when the HP\_PDN = 0 ACK signal is received to when the signal appears on the HP output. In most cases, enabling the SRC increases the turn-on time and may exceed the maximum specified value. #### **Table 3-14. HSBIAS Characteristics** Test conditions (unless specified otherwise): Fig. 2-1 and Fig. 2-2 show CS42L42 connections; GNDHS = GNDA = GNDL = GNDCP = 0 V; voltages are with respect to ground; parameters can vary with VA and VP; typical performance data taken with VL = VA = 1.8 V, VP = 3.6 V; min/max performance data taken with VA = 1.66–1.94 V, VL = 1.8 V, VP = 3.0–5.25; $I_{OUT}$ = 500 $\mu$ A; $I_{A}$ = +25°C; PDN\_ALL = 0, HSBIAS\_CTRL = 2.7-V Mode. | | Para | ameters <sup>1</sup> | Minimum | Typical | Maximum | Unit | |---------------------------------------------------|--------------|-------------------------------------------------|---------|---------|---------|-------| | Output voltage <sup>2</sup> | PDN_ALL | DETECT_MODE HSBIAS_CTRL | | | | | | | 0/1 | 0x (inactive/short detect only) 10 (2.0-V Mode) | 1.40 | 1.86 | 2.15 | V | | | 0/1 | 01 (short detect only) 11 (2.7-V Mode) | 1.75 | 2.30 | 2.70 | V | | | 0 | 11 (Normal Mode) 10 (2.0-V Mode) [3] | 1.80 | 2.00 | 2.10 | V | | | 0 | 00/11 (inactive/Normal Mode) 11 (2.7-V Mode) | 2.61 | 2.75 | 2.86 | V | | DC output current, I <sub>OUT2</sub> <sup>4</sup> | | HSBIAS_CTRL = 10 (2.0-V Mode) | _ | 0.91 | _ | mA | | | | HSBIAS_CTRL = 11 (2.7-V Mode) | _ | 1.2 | _ | mA | | Integrated output noise (measu | ured at HSx) | f = 100 Hz–20 kHz | _ | _ | 4 | μVrms | | Output resistance, R <sub>OUTx</sub> | | | 2.19 | 2.21 | 2.23 | kΩ | | Output resistance temperature | variation | –40°C to +85°C | | ±3 | | % | | Current-sense trip point | | HSBIAS_SENSE_TRIP = 000 | _ | 12 | _ | μA | | | | HSBIAS_SENSE_TRIP = 001 | _ | 23 | _ | μA | | | | HSBIAS_SENSE_TRIP = 010 | _ | 41 | _ | μA | | | | HSBIAS_SENSE_TRIP = 011 | _ | 52 | _ | μA | | | | HSBIAS_SENSE_TRIP = 100 | _ | 64 | _ | μA | | | | HSBIAS_SENSE_TRIP = 101 | | 75 | _ | μA | | | | HSBIAS_SENSE_TRIP = 110 | | 93 | - | μA | | | | HSBIAS_SENSE_TRIP = 111 | _ | 104 | | μA | | Capacitive load | | | _ | _ | 100 | μF | <sup>1.</sup>If HSBIAS\_CTRL = 01, the internal HSBIAS node is to be shorted to ground. Output is pulled down to ground via an internal resistance of R<sub>OUT</sub> to the HS3/HS4 pins, which is, in turn, connected internally or externally to ground (per Fig. 2-1). <sup>2.</sup> The output voltage is the unloaded, open-circuit voltage present at the HSx pin selected as HSBIAS output. <sup>3.</sup>No audio is allowed on HSIN/HSx if DETECT\_MODE = 11 and HSBIAS\_CTRL = 10. <sup>4.</sup> Specifies use limits for the normal operation and HSIN short conditions. #### Table 3-15. Switching Specifications—HSBIAS Test conditions (unless specified otherwise): Fig. 2-1 shows CS42L42 connections; GNDA = GNDP = GNDCP = GNDD = 0 V; voltages are with respect to ground; parameters can vary with VA and VP; typical performance data taken with VL = VA = VCP = 1.8 V, VP = 3.6 V; min/max performance data taken with VA = 1.66–1.94 V; VL = VCP = 1.8 V; VP = 3.0–5.25; I<sub>OUT</sub> = 500 μA (not valid for fall time); T<sub>A</sub> = +25°C; PDN\_ALL = 0, DETECT\_MODE = Normal Mode. | | Parameters <sup>1</sup> | | Symbol | Minimum | Typical | Maximum | Unit | |--------------------------------------|--------------------------|-----------------------------------------------------|-------------------------|---------|---------|---------|------| | HS bias rise time 2, 3 | | HSBIAS_RAMP = 00 | t <sub>mb-rise</sub> | _ | 0.002 | _ | ms | | | | HSBIAS_RAMP = 01 | | _ | 10 | _ | ms | | | | HSBIAS_RAMP = 10 | | _ | 25 | _ | ms | | | | HSBIAS_RAMP = 11 | | _ | 50 | _ | ms | | HS bias fall time 4 | | HSBIAS_RAMP = 00 | t <sub>mb-fall</sub> | _ | 3 | _ | ms | | | | HSBIAS_RAMP = 01 | | _ | 15 | _ | ms | | | | HSBIAS_RAMP = 10 | | _ | 37 | | ms | | | | HSBIAS_RAMP = 11 | | _ | 75 | _ | ms | | HS bias transition time <sup>5</sup> | Condition 1 <sup>6</sup> | 1.8 V → Hi-Z | t <sub>mb-tran</sub> — | | 92 | _ | μs | | | | $2.0 \text{ V} \rightarrow \text{Hi-Z}$ | | _ | 92 | _ | μs | | | | $2.3 \text{ V} \rightarrow \text{Hi-Z}$ | | _ | 93 | _ | μs | | | Condition 2 <sup>7</sup> | $2.7 \text{ V} \rightarrow 2.3 \text{ V}$ | t <sub>mb-tran</sub> | _ | 23 | _ | μs | | | | $1.8 \text{ V} \rightarrow 2.3 \text{ V}$ | | _ | 20 | _ | μs | | | | $2.0 \text{ V} \rightarrow 2.3 \text{ V}$ | | _ | 18 | _ | μs | | | | $2.0 \text{ V} \rightarrow 2.7 \text{ V}$ | | _ | 1 | _ | μs | | | Condition 3 <sup>8</sup> | Hi-Z → 1.8 V | t <sub>mb-tran</sub> | _ | 96 | _ | μs | | | | $Hi-Z \rightarrow 2.3 \text{ V}$ | | _ | 96 | _ | μs | | | Condition 4 8,9 | | t <sub>mb-tran</sub> | _ | 10 | _ | ms | | | Condition 5 10 | Hi-Z → 2.7 V, HSBIAS_RAMP = 01 | t <sub>mb-tran</sub> | _ | 183 | _ | μs | | | | $Hi-Z \rightarrow 2.7 \text{ V, HSBIAS\_RAMP} = 10$ | | _ | 198 | _ | μs | | | | $Hi-Z \rightarrow 2.7 \text{ V, HSBIAS}_RAMP = 11$ | | _ | 220 | _ | μs | | HS bias droop | | Condition 2 <sup>7</sup> | $V_{\text{mb-droop}}$ | _ | _ | 500 | mV | | HS bias startup-to-stable time 11 | | HSBIAS_RAMP = 00 | t <sub>mb-startup</sub> | _ | 0.01 | _ | ms | | | | HSBIAS_RAMP = 01 | | _ | 14 | _ | ms | | | | HSBIAS_RAMP = 10 | | _ | 36 | _ | ms | | | | HSBIAS_RAMP = 11 | | _ | 65 | _ | ms | 1. HSBIAS startup timing example - Weak Ground 2.HSBIAS rise time is measured from 10% to 90% of the final output voltage. Transitions are specified with an HSBIAS\_FILT capacitance of 4.7 μF. - 3. Under the specified configuration, the HSBIAS transitions with an exponential rise time. - 4.HS bias fall time is the time associated with HSBIAS falling from 95% to 5% of the programmed typical output voltage. If transitioning to Hi-Z, the output does not enter Hi-Z state until the internal digital counter completes, as determined by the HSBIAS RAMP setting. 5.HS bias transitions between the GND mode and ON modes occur with no transition state. <sup>(</sup>output voltage is at 95% of its programmed typical value). #### Table 3-16. DC Characteristics Test conditions (unless specified otherwise): Fig. 2-1 and Fig. 2-2 show CS42L42 connections; GNDA = GNDL = GNDCP = 0 V; voltages are with respect to ground; VL = VCP = VA = 1.8 V, VP = 3.6 V; T<sub>A</sub> = +25°C. | | Parameters | Minimum | Typical | Maximum | Unit | |-------------------------|----------------------------------------------------------------------------------------------------------------------|---------|---------|---------|------| | VCP_FILT (No load | VP_CP Mode (ADPTPWR = 001) +VCP_FILT | _ | 2.6 | _ | V | | connected to HPOUTx.) | -VCP_FILT | _ | -2.6 | _ | V | | | VCP Mode (ADPTPWR = 010) +VCP_FILT | | VCP | _ | V | | | -VCP_FILT | _ | -VCP | _ | V | | | VCP/2 Mode (ADPTPWR = 011) +VCP_FILT | | VCP/2 | _ | V | | | -VCP_FILT | - | -VCP/2 | _ | V | | | VCP/3 Mode (ADPTPWR = 100) +VCP_FILT | | VCP/3 | _ | V | | | -VCP_FILT | _ | -VCP/3 | _ | V | | HS3/HS4 ground switch r | resistance (Typical values have ±25% tolerance.) | _ | 0.5 | _ | Ω | | HS_CLAMPx depletion F | ET ground switch resistance | _ | 1 | _ | Ω | | Closed-loop external | External switch allowable ON-resistance (R <sub>ON</sub> ) <sup>1</sup> | _ | _ | 1 | Ω | | switch configuration | External switch ON-resistance flatness over SW1, SW2 R <sub>ON</sub> flatness | _ | _ | 0.075 | Ω | | | common-mode voltage appearing at switch <sup>1</sup> SW3, SW4 R <sub>ON</sub> flatness | _ | _ | 0.02 | Ω | | | External switch + PCB stray capacitance (C <sub>ON</sub> + C <sub>OFF</sub> + PCB <sub>STRAY</sub> – C) <sup>1</sup> | _ | 100 | _ | pF | | Other DC filter | FILT+ voltage | _ | VA | _ | V | | | HP output current limiter on threshold. See Section 4.6.4. <sup>2</sup> | 80 | 115 | 160 | mA | | | VD_FILT and VL power-on reset threshold (V <sub>POR</sub> ) Up | _ | 0.777 | _ | V | | | Down | _ | 0.628 | _ | V | | HPOUT pull-down | HPOUT_PULLDOWN = 0000-0111, 1100 | _ | 0.9 | _ | kΩ | | resistance 3,4 | HPOUT_PULLDOWN = 1001 | I . | 9.3 | _ | kΩ | | | HPOUT_PULLDOWN = 1010 | | 5.8 | _ | kΩ | | Headset-Detect Compara | | | 0.65 | _ | V | | (Step size = 0.05 V) | HSDET_COMP1_LVL = 0111 | | 1.0 | _ | V | | | HSDET_COMP1_LVL = 1111 | | 1.4 | _ | V | | Headset-Detect Compara | | | 1.65 | _ | V | | (Step size = 0.05 V) | HSDET_COMP2_LVL = 0111 | | 2.0 | _ | V | | | HSDET_COMP2_LVL = 1111 | _ | 2.4 | _ | V | <sup>1.</sup> External switches. See Section 4.4.2 for additional details. - 2. The HP output current limiter threshold spec is valid only while the Class H rails are in VCP Mode. - 3. Typical values have ±20% tolerance. - 4. Clamp is disabled (HPOUT CLAMP = 1) and channel is powered down (HPOUT PDN = 1). #### Table 3-17. Power-Supply Rejection Ratio (PSRR) Characteristics Test conditions (unless specified otherwise): Fig. 2-1 and Fig. 2-2 show CS42L42 connections; input test signal held low (all zero data); GNDA = GNDL = GNDCP = 0 V; voltages are with respect to ground; VL = VA = 1.8 V, VP = 3.6 V; T<sub>A</sub> = +25°C. | Parameters <sup>1</sup> | | Minimum | Typical | Maximum | Unit | |-----------------------------------------------------------------|--------|---------|---------|---------|------| | HSIN | 217 Hz | | 88 | _ | dB | | PSRR with 100-mVpp signal AC-coupled to VP supply | 1 kHz | _ | 83 | _ | dB | | | 20 kHz | _ | 73 | _ | dB | | HSIN | 217 Hz | _ | 70 | _ | dB | | PSRR with 100-mVpp signal AC-coupled to VA supply | 1 kHz | _ | 70 | _ | dB | | | 20 kHz | _ | 55 | _ | dB | | HPOUTx (-6-dB analog gain) | 217 Hz | _ | 75 | _ | dB | | PSRR with 100-mVpp signal AC coupled to VA supply <sup>2</sup> | 1 kHz | _ | 75 | _ | dB | | | 20 kHz | _ | 70 | _ | dB | | HPOUTx (-6-dB analog gain) | 217 Hz | | 85 | | dB | | PSRR with 100-mVpp signal AC-coupled to VCP supply <sup>2</sup> | 1 kHz | _ | 85 | _ | dB | | | 20 kHz | _ | 65 | _ | dB | | HPOUTx (0-dB analog gain) | 217 Hz | _ | 80 | _ | dB | | PSRR with 100-mVpp signal AC coupled to VP supply | 1 kHz | _ | 80 | _ | dB | | | 20 kHz | _ | 60 | _ | dB | #### Table 3-17. Power-Supply Rejection Ratio (PSRR) Characteristics (Cont.) Test conditions (unless specified otherwise): Fig. 2-1 and Fig. 2-2 show CS42L42 connections; input test signal held low (all zero data); GNDA = GNDL = GNDCP = 0 V; voltages are with respect to ground; VL = VA = 1.8 V, VP = 3.6 V; T<sub>A</sub> = +25°C. | Parameters 1 | | Minimum | Typical | Maximum | Unit | |----------------------------------------------------------------------|--------|---------|---------|---------|------| | HSBIAS (HSBIAS = 2.7-V mode, I <sub>OUT</sub> = 500 μA) | 217 Hz | _ | 105 | _ | dB | | PSRR with 100-mVpp signal AC coupled to VA supply 3,4 | 1 kHz | _ | 100 | _ | dB | | | 20 kHz | _ | 83 | _ | dB | | HSBIAS (HSBIAS = 2.7-V mode, I <sub>OUT</sub> = 500 μA) | 217 Hz | _ | 108 | _ | dB | | PSRR with 1-Vpp signal AC coupled to VP supply 4 | 1 kHz | _ | 95 | _ | dB | | | 20 kHz | _ | 70 | | dB | | HSBIAS (Normal Mode, HSBIAS = 2.0-V mode, I <sub>OUT</sub> = 500 μA) | 217 Hz | _ | 75 | _ | dB | | PSRR with 100-mVpp signal AC coupled to VA supply 3,4 | 1 kHz | _ | 70 | _ | dB | | | 20 kHz | _ | 55 | _ | dB | | HSBIAS (Normal Mode, HSBIAS = 2.0-V mode, I <sub>OUT</sub> = 500 μA) | 217 Hz | _ | 75 | _ | dB | | PSRR with 100-mVpp signal AC coupled to VP supply 4 | 1 kHz | — | 70 | _ | dB | | | 20 kHz | _ | 55 | _ | dB | 1.PSRR test configuration: Typical PSRR can vary by approximately 6 dB below the indicated values. - 2.No load connected to any analog outputs. - 3. The accurate reference, which sets the HSBIAS output voltage, is powered from VA. - 4.If HS\_CLAMP1/2 are connected to HS3/4, PSRR is reduced by 6 dB. #### **Table 3-18. Power Consumption** Test conditions (unless specified otherwise): Fig. 2-1 shows CS42L42 connections; GNDA = GNDL = GNDCP = 0 V; voltages are with respect to ground; performance data taken with VA = VCP = VL = 1.8 V; $\overline{DIGLDO\_PDN}$ is deasserted; VP = 3.6 V; $T_A$ = +25°C; ASP\_LRCK = 48-kHz Mode; $F_{SINT}$ = 48 kHz; SCLK = 12 MHz, MCLK\_SRC\_SEL = 0;mixer attenuation = 0 dB; $F_{ULL}$ \_SCALE\_VOL = 1 (-6 dB) for HPOUTx, $T_{UL}$ \_SENSE\_CTRL = 11, all other fields are set to defaults; no signal on any input; control port inactive; input clock/data are held low when not required; test load is $R_L$ = 30 $\Omega$ and $R_L$ = 1 nF for HPOUTx; measured values include currents consumed by the codec and do not include current delivered to external loads unless specified otherwise (e.g., HPOUTx); see Fig. 3-1. | | | Use Cases | ClassH | Ty | oical Cu | ırrent (µ | JA) | Total Power | |---|---|------------------------------------------------------------------------------------|---------|-----------------|------------------|-----------------|-----------------|-------------| | | | Use Cases | Mode | i <sub>VA</sub> | i <sub>VCP</sub> | i <sub>VL</sub> | i <sub>VP</sub> | (µW) | | 1 | Α | Off 1 | | 0 | 0 | 0 | 3.1 | 11.16 | | 2 | Α | Standby <sup>2,3</sup> Depletion FETs of | n — | 0 | 0 | 0 | 20 | 72.0 | | | В | S0 Detect and tip sense active, Depletion FETs of | ff — | 0 | 0 | 0 | 28 | 100.8 | | 3 | Α | Standby (RCO Mode) 4,5 Depletion FETs of | n — | 0 | 0 | 343 | 31 | 729 | | | В | S0 Detect and tip sense active, Depletion FETs of | ff — | 0 | 0 | 343 | 37 | 751 | | 4 | Α | Record | | 1483 | 0 | 663 | 58 | 4072 | | 5 | Α | Playback Stereo HPOUT (no signal, HPOUT_LOAD = | ) VCP/3 | 1413 | 1204 | 858 | 58 | 6464 | | | В | Stereo HPOUT (0.1 mW, HPOUT_LOAD = | ) VCP/3 | 1441 | 2336 | 965 | 58 | 8744 | | 6 | Α | S/PDIF Tx (SCLK = 12.288 MHz, 48-kHz data rate, 24-bit, no S/PDIF transmitter load | 6 — | 0 | 0 | 418 | 26 | 846 | | 7 | Α | Voice call Headset (HSIN, HSBIAS_CTRL = 1 | )) — | 3032 | 1200 | 1569 | 270 | 11414 | | | В | Voice call (SoundWire) Headset (HSIN, HSBIAS_CTRL = 1 | ) — | 3032 | 1200 | 1815 | 270 | 11857 | - 1.Off configuration: Clock/data lines held low; RESET = LOW; VA = VL = VCP = 0 V; VP = 3.6 V. - 2. Standby configuration: Clock/data lines held low; VA = VL = VCP = 0 V; VP = 3.6 V; M\_MIC\_WAKE = 0, M\_HP\_WAKE = 0 (unmasked). - 3.SCLK\_PRESENT = 1. - 4.SCLK PRESENT = 0 (RCO clocking). - 5.Standby configuration (RCO clocking): Clock/data lines held low; VA = 0 V; VL = 1.8 V, VCP = 0 V, VP = 3.6 V; M\_MIC\_WAKE = 0, M\_HP\_WAKE = 0 (unmasked). - 6.SCLK = 12.288 MHz, PLL off, SPDIF\_CLK\_DIV = 001 (divide factor = 2); data lines held low. **Note:** The current draw on the VA, VCP, and VL power supply pins is derived from the measured voltage drop across a 10- $\Omega$ series resistor between the associated supply source and each voltage supply pin. Given the larger currents that are possible on the VP supply, an ammeter is used for the measurement. Figure 3-1. Power Consumption Test Configuration Table 3-19. Register Field Settings | | | | Register Fields and Settin | | | | | | | ings | | | | | | | | |---|-------------|---------|--------------------------------------------------------|-------------|--------------|---------|-----------|--------|--------|--------------|-----------|-----------------|---------------|------------------|---------------|------------------|-----------------------| | 1 | Jse<br>ises | PDN_ALL | ASP_DAO_PDN | ASP_DAI_PDN | ASP_DAI1_PDN | ADC_PDN | MIXER_PDN | EQ_PDN | HP_PDN | SPDIF_TX_PDN | PLL_START | RING_SENSE_PDNB | DETECT_MODE 1 | TIP_SENSE_CTRL 1 | HSBIAS_CTRL 1 | HS_CLAMP_DISABLE | Class H Mode<br>p. 45 | | 1 | Α | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 00 | 00 | 01 | _ | _ | | 2 | Α | 1 | _ | _ | _ | _ | _ | _ | _ | 1 | 0 | _ | 01 | 01 | 10 | 0 | _ | | | В | 1 | | _ | _ | — | _ | _ | _ | 1 | 0 | — | 01 | 01 | 10 | 1 | _ | | 3 | Α | 1 | _ | _ | _ | _ | _ | _ | _ | 1 | 0 | _ | 01 | 01 | 10 | 0 | _ | | | В | 1 | _ | _ | _ | — | _ | _ | _ | 1 | 0 | _ | 01 | 01 | 10 | 1 | _ | | 4 | Α | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 00 | 00 | 00 | 0 | _ | | 5 | Α | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 01 | 00 | 10 | 1 | VCP/3 | | | В | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 01 | 00 | 10 | 1 | VCP/3 | | 6 | Α | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 00 | 00 | 00 | 1 | _ | | 7 | Α | | Individual power downs. See definitions in Table 3-18. | | | | | | _ | | | | | | | | | <sup>1.</sup>LATCH\_TO\_VP must be set for the following settings to take effect: TIP\_ SENSE\_CTRL, DETECT\_MODE, HS\_CLAMP\_DISABLE, HSBIAS\_CTRL. #### **Table 3-20. S0 Button Detect Characteristics** Test conditions (unless specified otherwise): Fig. 2-1 shows CS42L42 connections; GNDA = GNDL = GNDCP = 0 V; voltages are with respect to ground; parameters can vary with VA and VP; typical performance data taken with VL = VA = 1.8 V, VP = 3.6 V; min/max performance data taken with VA = 1.66–1.94 V, VL = 1.8 V, VP = 3.0–5.25 V; T<sub>A</sub> = +25°C. | | Parameters | Minimum | Typical | Maximum | Unit | |-----------------|--------------------------------------------|---------|----------------|---------|------| | HS DC-detection | Short-detect threshold (S0 button) | 100 | 150 | 200 | mV | | parameters | Total group delay | _ | 5 | _ | ms | | | HS DC detect threshold <sup>1</sup> | _ | (M+1) x 1.5625 | _ | % | | | DC level detect power-up time <sup>2</sup> | _ | 11 | _ | ms | <sup>1.</sup> The variable M refers to the decimal representation of the HS DETECT LEVEL setting (see p. 156). #### Table 3-21. Switching Specifications—SoundWire Port Test conditions (unless specified otherwise): GND = 0 V; SWIRE\_SEL pin = VL; voltages are with respect to ground; VD\_FILT = 1.2 V; VA = 1.8 V; VP = 3.6 V; TA = $\pm 25^{\circ}$ C; logic 0 = ground, logic 1 = VL; input timings are measured at V<sub>IL</sub> and V<sub>IH</sub> thresholds; output timings are measured at V<sub>OL</sub> and V<sub>OH</sub> thresholds for VL logic (as shown in Table 3-25). | | Paran | neter | Symbol | Minimum | Maximum | Unit | |----------|---------------------------------------|--------------------------------------------|------------------------------|-------------|-------------|------| | VL = 1.2 | SWIRE_CLK frequency | Small data bus (10- to 60-pF capacitance) | F <sub>swsclk</sub> | _ | 12.3 | MHz | | | | Large data bus (10- to 100-pF capacitance) | | <u> </u> | 11.0 | MHz | | | Input clock slew time | Small data bus | | 2.0 | 5.0 | ns | | | | Large data bus | _ | 2.0 | 6.0 | ns | | | Data output slew time 1 | | T <sub>SLEW</sub> | 2.0 | _ | ns | | | Data driver disable time <sup>2</sup> | | T <sub>DZ</sub> | <del></del> | 5.0 | ns | | | Delay from clock to active state | | T <sub>ZD</sub> | 8.1 | _ | ns | | | Time for data output valid | Small data bus (10- to 60-pF capacitance) | T <sub>OV_DATA</sub> | _ | 27.9 | ns | | | | Large data bus (10- to 100-pF capacitance) | _ | _ | 29.0 | ns | | | Data output hold time | | T <sub>OH_DATA</sub> | 6.7 | _ | ns | | | Data input minimum setup time 2 | 2 | T <sub>ISETUP_MIN_DATA</sub> | | 0.0 | ns | | | Data input minimum hold time | | T <sub>IHOLD_MIN_DATA</sub> | _ | 4.0 | ns | | | Clock input duty cycle | | _ | 45 | 55 | % | | | VL logic (SWIRE_CLK and | High-level output voltage | | 0.8*VL | _ | V | | | SWIRE_SD pins) | Low-level output voltage | OL | _ | 0.2*VL | V | | | | High-level input voltage | | 0.65*VL | <del></del> | V | | | | Low-level input voltage | | _ | 0.35*VL | V | | | | Input voltage threshold (rising edge) | | 0.5*VL | 0.65*VL | V | | | | Input voltage threshold (falling edge) | | 0.35*VL | 0.5*VL | V | | | | Hysteresis voltage | $V_{HYST}$ | 0.1*VL | _ | V | <sup>2.</sup> Time for the DC level detector circuits to completely power up after PDN\_MIC\_LVL\_DETECT transitions from 1 to 0 (see p. 155). #### Table 3-21. Switching Specifications—SoundWire Port (Cont.) Test conditions (unless specified otherwise): GND = 0 V; SWIRE\_SEL pin = VL; voltages are with respect to ground; VD\_FILT = 1.2 V; VA = 1.8 V; VP = 3.6 V; TA = $\pm 25^{\circ}$ C; logic 0 = ground, logic 1 = VL; input timings are measured at V<sub>IL</sub> and V<sub>IH</sub> thresholds; output timings are measured at V<sub>OL</sub> and V<sub>OH</sub> thresholds for VL logic (as shown in Table 3-25). | | Paran | neter | Symbol | Minimum | Maximum | Unit | |----------|----------------------------------------|-------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------|-------------------|------------| | VL = 1.8 | SWIRE_CLK frequency | Small data bus (10- to 60-pF capacitance)<br>Large data bus (10- to 100-pF capacitance) | | _ | 12.7<br>10.1 | MHz<br>MHz | | | Input clock slew time | Small data bus<br>Large data bus | | 2.0<br>2.0 | 5.4<br>9.0 | ns<br>ns | | | Data output slew time 1 | | T <sub>SLEW</sub> | 2.0 | _ | ns | | | Data driver disable time <sup>2</sup> | | T <sub>DZ</sub> | _ | 4.0 | ns | | | Delay from clock to active state | | T <sub>ZD</sub> | 7.9 | _ | ns | | | Time for data output valid | Small data bus (10- to 60-pF capacitance)<br>Large data bus (10- to 100-pF capacitance) | | _ | 27.6<br>31.6 | ns<br>ns | | | Data output hold time | | T <sub>OH_DATA</sub> | 6.7 | _ | ns | | | Data input minimum setup time 2 | 2 | TISETUP_MIN_DATA | _ | 0.0 | ns | | | Data input minimum hold time | | T <sub>IHOLD_MIN_DATA</sub> | _ | 4.0 | ns | | | Clock input duty cycle | | _ | 45 | 55 | % | | | VL logic (SWIRE_CLK and SWIRE SD pins) | High-level output voltage<br>Low-level output voltage | | 0.8*VL | <br>0.2*VL | V | | | OWNICE_OD pins) | High-level input voltage | | 0.65*VL | - U.Z VL | v | | | | Low-level input voltage | $V_{IL}$ | _ | 0.35*VL | V | | | | Input voltage threshold (rising edge) Input voltage threshold (falling edge) Hysteresis voltage | V <sub>TN</sub> | 0.5*VL<br>0.35*VL<br>0.1*VL | 0.65*VL<br>0.5*VL | V<br>V | | 1 | | nysteresis voitage | V <sub>HYST</sub> | U.I VL | _ | V | <sup>1.</sup>Slew time for positive or negative clock/data edge on clock/data output between 0.2 and 0.8 VL. #### Table 3-22. Digital Audio Interface Timing Characteristics Test conditions (unless specified otherwise): GNDA = GNDL = GNDCP = 0 V; all voltages with respect to ground; values are for both VL = 1.2 and 1.8 V; inputs: Logic 0 = GNDL = 0 V, Logic 1 = VL; T<sub>A</sub> = +25°C; C<sub>LOAD</sub> = 30 pF (for VL = 1.2 V) and 60 pF (for VL = 1.8 V); input timings are measured at V<sub>IL</sub> and V<sub>IH</sub> thresholds; output timings are measured at V<sub>OL</sub> and V<sub>OH</sub> thresholds (see Table 3-25); ASP TX HIZ DLY = 00. | | Parameters 1,2,3 | Symbol | Minimum | Typical | Maximum | Unit | |--------|-------------------------------------------------------------------------------|-----------------------|---------------------|---------|-------------------------|------| | ASP_S | CLK frequency <sup>4</sup> | f <sub>SCLK</sub> | 0.973 [5] | _ | 25.81 | MHz | | SCLK h | igh period <sup>4</sup> | t <sub>HI:SCLK</sub> | 18.5 | _ | _ | ns | | 1 | w period <sup>4</sup> | t <sub>LO:SCLK</sub> | 18.5 | _ | _ | ns | | 1 | uty cycle <sup>4</sup> | _ | 45 | _ | 55 | % | | | FSYNC/LRCK frame rate | _ | 0.99 | _ | 1.01 | Fs | | Master | Error duty cycle | _ | 45 | _ | 55 | % | | Mode | FSYNC high period <sup>6</sup> | t <sub>HI:FSYNC</sub> | 1/f <sub>SCLK</sub> | _ | (n-1)/f <sub>SCLK</sub> | s | | | FSYNC/LRCK delay time after SCLK launching edge <sup>7</sup> VL = 1.8 V | | 0 | _ | 15 | ns | | | VL = 1.2 V | | 0 | _ | 17 | ns | | | SDIN setup time before SCLK latching edge <sup>7</sup> | t <sub>SU:SDI</sub> | 10 | _ | _ | ns | | | SDIN hold time after SCLK latching edge <sup>7</sup> | t <sub>H:SDI</sub> | 5 | _ | _ | ns | | | SDOUT delay time after SCLK launching edge VL = 1.8 V | | 0 | _ | 15 | ns | | | VL = 1.2 V | | 0 | _ | 17 | ns | | | SDOUT Hi-Z delay time after SCLK latching edge (TDM; ASP_TX_HIZ_DLY = 00) 8,9 | t <sub>DLY:HiZ</sub> | _ | _ | 22 | ns | | Slave | FSYNC/LRCK frame rate | _ | 0.99 | _ | 1.01 | Fs | | Mode | FSYNC/LRCK duty cycle | _ | 45 | _ | 55 | % | | | FSYNC/LRCK setup time before SCLK latching edge <sup>7</sup> | t <sub>SU:LRCK</sub> | 10 | _ | _ | ns | | | FSYNC/LRCK hold time after SCLK latching edge <sup>7</sup> | t <sub>H:LRCK</sub> | 5 | _ | _ | ns | | | SDIN hold time after SCLK latching edge <sup>7</sup> | t <sub>H:SDI</sub> | 5 | _ | _ | ns | | | FSYNC/LRCK duty cycle | _ | 45 | _ | 55 | % | | | SDOUT delay time after SCLK launching edge VL = 1.8 V | | 0 | _ | 15 | ns | | | VL = 1.2 V | | 0 | _ | 17 | ns | | | SDOUT Hi-Z delay time after SCLK latching edge (ASP_TX_HIZ_DLY = 00)8,9 | t <sub>DLY:HiZ</sub> | _ | _ | 22 | ns | 1. Output clock frequencies follow SCLK frequency proportionally. Deviation of the bit-clock source from nominal supported rates is directly imparted to the output clock rate by the same factor (e.g., +100-ppm offset in the frequency of SCLK becomes a +100-ppm offset in MCLK and LRCK). $\mathsf{t}_{\mathsf{H}:\mathsf{LRCLK}}$ ∙t<sub>D:CLK-LRCLK</sub> 3.TDM interface timing. Note: SCPOL = 0 - 4.SCLK is mastered from an external device. The external device is expected to maintain SCLK timing specifications. 5.SCLK operation below 2.8224 MHz may result in degraded performance. - 6. Maximum LRCK duty cycle is equal to frame length, in SCLK periods, minus 1. Maximum duty cycle occurs when LRCK HI is set to 511 SCLK periods and LRCK period is set to 512 SCLK periods. t<sub>su:spi</sub>► - 7. Data is latched on the rising or falling edge of SCLK, as determined by ASP\_SCPOL\_IN\_x and ASP\_FSD (See Section 7.5.7 and Section 7.5.8). - 8. Data may be latched on either the rising or falling edge of SCLK. - 9.TDM interface Hi-Z timing #### Table 3-23. Switching Characteristics—S/PDIF Transmitter Test conditions (unless specified otherwise): Outputs: Logic 0 = 0 V, Logic 1 = VL = 1.8 V; C<sub>L</sub> = 60 pF. | Parameter | Minimum | Typical | Maximum | Unit | |------------------------------------------------------------|---------|---------|---------|--------| | Frame rate | 32 | _ | 192 | kHz | | S/PDIF transmitter output time-interval error (TIE) jitter | _ | 500 | ı | ps RMS | #### Table 3-24. I<sup>2</sup>C Slave Port Characteristics Test conditions (unless specified otherwise): Fig. 2-1 shows typical connections; Inputs: GNDA = GNDL = GNDCP = 0 V; all voltages with respect to ground; min/max performance data taken with VL = 1.66-1.94 V (VL\_SEL = VP) or VL = 1.1-1.3 V (VL\_SEL = GNDD); inputs: Logic 0 = GNDA = 0 V, Logic 1 = VL; $T_A$ = $+25^{\circ}$ C; SDA load capacitance equal to maximum value of $C_B$ = 400 pF; minimum SDA pull-up resistance, $R_{P(min)}$ . Table 3-1 describes some parameters in detail. All specifications are valid for the signals at the pins of the CS42L42 with the specified load capacitance. | Parameter <sup>2</sup> | | Symbol <sup>3</sup> | Minimum | Maximum | Unit | |---------------------------------------------------------|----------------------------------------------|---------------------|------------|--------------------|----------------| | SCL clock frequency | | f <sub>SCL</sub> | _ | 1000 | kHz | | Clock low time | | t <sub>LOW</sub> | 500 | _ | ns | | Clock high time | | t <sub>HIGH</sub> | 260 | _ | ns | | Start condition hold time (before first clock pulse) | | t <sub>HDST</sub> | 260 | _ | ns | | Setup time for repeated start | | t <sub>SUST</sub> | 260 | _ | ns | | Rise time of SCL and SDA | Standard Mode<br>Fast Mode | t <sub>RC</sub> | _ | 1000<br>300 | ns<br>ns | | | Fast Mode Plus | | _ | 120 | ns | | Fall time of SCL and SDA | Standard Mode | $t_{FC}$ | _ | 300 | ns | | | Fast Mode<br>Fast Mode Plus | | _ | 300<br>120 | ns<br>ns | | Setup time for stop condition | | t <sub>SUSP</sub> | 260 | _ | ns | | SDA setup time to SCL rising | | t <sub>SUD</sub> | 50 | _ | ns | | SDA input hold time from SCL falling <sup>4</sup> | | t <sub>HDDI</sub> | 0 | _ | ns | | Output data valid (Data/Ack) <sup>5</sup> | Standard Mode<br>Fast Mode<br>Fast Mode Plus | t <sub>VDDO</sub> | | 3450<br>900<br>450 | ns<br>ns<br>ns | | Bus free time between transmissions | | t <sub>BUF</sub> | 500 | _ | ns | | SDA bus capacitance | Fast Mode Plus<br>Standard Mode, Fast Mode | СВ | = | 550<br>400 | pF<br>pF | | SCL/SDA pull-up resistance <sup>1</sup> | VL = 1.2 V<br>VL = 1.8 V | R <sub>P</sub> | 200<br>250 | _ | Ω | | Switching time between RCO and PLL or SCLK <sup>6</sup> | | _ | 150 | _ | μs | <sup>1.</sup> The minimum $R_P$ value (see Fig. 2-1) is determined by using the maximum VL level, the minimum sink current strength of its respective output, and the maximum low-level output voltage, $V_{OL}$ . The maximum $R_P$ value may be determined by how fast its associated signal must transition (e.g., the lower the $R_P$ value, the faster the I<sup>2</sup>C bus can operate for a given bus load capacitance). See the I<sup>2</sup>C bus specification referenced in Section 13. 2.All timing is relative to thresholds specified in Table 3-25, $V_{IL}$ and $V_{IH}$ for input signals, and $V_{OL}$ and $V_{OH}$ for output signals. - 4.Data must be held long enough to bridge the SCL transition time, t<sub>F</sub>. - 5. Time from falling edge of SCL until data output is valid. - 6.The switch between RCO and either SCLK or PLL occurs upon setting/clearing SCLK\_PRESENT (see p. 138) and sending the I<sup>2</sup>C stop condition. An SCLK\_PRESENT transition (0 to 1 or 1 to 0) starts a switch between RCO and the selected SCLK or PLL. An I<sup>2</sup>C stop condition is sent, after which a wait time of at least 150 μs is required before the next I<sup>2</sup>C transaction can begin using the newly selected clock. #### Table 3-25. Digital Interface Specifications and Characteristics Test conditions (unless specified otherwise): Fig. 2-1 shows CS42L42 connections; GNDD = GNDCP = GNDA = 0 V; voltages are with respect to ground; parameters can vary with VL and VP; min/max performance data taken with VCP = VA = 1.8 V, VD\_FILT = 1.2 V; VP = 3.0–5.25 V; VL = 1.66–1.94 V (VL\_SEL = VP) or VL = 1.1–1.3 V (VL\_SEL = GNDD); $T_A = +25^{\circ}C$ ; $C_L = 60$ pF. | Parameters 1 | Symbol | Min | Max | Unit | |-----------------------------------------------------------------------------------------------|-------------------------|---------|---------|------| | Input leakage current <sup>2,3</sup> ASP_SDOUT, ASP_LRCK/FSYNC | I <sub>in</sub> | _ | ±4 | μA | | ASP_SCLK/SWIRE_CLK, SWIRE_SD/ASP_SDIN | | _ | ±3 | μA | | RING_SENSE, TIP_SENSE | | _ | ±100 | nA | | SDA, SCL | | _ | ±100 | nA | | ĪNT, WAKE, RESET | | _ | ±100 | nA | | Input leakage current (SoundWire) 2,3 Supplies as stipulated above | l <sub>in</sub> | _ | ±3 | μA | | ASP_SCLK/SWIRE_CLK and SWIRE_SD/ASP_SDIN only VD_FILT = 0 V (VL is as stated above) | | _ | ±3 | μA | | VL = 0 V | | _ | [4] | mA | | Internal weak pull-down | _ | 550 | 2450 | kΩ | | Input capacitance <sup>2</sup> | _ | _ | 10 | pF | | INT or WAKE current sink (V <sub>OL</sub> = 0.3 V maximum) | _ | 825 | _ | μΑ | | VL Logic (non-l <sup>2</sup> C, including High-level output voltage ( $I_{OH} = -100 \mu A$ ) | V <sub>OH</sub> | 0.9*VL | | V | | SPDIF TX) Low-level output voltage | V <sub>OL</sub> | _ | 0.1*VL | V | | High-level input voltage | VIH | 0.7*VL | _ | V | | Low-level input voltage | V <sub>IL</sub> | _ | 0.3*VL | V | | VL Logic (I <sup>2</sup> C only) Low-level output voltage | V <sub>OL</sub> | _ | 0.2*VL | V | | High-level input voltage | $V_{IH}$ | 0.7*VL | _ | V | | Low-level input voltage | $V_{IL}$ | _ | 0.3*VL | V | | Hysteresis voltage | $V_{HYS}$ | 0.05*VL | _ | V | | VP Logic (excluding TIP_SENSE) Low-level output voltage | $V_{OL}$ | _ | 0.2 | V | | High-level input voltage | $V_{IH}$ | 0.9 | _ | V | | Low-level input voltage | $V_{IL}$ | _ | 0.2 | V | | TIP_SENSE 5 High-level input voltage | $V_{IH}$ | 0.87*VP | | V | | Low-level input voltage | $V_{IL}$ | _ | 2.0 | V | | RING_SENSE 6 RS_TRIM_T = 0, High-level input voltage | V <sub>IH</sub> | 0.15*VP | _ | V | | Low-level input voltage | $V_{IL}$ | _ | 0.03*VP | V | | RS_TRIM_T = 1, High-level input voltage | $V_{IH}$ | 0.40*VP | _ | V | | Low-level input voltage | $V_{IL}$ | _ | 0.28*VP | V | | RING_SENSE pull-up resistance RING_SENSE_PU_HIZ = 1, RS_TRIM_R = 0; R <sub>PU</sub> to Hi-Z | R <sub>PU</sub> -Hi-Z | 1.688 | 2.813 | МΩ | | RING_SENSE_PU_HIZ = 0; R <sub>PU</sub> to Mid-Z | R <sub>PU</sub> -MIDZ | 12.15 | 20.25 | kΩ | | TIP_SENSE current to -VCP_FILT 5 TIP_SENSE_CTRL = 11 (Short-Detect Mode) | I <sub>TIP_SENSE</sub> | 1.00 | 2.91 | μA | | RING_SENSE current to GND 6 RS_TRIM_R = 0 (Hi-Z Mode) | I <sub>RING_SENSE</sub> | 1.00 | 3.2 | μA | - 1.See Table 1-1 for serial and control-port power rails. - 2. Specification is per pin. The CS42L42 is not a low-leakage device, per the MIPI Specification. See Section 13. - 3. Includes current through internal pull-up or pull-down resistors on pin. - 4.If VL = 0 V, the current must not exceed the values provided in Table 3-3. - 5.TIP\_SENSE input circuit. This circuit allows the TIP\_SENSE signal to go as low as -VCP\_FILT and as high as VP. Section 4.14.2 provides configuration details. 6.RING\_SENSE input circuit. This circuit allows the RING\_ SENSE signal to range between -VCP\_FILT and VP. ## 4 Functional Description This section provides a general description of the CS42L42 architecture and detailed functional descriptions of the various blocks that make up the CS42L42. Fig. 4-1 shows the flow of signals through the CS42L42 and gives links to detailed descriptions of the respective sections. Figure 4-1. Overview of Signal Flow The CS42L42 is an ultralow-power, 24-bit audio codec, with a single analog input ADC channel and a stereo DAC. The ADC is fed by fully differential or pseudodifferential analog input that support mic and line-level input signals. The DAC feeds a stereo pseudodifferential output amplifier. The converters operate at a low oversampling ratio, maximizing power savings while maintaining high performance. The serial data interface ports operate either at standard audio-sample rates as timing slaves or in Hybrid-Master Mode as a bit-clock slave generating LRCK internally. An onboard fractional-N PLL can be used to generate the internal-core timing $(MCLK_{INT})$ if the SCLK source is not one of the following rates (where N = 2 or 4): - N x 5.6448 or 6.1440 MHz - USB rates (N x 6 MHz) The CS42L42 significantly reduces overall power consumption, with a very low-voltage digital core and with low-voltage Class H amplifiers (powered from an integrated LDO regulator and a step-down/inverting charge pump, respectively). The CS42L42 comprises the following subblocks: - Analog input. The analog input block, described in Section 4.1, allows selection from mono line-level or mic sources. The pseudodifferential line-input configuration provides noise rejection for single-ended analog CS42L42 inputs. Mic input supports fully differential sources and can operate with single-ended sources in a pseudodifferential configuration. Analog input requires no external DC-blocking capacitors. - Digital mixer. The digital mixer, described in Section 4.2, facilitates the mixing and routing of the ADC and serial port audio data to the device analog. All paths have selectable attenuation before being mixed to allow relative volume control and to avoid clipping. - Equalizer. A bypassable, three-band equalizer, described in Section 4.3, is available to process signals within the CS42L42. Each of the three fully programmable filter banks can be configured independently. into more power-efficient Class H amplifiers. - Analog outputs. The analog output block, described in Section 4.4, includes separate pseudodifferential headphone Class H amplifiers. An on-chip step-down/inverting charge pump creates a positive and negative voltage equal to the input or to either one-half or one-third of the input supply for the amplifiers, allowing an adaptable, full-scale output swing centered around ground. The resulting internal amplifier supply can be ±VCP/3, ±VCP/2, ±VCP, or ±2.5 V. The inverting architecture eliminates the need for large DC-blocking capacitors and allows the amplifier to deliver more power to HP loads at lower supply voltages. The step-down architecture allows the amplifier's power supply to adapt to the required output signal. This adaptive power-supply scheme converts traditional Class AB amplifiers - Class H amplifier. The HP output amplifiers, described in Section 4.6, use a patented Cirrus Logic four-mode Class H technology that maintains high performance and maximizes operating efficiency of a typical Class AB amplifier. - Clocking architecture. Described in Section 4.7, the clock for the device can be supplied internally from an integrated fractional-N PLL using ASP\_SCLK/SWIRE\_CLK as the source clock or the internal PLL can be bypassed and derived directly from the ASP\_SCLK/SWIRE\_CLK input pin. - MIPI-compliant two-wire SoundWire interface. The CS42L42 integrates a SoundWire interface to transport audio and control data, which provides an alternative to the I<sup>2</sup>C/ASP interfaces. See Section 4.8. - Serial ports. The CS42L42 has two serial data-port options: The TDM/I<sup>2</sup>S (ASP) port is a highly configurable serial port; the MIPI-compliant SoundWire serial port can be selected to communicate audio and voice data to and from other devices in the system, such as application processors and Bluetooth® transceivers. See Section 4.9. The ASP can operate in TDM Mode, which includes full-duplex communication, defeatable SDOUT driver for sharing the TDM bus between multiple devices, flexible data structuring via control port registers, clock slave mode, and higher bandwidth, enabling more data to be transferred to and from the device. - S/PDIF Tx Port. The S/PDIF output port, described in Section 4.10, is integrated to provide a pass-through of encoded (e.g., AC3) or PCM data from the serial audio ports to an external optical driver. - Sample-rate converters (SRCs). SRCs, described in Section 4.11, are used to bridge different sample rates at the serial ports within the digital-processing core. SRCs are used for the ASP output channel, and both ASP input channels, the SoundWire output channel and both SoundWire input channels. SRCs can be bypassed. Note that the S/PDIF channels do not have SRCs in their paths. - Headset interface. This interface is described in Section 4.12. It is a collection of low-power circuits that provide an intelligent interface to an external headset. It also communicates with an applications processor to relay command and status information. Headset-type detection is described in Section 4.13. - The CS42L42 supports plug presence-detect capability via the two associated sense pins: TIP\_SENSE and RING\_ SENSE. The sense pins are debounced to filter out brief events before being reported to the corresponding presence detect bit and generating an interrupt if appropriate. Plug presence detection is described in Section 4.14. - Power management. Several control registers provide independent power-down control of the analog and digital sections of the CS42L42, allowing operation in select applications with minimal power consumption. Power management considerations are described in Section 4.15. - Control-port operation. The control port, described in Section 4.16, provides access to the registers for configuring the codec. The control port operation may be completely asynchronous with respect to the audio sample rates. To avoid potential interference problems, control-port data pins must remain static if no operation is required. - Resets. Section 4.17 describes the reset options—power-on reset (POR), asserting RESET, and the SoundWire reset mechanism. - Interrupts. The CS42L42 includes an open-drain interrupt output, INT. Interrupt mask registers control whether an event associated with an interrupt status/mask bit pair triggers the assertion of INT. A set of SoundWire interrupts is provided that is separate from the general interrupt implementation. See Section 4.18. Note that the following terms are used interchangeably in this document: - ASP RX, DAI0, and DAC input - ASP DAI1 and SPDIF input - ASP TX, DAO and ADC ## 4.1 Analog Input The CS42L42 analog (line in/mic) input is fed to a high-dynamic range ADC path, shown in Fig. 4-2. Figure 4-2. Analog-Input Signal Flow The CS42L42 provides a mono, high-performance capture path, directly sourced from HSIN±. To optimize the path's dynamic range and power consumption, the ADC uses analog and DSP techniques to automatically adapt to input signal content. During normal operation, the high-performance ADC path channel selects either a high-input amplitude path or low-noise path. With this functionality, the path's dynamic range can be optimized without the power consumption of a single, high-amplitude, low-noise ADC path. The ADC HSIN inputs supports fully differential, pseudodifferential, and single-ended configurations (see Fig. 4-3). Although the best performance is typically achieved with a fully differential signal input, the pseudodifferential configuration is recommended over a traditional single-ended input configuration when possible (see Fig. 4-2). This is due to cancelation of common-mode signals or noise that may appear on the signal. Figure 4-3. Analog Input Configurations ## 4.1.1 ADC High-Pass Filter The ADC path, shown in Fig. 4-2, includes a defeatable, first-order digital high-pass filter, enabled by setting ADC\_HPF\_EN (see p. 159). Clearing this bit may cause clipping of the ADC digital output. ADC\_HPF\_CF (see p. 159) is used to configure the corner frequency. Table 3-6 lists high-pass filter specifications. #### 4.1.2 ADC Wind-Noise Filter The defeatable, bypassable, fourth-order digital high-pass filter is enabled by ADC\_WNF\_EN (see p. 159). Its configurable corner frequency is controlled by ADC\_WNF\_CF (see p. 159). Table 3-11 lists wind-noise filter specifications. #### 4.1.3 ADC Gain Control In traditional ADC designs, selectable gain stages or fixed-gain preamps (PGAs) commonly precede the ADC inputs. Although these offer flexibility, they are a result of ADC input limitations. If a gain is selected too high, clipping may occur in the ADC on loud passages. If the gain is too low to avoid clipping, sounds may be too low and SNR may suffer. The CS42L42 ADC path achieves very high dynamic range with a very low noise floor with minimal power. Using patent-pending circuitry that simplifies the ADC input-path configuration, the ADC fundamentally captures the entire sound signal. The resulting SNR is typically much higher than legacy systems, without potential clipping. The CS42L42 incorporates digital-gain capability that allows the SNR to remain constant as compared to analog gain adjustments in legacy systems. Enabling ADC\_DIG\_BOOST (see p. 158) adds a +20-dB digital gain to the ADC output. Additionally, the ADC\_VOL control (see p. 158) allows for volume control range from +12 to –96 dB, or mute. ### 4.1.4 Soft Ramping Control If ADC\_SOFTRAMP\_EN (see p. 158) is set, changes to ADC digital volumes are applied slowly by stepping through each volume-control setting with a delay between steps equal to an integer number of Fs periods. The delay between steps can vary from 1/Fs period to 72/Fs periods and is set via DSR\_RATE (see p. 134). ## 4.2 Digital Mixer The internal stereo digital mixer, shown in Fig. 4-4, can mix the ADC path output with Channel A and B from the serial port inputs. Each input can be attenuated via MIXER CHx VOLy. Outputs are available as a source for the DACs. Figure 4-4. Digital Mixer Subblocks **Note:** When mixing channels, to ensure that all paths are defined and known, select only active channels. Selecting a powered-down channel may cause undesirable behavior, such as clipping or high distortion. ## 4.2.1 Avoiding Mixer Clipping Because digital mixers are essentially adders, when more than one input is fed into a mixer, a potential for overflow exists, depending on the bit-word length of the inputs and the mixer and the input value range used. For example, if two, full-range, signed, 4-bit channels yield a signed 4-bit result, whenever the sum of the two inputs falls outside the –8 to +7 range, the hypothetical result would overflow, causing undesired output signal distortion (i.e., wrapping). All mixers have enough accumulator bits to avoid overflow. If any mixer's result exceeds the bit width of the signal data path, the result is forced to either the full-scale maximum or minimum value. This ensures that the signal is clipped rather than distorted (by the wrapping effect of truncating the accumulator result to fit the data path width). Attention is required to ensure that clipping does not occur within the digital mixer control. Of course, if the digital mixer control is fed a signal that was clipped elsewhere, its output retains that external clipping. Table 4-1 lists the recommended maximum premixer volume level settings to avoiding mixer clipping. Table 4-1. Recommended Premixer Attenuation to Avoid Clipping | Number of Active Channels into Mixer | Maximum Signal Strength Allowed per Input | Suggested Volume (dB) Setting per Input | |--------------------------------------|-------------------------------------------|-----------------------------------------| | 1 | 1 | 0 | | 2 | 1/2 | -6 | For Table 4-1, it is assumed that all inputs are at full scale (no preattenuation) and that there is no relative volume adjustment between inputs. If one or more inputs is at less than full scale, less attenuation (a higher volume) can be set while avoiding mixer clipping. If there is to be a relative volume adjustment between inputs, less attenuation can be set for one or more inputs as long as any other inputs are sufficiently attenuated to avoid clipping (e.g., with three full-scale inputs, one input could be attenuated by 6 dB, as long as the other two are attenuated by 12 dB). **Note:** As noted elsewhere, to avoid clipping, select only active channels when mixing channels. #### 4.2.2 Mixer Attenuation Values The digital mixer contains programmable attenuation blocks that are configured as described in the MIXER\_CHx\_VOLy field descriptions in Section 7.15.1—Section 7.15.3. For all settings except 0 dB, attenuation on the mixer input includes an offset that increases as attenuation increases, as follows: - For commonly used -6n dB ( $n = \{1, 2, \text{ etc.}\}$ ) attenuation settings, the offset rounds the attenuation exactly to the desired $1/2^n$ factor (e.g., 20Log(1/2) = 6.021 dB, not 6.000 dB). - For attenuation settings other than –6*n* dB, the always positive offset provides slightly more attenuation, giving enough margin to avoid mixer clipping. # 4.3 Three-Band Equalizer The mono equalizer connects as shown in Fig. 4-5. The equalizer input enters three fully programmable parametric filter banks that can be independently configured in any of the following: low-pass filter (LPF), high-pass filter (HPF), all-pass filter (APF), band-pass filter (BPF), notch filter (NF), peaking EQ (PEQ), low-shelving EQ (LSEQ), or high-shelving EQ (HSEQ). Figure 4-5. Three-Band Equalizer The three filter banks are cascaded, such that the Filter Bank 1 output is the input to Filter Bank 2, and so on. Therefore, the overall transfer function is the product of the three functions: $H_1(z) \cdot H_2(z) \cdot H_3(z)$ , as shown in Fig. 4-5. Each bank is implemented as Direct Form II transposed, as shown in Fig. 4-6. Figure 4-6. Direct Form II Transposed Filter Bank Architecture Eq. 4-1 represents the filter bank architecture, where y[n] represents the output sample value and x[n] represents the input sample value. $$y[n] = b_0x[n] + b_1x[n-1] + b_2x[n-2] + a_1y[n-1] + a_2y[n-2]$$ Equation 4-1. Filter Equation **Note:** If the conventional difference equation is used to calculate coefficients, coefficients a1 and a2 must be inverted before writing them. To avoid audible distortion when inputs to the equalizer are extremely large, the gain must be limited to 0 dB for each filter stage and all B coefficients must be between ±1.0. As Table 4-2 shows, coefficients are represented in binary by 32-bit signed values stored in S1.30 two's complement format. The 2 MSBs represent the sign bit and whole-number portion of the decimal coefficient. The 30 LSBs represent the fractional portion of the coefficient. Coefficients must be in the range of -2.00000 to 1.999999999 (0x8000 0000-0x7FFF FFFF). Table 4-2. Equalizer Filter Formatting (Fs<sub>INT</sub> = 48 kHz) | <b>Precision of Coefficients</b> | Order of Filter | Sample Rate | Coefficient Design Base | Length (in Bytes) | |----------------------------------|-----------------|-------------------|------------------------------------------------------------------------------|-------------------| | S1.30 | 3 biquads | Fs <sub>INT</sub> | $z^{-1}$ (For $z^{-1}$ , design the coefficients at the rate of the filter.) | 60 | Section 7.16 describes three-band equalizer registers. All coefficients are configured as pass-through at power-up. **Note:** Filters are read and written by using EQ\_COEF\_OUT and EQ\_COEF\_IN (see p. 161). However, they must be accessed only as part of a full-filter access procedure; otherwise, the three-band filter may be corrupted and audio artifacts may occur. Use Ex. 4-1 to write EQ filter coefficients. #### **Example 4-1. Writing the EQ Filter Coefficients** | STEF | TASK | | | | |------|-----------------------------------------------|-----------------------------------------|-----------|-------------------------------------| | 1 | Ensure EQ initialization is complete (EQ_ | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | | | INIT_DONE = 1). | Equalizer Initialization Status | 0x01 | | | | Note: polling EQ_INIT_DONE is valid only | Reserved | 000 000 | _ | | | if EQ PDN = 0 (EQ is powered up.) | EQ_INIT_DONE | 1 | EQ initialization complete. | | 2 | Clear the equalizer start filter bit to allow | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | | | writing coefficients. | Equalizer Start Filter Control | 0x00 | | | | | Reserved | 000 000 | _ | | | | EQ_START_FILTER | 0 | Coefficients can be read or written | | 3 | Disable the EQ bypass. | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | | | | Serial Port SRC Control | 0x00 | | | | | Reserved | 000 | _ | | | | EQ_BYPASS | 0 | No bypass | | | | I2C_DRIVE | 0 | Normal | | | | ASP_DRIVE | 0 | Normal | | | | SRC <sup>B</sup> YPASS DAC | 0 | No bypass | | | | SRC_BYPASS_ADC | 0 | No bypass | | 4 | Mute the EQ input path. | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | | | | Equalizer Input Mute Control | 0x01 | | | | | Reserved | 0000 0000 | _ | | | | EQ_MUTE | 1 | Mute EQ Channel input. | | 5 | Set the EQ write enable bit. | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | | | | Equalizer Filter Coefficient Read/Write | 0x02 | | | | | Reserved | 000000 | _ | | | | EQ WRITE | 1 | Enable EQ write. | | | | EQ_READ | 0 | Disable EQ read. | | _ | | | 00 1 4 14 | | <sup>6</sup> Write input coefficients. There are 15 32-bit coefficients and four 8-bit registers, so 60 register writes are required. Biquad 1, a1 | Biquad | 3, | b2 | |--------|----|----| |--------|----|----| | | | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | |-----|--------------------------------|----------------------------------------|-------------------|-------------------| | 6.1 | Write EQ_COEF_IN[7:0] (0x2401) | Equalizer Filter Coefficient Input 0–3 | 0xXX | | | | | EQ_COEF_IN[7:0] | | Coefficient write | | 6.2 | Write EQ_COEF_IN[15:8] | Equalizer Filter Coefficient Input 0–3 | 0xXX | | | | (0x2402) | EQ_COEF_IN[15:8] | | Coefficient write | | 6.3 | Write EQ_COEF_IN[23:16] | Equalizer Filter Coefficient Input 0–3 | 0xXX | | | | (0x2403) | EQ_COEF_IN[23:16] | | Coefficient write | | 6.4 | Write EQ_COEF_IN[31:24] | Equalizer Filter Coefficient Input 0–3 | 0xXX | | | | (0x2404, see note below) | EQ_COEF_IN[31:24] | Coefficient write | | | | · | | | | The biquad order is as follows: 1, 2, 3 The coefficient order is as follows: b0, b1, a1, a2, b2 The sequence shown in Steps 6.1 through 6.4 writes a single coefficient for a single biquad: This process is repeated 15 times. The order of coefficients is as follows: Biquad 1, b0 Biquad 1, b1 | Clear the EQ write enable bit. | Equalizer Filter Coefficient Read/Write | 0x00 | | |--------------------------------|-----------------------------------------|---------------|---------------------------------------| | | Reserved | 000000 | _ | | | EQ_WRITE<br>EQ_READ | 0<br>0 | Disable EQ write.<br>Disable EQ read. | | Set the EQ filter start bit. | Equalizer Start Filter Control | 0x01 | | | | Reserved EQ_START_FILTER | 0000 000<br>1 | —<br>Start EQ filter. | | Unmute the EQ input path. | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | | | Equalizer Input Mute Control | 0x00 | | | | Reserved<br>EQ_MUTE | 0000 000<br>0 | — Unmute EQ Channel input. | Use Ex. 4-2 to read EQ filter coefficients. Read the coefficients only as soon as they are written (e.g., before setting EQ\_ START\_FILTER in Step 8 in Ex. 4-1). **Notes:** If EQ\_START\_FILTER is cleared after reading the coefficients, the b0 coefficients are set to +1.0 and the remaining coefficients are cleared. Setting the EQ\_START\_FILTER back to 1 does not restore the coefficients. A complete rewrite must be performed. Writing EQ\_COEF\_IN[31:24] stretches the clock unless (EQ\_PDN==0 && (EQ\_READ==1 XOR EQ\_WRITE==1)) Reading EQ\_COEF\_OUT[7:0] stretches the clock unless (EQ\_PDN==0 && (EQ\_READ==1 XOR EQ\_WRITE==1)) If SoundWire is used to read the EQ coefficients, indirect access is preferred. See Section 4.8.12. **Example 4-2. Reading the EQ Filter Coefficients** | STEF | TASK | | | | | |------|--------|------------------------------------------------|-----------------------------------------|-------------------|------------------------------------| | 1 | Set th | e EQ read enable bit. | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | | | | | Equalizer Filter Coefficient Read/Write | 0x01 | | | | | | Reserved EQ_WRITE EQ_READ | 0000 00<br>0<br>1 | | | 2 | | output coefficients | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | | | 2.1 | Read EQ_COEF_OUT[7:0] (0x2407, see note above) | Equalizer Filter Coefficient Output 0–3 | 0xXX | | | | | (0x2407, see note above) | EQ_COEF_OUT[7:0] | | Coefficient read from EQ | | | 2.2 | Read EQ_COEF_OUT[15:8] | Equalizer Filter Coefficient Output 0-3 | 0xXX | | | | | (0x2408) | EQ_COEF_OUT[15:8] | | Coefficient read from EQ | | | 2.3 | Read EQ_COEF_OUT[23:16] | Equalizer Filter Coefficient Output 0-3 | 0xXX | | | | | (0x2409) | EQ_COEF_OUT[23:16] | | Coefficient read from EQ | | | 2.4 | Read EQ_COEF_OUT[31:24] | Equalizer Filter Coefficient Output 0-3 | 0xXX | | | | | (0x240A) | EQ_COEF_OUT[31:24] | | Coefficient read from EQ | | 3 | Clear | the EQ read enable bit. | Equalizer Filter Coefficient Read/Write | 0x00 | | | | | | Reserved<br>EQ_WRITE<br>EQ_READ | 0000 00<br>0<br>0 | Disable EQ write. Disable EQ read. | # 4.4 Analog Output This section describes the headphone (HP) outputs. The CS42L42 provides an analog output that is fed from the mixer. Fig. 4-7 shows the general flow of the analog outputs. Figure 4-7. Analog-Output Signal Flow The output path is sourced directly from the mixer output. The playback path uses advanced analog and digital signal-processing techniques to adapt to the input signal content and enhance dynamic range and power consumption of the playback path. The HP output must be muted before changing the state of FULL\_SCALE\_VOL (see p. 160), which sets the maximum HPOUT output voltage. See Table 3-13. HP outputs are muted by ANA\_MUTE\_B and ANA\_MUTE\_A (see p. 160). Fig. 4-8 shows analog output flow details. Power to DACs is controlled by the related output drivers' PDN bits. Fig. 4-9 is an op-amp-level schematic for the analog output flow. Figure 4-9. Op-Amp-Level Schematic—Analog Outputs # 4.4.1 Pseudodifferential Outputs The analog output amplifiers use a pseudodifferential output topology that allows the amplifier to monitor the ground potential at the load through the reference pins (HSx\_REF, RING\_SENSE). Minimize the impedance from the CS42L42 reference pin to the load ground (typically the connector ground). Impedance in this path affects analog output attenuation as well as the common-mode rejection of the output amplifier, which affects output offset and step deviation. # 4.4.2 Using External Output Switches The CS42L42 can work with external switches for the headphone outputs along with mic inputs. Fig. 4-10 shows a simplified, closed-loop example of supporting two separate headsets, including headphone and mic support. For simplicity, tip sense and ring sense connectivity is not shown. Figure 4-10. Closed-Loop External Output Switches Fig. 4-10 shows HPSENSA and HPSENSB, pins not typically seen in the HP output. They allow the feedback point of the HP output to include the switch impedance. This closed-loop method improves output performance, although the following considerations must be adhered to when incorporating external switches: - The combined switch ON-resistance ( $R_{ON}$ ) and PCB trace resistance must be less than 1 $\Omega$ . Although any added resistance in the signal path decreases output voltage swing, keeping the total resistance below 1 $\Omega$ minimizes the voltage loss along with reducing the effect on DC offsets. For example, for a 30- $\Omega$ load, the full-scale output voltage swing is reduced by the extent of the switches' ON-resistance. - The switch ON-resistance flatness ( $R_{ON}$ flatness) must be less than 0.02 $\Omega$ over the common-mode voltage swing of these switches. for SW6 and SW8 and less than 0.075 $\Omega$ over the common-mode voltage swing of SW2 and SW4. Failure to meet this requirements degrades THD performance. - Note that not just the value of the switches' $R_{ON}$ flatness, but also its shape has a considerable effect on THD performance. It is recommended that the shape be as linear as possible over the common-mode voltage swing appearing at each switch. Shapes such as "W", "N", and "M" significantly affect THD, even if their $R_{ON}$ flatness meets the values defined here. - The total capacitance placed on the HPOUTx pins is limited to 1 or 10 nF, depending on the HPOUT\_LOAD setting (see p. 159). The combined switch capacitance (C<sub>ON</sub> + C<sub>OFF</sub>), PCB stray capacitance, and any headphone connector/cable/load capacitance must be within these limits, otherwise stability is reduced and THD is degraded. Because the amplifier feedback path includes the switches, HP\_PDN must be set if the switches are open. # 4.4.3 Using Open-Loop Configuration for Multiple HPs and Mics The open-loop configuration shown in Fig. 4-11 offers another way to support multiple headphones and microphones. Figure 4-11. Open-Loop Configuration This approach requires half the number of switches, saving PCB space and cost, addressing routing concerns, and decreasing the total capacitance. The drawback is that the feedback points do not account for switch characteristics, which leads to significantly degraded THD performance and an increased reduction in voltage appearing at the headphone connector. Due to these factors, this open-loop approach is not recommended for general use. The closed-loop approach feedback point is taken at the connector. This forces the HP output amplifier to correct for switch characteristics even though the maximum output voltage swing is the same for both configurations. Additionally, the HSx\_REF connection point is also at the connector in the closed-loop configuration, which improves HP performance over the open-loop method. Together, the closed-loop configuration results in the best performance if switches must be used. # 4.4.4 Output Load Detection The CS42L42 can distinguish between the following output loads: - $R_1 = 15, 30, \text{ or } 3 \text{ k}\Omega$ - C<sub>1</sub> < ~2 nF (low capacitance); C<sub>1</sub> > ~2 nF (high capacitance) **Note:** Channels A and B must have matching loads, although load detection is performed using Channel A. Before output load detection is initiated, the following steps must be performed: - 1. HS-type information must be determined to run a headset load-detection sequence, as described in Section 4.13. - 2. Power down the ADC and HP blocks: ADC\_PDN = 1, HP\_PDN = 1 (see p. 135). - 3. Mute the analog outputs: ANA\_MUTE\_B = ANA\_MUTE\_A = 1 (see p. 160). - 4. Disable the DAC high-pass filter: DAC\_HPF\_EN = 0 (see p. 159). **Note:** Restore the previous setup after detection completes. - 5. Set LATCH\_TO\_VP (see p. 155). - Set HSBIAS\_CTRL to 00 (Hi-Z Mode; see p. 155). - 7. Set ADPTPWR = 100 (see p. 160). - 8. Set the analog soft-ramp rate (ASR\_RATE = 0111; see p. 134). - 9. Set the digital soft-ramp rate (DSR RATE = 0001; see p. 134). - 10. After load detection completes, ASR\_RATE, DSR\_RATE, ADPTPWR, and DAC\_HPF\_EN must be restored to their previous values. See Section 4.6 for details. See the detailed detection instruction sequence in Ex. 5-5 for details. After an HP-detect event, if HP\_LD\_EN is set (see p. 153), the CS42L42 proceeds to detect the resistance and capacitance of the output load. A 24-kHz tone is output on HPOUTA, and HS3 or HS4 (depending on China headset detect results) is measured using an internal resistor bank as a reference. RLA\_STAT (see p. 153) reports resistance-detection results for Channel A as follows: - 00: 15 Ω - 01: 30 Ω - 10: 3 kΩ - 11: Reserved If the typical output resistance of less than ~300 $\Omega$ is indicated, a low-capacitance load is assumed. If the resistance is greater than 300 $\Omega$ , capacitance detection proceeds. After the detection sequence completes, HPLOAD\_DET\_DONE (see p. 153) is set. The results of capacitor detection is reported in CLA\_STAT (see p. 153). This result can be used to program the value in HPOUT\_LOAD(see p. 159), which determines the compensation of the headphone amplifier. #### Notes: - The HP path must be powered down before updating the HPOUT\_LOAD setting and repowered afterwards. - Low capacitance results were determined with C<sub>L</sub> = 1 nF; high capacitance results were determined with C<sub>L</sub> = 10 nF. #### 4.4.5 Slow Start Control Mixer, DAC, and HP soft ramping is enabled through SLOW\_START\_EN (p. 134). If SLOW\_START\_EN = 111, changes to DAC/HP volumes are applied slowly by stepping through each volume-control setting with a delay between steps equal to an integer number of Fs periods. The delay between steps, which can vary from 1/Fs to 72/Fs periods, is set via DSR\_RATE and ASR\_RATE (see p. 134). If ramping is disabled, changes occur immediately with the clock edge. # 4.5 System Headphone Parasitic Resistances Parasitic resistances limit the measurements on several specs, including the following: - Headphone-to-analog input isolation - · Headphone interchannel isolation - · Headphone mute attenuation - Headphone DC offset Fig. 4-12 shows the headphone-to-analog input electrical path. Figure 4-12. Headphone-to-ADC Electrical Path Based on Fig. 4-12, the formula in Eq. 4-2 measures headphone-to-analog isolation. Isolation = $$20 \cdot log \left( \frac{2}{R_1} \cdot R_{T2} \right)$$ Equation 4-2. Headphone-to-Analog Isolation Equation Eq. 4-2 gives an isolation of +69.03 dB, given the following: - $R_L = 30 \Omega$ - $R_{T2} = 0.0053 \Omega$ - $R_{COM2} = 0.1 \Omega$ - R<sub>BIAS</sub> = 2.21 kΩ - $R_{MIC} = 2.21 k\Omega$ Fig. 4-13 shows the headphone electrical path. Figure 4-13. Headphone Electrical Path Based on Fig. 4-13, the formula Eq. 4-3 can be used to measure the headphone interchannel isolation, and formula Eq. 4-4 can be used to measure the actual mute attenuation based on a measured mute attenuation. Interchannel Isolation = $$-20 \cdot log \left| \frac{R_{COM1} + R_{T1}}{2 \cdot (R_1 + R_2)} - \frac{R_{COM2}}{R_L} \right|$$ Equation 4-3. Headphone Interchannel Isolation (ICI) Equation Eq. 4-3 yields a headphone interchannel isolation of +83.5 dB when the following assumptions are made: - R<sub>I</sub> = 30 Ω - $R_1 = R2 = 12 \text{ k}\Omega$ - $R_{T1} = 0.002 \Omega$ - $R_{COM1} = 0.001 \Omega$ - R<sub>COM2</sub> = 0.002 Ω<sup>6</sup> Eq. 4-4 can be used to measure the mute attenuation: Mute Attenuation = $$20 \cdot log \left( 10^{\left(\frac{(MA_M + 6)}{20}\right)} - \frac{R_{T1}}{12000} \right) - 6$$ Equation 4-4. Headphone Mute Attenuation Equation Eq. 4-4 yields an actual mute attenuation of –87.77 dB assuming the following: - $R_{T1} = 0.4 \Omega$ - MA<sub>M</sub> (Mute attenuation measured) = -84.8 dB Because large values of R<sub>T1</sub> cause increased DC offset (see Fig. 4-13), it is recommended to keep RT1 less than 1 Ω. # 4.6 Class H Amplifier Fig. 4-14 shows the Class H operation. Figure 4-14. Class H Operation The CS42L42 HP output amplifiers use a Cirrus Logic four-mode Class H technology, which maximizes operating efficiency of the typical Class AB amplifier while maintaining high performance. In a Class H amplifier design, the rail voltages supplied to the amplifier vary with the needs of the music passage being amplified. This conserves energy during low-power passages and when the program material is played back at low volume. The internal charge pump, which creates the rail voltages for the HP amplifiers, is the central component of the four-mode Class H technology. The charge pump receives its input voltage from the voltage present on either the VCP or VP pin. From this voltage, the charge pump generates the differential rail voltages supplied to the amplifier output stages. The charge pump can supply four sets of differential rail voltages: ±2.5, ±VCP, ±VCP/2, and ±VCP/3. Table 4-3 shows the nominal signal- and volume-level ranges if the amplifier is set to the adapt-to-signal mode explained in Section 4.6.1. In addition to adapting to the input signal, the Class H control is capable of monitoring the internal headphone amplifier supply to allow more efficient, load-dependent, automatic Smart Class H Mode selection. In fixed modes, if the signal level exceeds the maximum value of the indicated range, clipping can occur. Load Mode Class-H Supply Voltage Signal-Level Range 1,2,3,4 Resistance Capacitance 15 Ω 1 nF 0 ±2.5 V ≥ –8 dB –9 to −14 dB ± VCP 1 2 ± VCP/2 -15 to -20 dB 3 ± VCP/3 ≤ –21 dB 10 nF ≥ -9 dB 0 ±2.5 V ± VCP -10 to -14 dB 1 ± VCP/2 -15 to -19 dB 2 3 ± VCP/3 ≤ -20 dB 30 Ω 1 or 10 nF 0 ±2.5 V ≥ –4 dB 1 ± VCP -5 to -11 dB 2 ± VCP/2 -12 to -16 dB 3 ± VCP/3 ≤ –17 dB 0 ±2.5 V ≥ –1 dB $3 k\Omega$ 1 or 10 nF 1 ± VCP –2 to –8 dB 2 ± VCP/2 −9 to −13 dB 3 ± VCP/3 ≤ –14 dB Table 4-3. Class H Supply Modes # 4.6.1 Power Control Options This section describes the supported types of operation: standard Class AB and adapt to signal. The set of rail voltages supplied to the amplifier output stages depends on the ADPTPWR setting, as described in Section 7.14.1. ### 4.6.1.1 Standard Class AB Operation (ADPTPWR = 001, 010, 011, or 100) If ADPTPWR is set to 001, 010, 011, or 100, the rail voltages supplied to the amplifiers are held to ±2.5, ±VCP, ±VCP/2, or ±VCP/3, respectively. For these settings, the rail voltages supplied to the output stages are held constant, regardless of the signal level. In these settings, the CS42L42 amplifiers operate in a traditional Class AB configuration. ### 4.6.1.2 Adapt-to-Output Signal (ADPTPWR = 111) If ADPTPWR = 111, the rail voltage sent to the amplifiers is based only on whether the signal sent to the amplifiers would cause the amplifiers to clip when operating on the lower set of rail voltages at certain threshold values. - If clipping can occur, the control logic instructs the charge pump to provide the next higher set of rail voltages. - If clipping could not occur, the control logic instructs the charge pump to provide the lower set of rail voltages, eliminating the need to advise the CS42L42 of volume settings external to the device. <sup>1.</sup>In Adapt-to-Signal Mode, volume level ranges are approximations but are within -0.5 dB from the values shown. <sup>2.</sup> Relative to digital full scale with FULL SCALE VOL set to 0 dB. <sup>3.</sup>In fixed modes, clipping occurs if the signal level exceeds the maximum of this range due to setting the amplifier's supply too low. <sup>4.</sup>To optimize efficiency, smart Class H thresholds automatically vary based on load conditions. # 4.6.2 Power-Supply Transitions Charge-pump transitions from the lower to the higher set of rail voltages occur on the next FLYN/FLYP clock cycle. Despite the system's fast response time, the VCP\_FILT pin's capacitive elements prevent rail voltages from changing instantly. Instead, the rail voltages ramp from the lower to the higher supply, based on the time constant created by the output impedance of the charge pump and the capacitor on the VCP\_FILT pin (the transition time is approximately 20 µs). Fig. 4-15 shows Class H supply switching. During this transition, a high dV/dt transient on the inputs may briefly clip the outputs before the rail voltages charge to the full higher supply level. This transitory clipping has been found to be inaudible in listening tests. Figure 4-15. VCP\_FILT Transitions—Headphone Output When the charge pump transitions from the higher to the lower set of rail voltages, there is a 5.5-s delay before the charge pump supplies the lower rail voltages to the amplifiers. This hysteresis ensures that the charge pump does not toggle between the two rail voltages as signals approach the clip threshold. It also prevents clipping in the instance of repetitive high-level transients in the input signal. Fig. 4-16 shows this transitional behavior. Figure 4-16. VCP\_FILT Hysteresis—Headphone Output # 4.6.3 Efficiency As discussed in previous sections, amplifiers internal to the CS42L42 operate from one of four sets of rail voltages, based on the needs of the signal being amplified. Fig. 4-17 and Fig. 4-18 show power curves for all modes of operation and provides details regarding the power supplied to 15- and $30-\Omega$ stereo loads versus the power drawn from the supply for each Class H mode. If rail voltages are set to $\pm 2.5$ V, the amplifiers operate in their least efficient mode for low-level signals. If they are held at $\pm$ VCP, $\pm$ VCP/2, or $\pm$ VCP/3, amplifiers operate more efficiently, but are clipped if required to amplify a full-scale signal. The adapt-to-signal trace shows the benefit of four-mode Class H operation. At lower output levels, amplifier output is represented by the $\pm$ VCP/3 or $\pm$ VCP/2 curve, depending on the signal level. At higher output levels, amplifier output is represented by the $\pm$ VCP or $\pm$ 2.5-V curve. The duration for which the amplifiers operate within any of the four curves ( $\pm$ VCP/3, $\pm$ VCP, or $\pm$ 2.5 V) depends on both the content and the output level of the material being amplified. The highest efficiency operation results from maintaining an output level that is close to, without exceeding, the clip threshold of the particular supply curve. Note that the Adapt-to-Signal Mode trace in Fig. 4-17 shows that it never transitions to Mode 0, because FULL\_SCALE\_ VOL = 1 (-6 dB) due to a 15- $\Omega$ stereo load. Figure 4-17. Class H Power-to-Load Versus Power from Supply (15 $\Omega$ , Stereo) The Adapt-to-Signal Mode trace in Fig. 4-18 shows the transition to Mode 0, because FULL\_SCALE\_VOL = 0 (0 dB) due to a $30-\Omega$ stereo load. Figure 4-18. Class H Power-to-Load Versus Power from Supply (30 $\Omega$ , Stereo) #### 4.6.4 HP Current Limiter The CS42L42 features built-in current-limit protection for the HP output. Table 3-16 lists the current limit threshold during the short-circuit conditions shown in Fig. 4-19. For HP amplifiers, current is from the internal charge-pump output, and, as such, applies the current from VCP or VP, depending on the mode. Figure 4-19. HP Short-Circuit Setup # 4.7 Clocking Architecture The CS42L42 offers several ways to support control, ASP operation, data conversion, and signal processing. Internal clocks are generated either from SCLK (ASP\_SCLK/SWIRE\_CLK) or from the integrated fractional-N PLL; see Fig. 4-20. Depending on the MCLK SRC SEL setting (see Fig. 4-21), MCLK<sub>INT</sub> is provided by one of the following methods: - Externally sourced directly from the ASP\_SCLK/SWIRE\_CLK input pin - Internally generated from an integrated fractional-N PLL with ASP\_SCLK/SWIRE\_CLK as a reference clock Figure 4-20. Clock Architecture Block Diagram # 4.7.1 Start-Up Clocking Using the RC Oscillator (RCO) At power on, an integrated low-power RCO, shown in Fig. 4-20, functions as the default clock for the digital core of the CS42L42, during which time SCLK is unavailable. A reset event always returns it to running off of the RCO. If SCLK is unavailable, RCO clocking must be used only for I<sup>2</sup>C functionality. RCO is multiplexed with MCLK<sub>INT</sub> and fed to the I<sup>2</sup>C slave control port. The SCLK must become active and the RCO must be disabled before data conversion. ### Note the following: - OSC\_SW\_SEL\_STAT (see p. 138) indicates the status of the clock switching (in transition, RCO, or SCLK/PLL). With the existing encoding, only one bit can physically change at a time, and the bit changing is always synchronous to the clock that is currently selected. - OSC PDNB STAT (see p. 138) indicates the RCO power-down status. - SCLK\_PRESENT is used to determine the internal MCLK source. See Section 7.4.6 for details. The clock-switch state machine uses the transition of SCLK\_PRESENT to both initiate switches between the selected internal MCLK between the SCLK pin (SCLK\_PRESENT = 1) or the internal RCO (SCLK\_PRESENT = 0) and to send the $I^2$ C stop condition that each switching event requires. During switching, a delay of at least 150 $\mu$ S is needed before additional successful $I^2$ C communication can begin to use the new clocking source. #### Notes: - Muting the system is recommended when a new clock source is chosen. - For normal operation, SCLK—not RCO—must be used (SCLK\_PRESENT = 1) for running the ASP data path. ### 4.7.1.1 Switching from RCO With SCLK running, an SCLK\_PRESENT 0-to-1 transition starts a switch from the RCO to the selected SCLK or PLL. This switch is superseded by any outstanding I<sup>2</sup>C transactions. After the I<sup>2</sup>C stop condition is sent, the transition begins, taking 150 $\mu$ s to complete, during which time the system requires that no new I<sup>2</sup>C transactions be initiated. The next I<sup>2</sup>C transaction can begin after this 150- $\mu$ s delay. #### 4.7.1.2 Switching to RCO To stop SCLK, the system must revert to RCO clocking to ensure that I<sup>2</sup>C communications function properly. To power the RCO back up, SCLK\_PRESENT must be cleared before stopping SCLK. A 1-to-0 SCLK\_PRESENT transition generates a glitch-free mux switch timing from SCLK to RCO. SCLK must remain running during the transition and new I<sup>2</sup>C transactions must not be initiated for at least 150 $\mu$ s after an I<sup>2</sup>C stop is received. The next I<sup>2</sup>C transaction cannot begin until after this 150 $\mu$ s delay. Failure to account for this 150 µs delay could cause I2C communications to fail. ## 4.7.2 MCLK<sub>INT</sub> Sources The MCLK<sub>INT</sub> source is supplied directly from ASP\_SCLK/SWIRE\_CLK input pin or from the fractional-N PLL. MCLKDIV must be set according to the MCLK<sub>INT</sub> frequency, which must be set to either the 12-MHz region (11.2896–12.288 MHz) or the 24-MHz region (22.5792–24.576 MHz). Table 4-6 shows several examples. Table 4-4 lists further restrictions. MCLK<sub>INT</sub> Source MCLK\_SRC\_SEL (see p. 141) MCLKDIV (see p. 141) Nominal ASP\_SCLK/SWIRE\_CLK Pin Frequency ASP\_SCLK/ SWIRE\_CLK 0 0 12 MHz Fractional-N PLL 1 0 12 MHz 1 0 12 MHz 1 1 24 MHz Table 4-4. MCLK<sub>INT</sub> Source Restrictions MCLK<sub>INT</sub> is switched through internal glitchless clock muxing. Doing so during operation may cause audible artifacts, but does not put the device into an unrecoverable state. Therefore, it is recommended to mute the system for at least 150 $\mu$ s. If MCLK<sub>INT</sub> is sourced from the PLL, on-the-fly frequency changes to the source may cause the PLL to go out of phase lock with the clock source. To reduce the risk of audible artifacts, it is recommended to mute the system first. Any necessary configuration changes based on the new clock source frequency must occur before unmuting the system. Figure 4-21. MCLK INT Source Switching For proper internal Fs clocking, the INTERNAL\_FS and MCLKDIV bits must be configured, as shown in Table 4-4. MCLK<sub>INT</sub> (MHz) MCLKDIV (see p. 141) INTERNAL\_FS (see p. 134) Resulting Fs<sub>INT</sub> (kHz) 44.1 11.2896 12 0 0 48 12.288 0 1 48 22.5792 1 1 44.1 24 48 1 0 24.576 Table 4-5. Determining Fs<sub>INT</sub> **Note:** The control-port/advanced peripheral bus (APB) frequency is equal to the MCLK<sub>INT</sub> frequency. #### 4.7.3 Fractional-N PLL The CS42L42 has an integrated fractional-N PLL to support the clocking requirements of the internal analog circuits and converters. This PLL can be enabled or bypassed to suit system-clocking needs. The input reference clock for the PLL is the ASP\_SCLK/SWIRE\_CLK input pin. The reference clock frequency must be between 2.8224 and 25 MHz. The PLL can be configured for a wide range of combinations of SCLK and MCLK<sub>INT</sub>. PLL\_REF\_INV (see p. 144) can be used to invert the PLL reference clock. Table 4-6 lists common settings. | SCLK | MCLK_SRC_SEL | SCLK_PREDIV | PLL_DIV_INT | PLL_DIV_FRAC | PLL_MODE | PLL_DIVOUT | MCLKINT | PLL_CAL_RATIO | n [4] | |--------|---------------------------|---------------------------|--------------|---------------------------|--------------|---------------------------|---------|---------------|--------| | (MHz) | (see p. 141) <sup>1</sup> | (see p. 144) <sup>2</sup> | (see p. 152) | (see p. 152) <sup>2</sup> | (see p. 152) | (see p. 152) <sup>3</sup> | (MHz) | (see p. 152) | ,, , , | | 1.024 | 1 | 00 | 0xAC | 0x44 0000 | 01 | 0x10 | 11.2896 | 118 | 3 | | | 1 | 00 | 0xBB | 0x80 0000 | 11 | 0x10 | 12 | 125 | 3 | | | 1 | 00 | 0xC0 | 0x00 0000 | 11 | 0x10 | 12.288 | 128 | 3 | | 1.536 | 1 | 00 | 0x72 | 0xD8 0000 | 01 | 0x10 | 11.2896 | 118 | 2 | | | 1 | 00 | 0x7D | 0x00 0000 | 11 | 0x10 | 12 | 125 | 2 | | | 1 | 00 | 0x80 | 0x00 0000 | 11 | 0x10 | 12.288 | 128 | 2 | | | 1 | 00 | 0x7D | 0x00 0000 | 11 | 0x08 | 24 | 125 | 4 | | | 1 | 00 | 0x80 | 0x00 0000 | 11 | 0x08 | 24.576 | 128 | 4 | | 2.048 | 1 | 00 | 0x56 | 0x22 0000 | 01 | 0x10 | 11.2896 | 88 | 2 | | | 1 | 00 | 0x5D | 0xC0 0000 | 11 | 0x10 | 12 | 94 | 2 | | | 1 | 00 | 0x60 | 0x00 0000 | 11 | 0x10 | 12.288 | 96 | 2 | | 2.8224 | 1 | 00 | 0x40 | 0x00 0000 | 11 | 0x10 | 11.2896 | 128 | 1 | | | 1 | 00 | 0x40 | 0x00 0000 | 11 | 0x08 | 22.5792 | 128 | 2 | | 3 | 1 | 00 | 0x3C | 0x36 1134 | 11 | 0x10 | 11.2896 | 120 | 1 | | | 1 | 00 | 0x40 | 0x00 0000 | 11 | 0x10 | 12 | 128 | 1 | | | 1 | 00 | 0x40 | 0x00 0000 | 01 | 0x10 | 12.288 | 131 | 1 | | | 1 | 00 | 0x40 | 0x00 0000 | 11 | 0x08 | 24 | 128 | 2 | | | 1 | 00 | 0x40 | 0x00 0000 | 01 | 0x08 | 24.576 | 131 | 2 | | 3.072 | 1 | 00 | 0x39 | 0x6C 0000 | 01 | 0x10 | 11.2896 | 118 | 1 | | | 1 | 00 | 0x3E | 0x80 0000 | 11 | 0x10 | 12 | 125 | 1 | | | 1 | 00 | 0x40 | 0x00 0000 | 11 | 0x10 | 12.288 | 128 | 1 | | | 1 | 00 | 0x3E | 0x80 0000 | 11 | 0x08 | 24 | 125 | 2 | Table 4-6. Common PLL Setting Examples 11 80x0 24.576 0x00 0000 128 00 0x40 Table 4-6. Common PLL Setting Examples (Cont.) | | MCLK_SRC_SEL | SCLK_PREDIV | | PLL_DIV_FRAC | PLL_MODE | PLL_DIVOUT | MCLK <sub>INT</sub> | PLL_CAL_RATIO | n [4] | |---------------|---------------------------|---------------------------|--------------|---------------------------|----------|---------------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | (MHz) | (see p. 141) <sup>1</sup> | (see p. 144) <sup>2</sup> | (see p. 152) | (see p. 152) <sup>2</sup> | | (see p. 152) <sup>3</sup> | (MHz) | (see p. 152) | | | 4.00 | 1 | 00 | 0x2D | 0x28 8CE7 | 11 | 0x10 | 11.2896 | 1 | 1 | | | 1 | 00 | 0x30 | 0x00 0000 | 11 | 0x10 | 12 | | 1 | | 1 2 2 2 | 1 | 00 | 0x30 | 0x00 0000 | 01 | 0x10 | 12.288 | | 1 | | 4.096 | 1 | 00 | 0x2B | 0x11 0000 | 01 | 0x10 | 11.2896 | | 1 | | | 1 | 00 | 0x2E | 0xE0 0000 | 11 | 0x10 | 12 | | 1 | | 5 0 4 4 0 | 1 | 00 | 0x30 | 0x00 0000 | 11 | 0x10 | 12.288 | | 1 | | 5.6448 | 1 | 01 | 0x40 | 0x00 0000 | 11 | 0x10 | 11.2896 | | 1 | | | 1 | 01 | 0x40 | 0x00 0000 | 11 | 0x08 | 22.5792 | | 2 | | 6 | 1 | 01 | 0x3C | 0x36 1134 | 11 | 0x10 | 11.2896 | | 1 | | | 1 | 01 | 0x40 | 0x00 0000 | 11 | 0x10 | 12 | | 1 | | | 1 | 01 | 0x40 | 0x00 0000 | 01 | 0x10 | 12.288 | | 1 | | | 1 | 01 | 0x40 | 0x00 0000 | 11 | 0x08 | 24 | | 2 | | 0.444 | 1 | 01 | 0x40 | 0x00 0000 | 01 | 0x08 | 24.576 | | 2 | | 6.144 | 1 | 01 | 0x39 | 0x6C 0000 | 01 | 0x10 | 11.2896 | | 1 | | | 1 | 01 | 0x3E | 0x80 0000 | 11 | 0x10 | 12 | | 1 | | | 1 | 01 | 0x40 | 0x00 0000 | 11 | 0x10 | 12.288 | | 1 | | | 1 | 01 | 0x3E | 0x80 0000 | 11 | 0x08 | 24 | | 2 | | 0.0 | 1 | 01 | 0x40 | 0x00 0000 | 11 | 0x08 | 24.576 | | 2 | | 9.6 | 1 | 10 | 0x49 | 0x80 0000 | 01 | 0x10 | 11.2896 | | 1 | | | 1 | 10 | 0x50 | 0x00 0000 | 11 | 0x10 | 12 | | 2 | | | 1 | 10 | 0x50 | 0x00 0000 | 01 | 0x10 | 12.288 | | 2 | | | 1 | 10<br>10 | 0x49<br>0x50 | 0x80 0000<br>0x00 0000 | 01<br>11 | 0x08<br>0x08 | 22.5792<br>24 | | 2 | | | 1 | 10 | 0x50<br>0x50 | 0x00 0000 | 01 | 0x08 | 24.576 | | 3 | | 44 0000 | 1 | 10 | UXOU | 0000 0000 | UI | UXU8 | | | 3 | | 11.2896 | 0<br>1 | 10 | 0x40 | 0x00 0000 | <u> </u> | 0x08 | 11.2896<br>22.5792 | | 2 | | 40 | | - | 0x40<br>0x3C | | 11 | | 11.2896 | | | | 12 | 0 | 10 | UX3C | 0x36 1134 | 11 | 0x10 | 12.0000 | 120 | 1 | | | | 10 | 0x40 | 0x00 0000 | 01 | 0x10 | 12.0000 | 121 | 1 | | | 1 | 10 | 0x40<br>0x40 | 0x00 0000 | 11 | 0x10 | 24 | _ | 2 | | | 1 | 10 | 0x40<br>0x40 | 0x00 0000 | 01 | 0x08 | 24.576 | | 2 | | 12.2880 | 1 | 10 | 0x40<br>0x39 | 0x6C 0000 | 01 | 0x00 | 11.2896 | | 1 | | 12.2000 | 1 | 10 | 0x39<br>0x3E | 0x80 0000 | 11 | 0x10 | 11.2090 | | 1 | | | 0 | 10 | UXJL | 0.000 0000 | | 0.10 | 12.2880 | 90 96 98 88 94 96 128 128 120 128 131 118 125 128 150 80 82 150 107 109 128 131 118 128 120 131 118 125 128 130 131 118 125 125 128 131 118 128 131 118 125 125 128 131 118 128 131 118 125 125 128 131 118 125 125 128 131 118 125 125 128 131 118 125 125 128 131 118 121 150 80 82 150 107 109 128 131 118 121 150 80 81 111 118 125 125 128 131 131 131 138 125 120 128 131 131 131 131 131 131 131 131 131 13 | +- | | | 1 | 10 | 0x3E | 0x80 0000 | 11 | 0x08 | 24 | | 2 | | | 1 | 10 | 0x3E<br>0x40 | 0x00 0000 | 11 | 0x08 | 24.576 | | 2 | | 13 | 1 | 10 | 0x39 | 0xAB 52B5 | 01 | 0x00 | 11.2896 | | 1 | | 13 | 1 | 10 | 0x3B | 0x4B 32B3<br>0x13 B13B | 11 | 0x11 | 12 | | 1 | | | 1 | 10 | 0x3B | 0x13 B13B | 01 | 0x10 | 12.288 | | 1 | | 19.2 | 1 | 11 | 0x49 | 0x80 0000 | 01 | 0x10 | 11.2896 | | 1 | | 13.2 | 1 | 11 | 0x50 | 0x00 0000 | 11 | 0x10 | 12 | | 2 | | | 1 | 11 | 0x50 | 0x00 0000 | 01 | 0x10 | 12.288 | | 2 | | | 1 | 11 | 0x49 | 0x80 0000 | 01 | 0x10 | 22.5792 | | 2 | | | 1 | 11 | 0x50 | 0x00 0000 | 11 | 0x08 | 24 | | 3 | | - | 1 | 11 | 0x50 | 0x00 0000 | 01 | 0x08 | 24.576 | | 3 | | 22.5792 | 1 | 11 | 0x40 | 0x00 0000 | 11 | 0x00 | 11.2896 | | 1 | | 22.01 32 | 0 | 11 | 0.40 | 0,000,0000 | 11 | 0.10 | 22.5792 | 120 | + ' | | 24 | 1 | 11 | 0x3C | 0x36 1134 | 11 | 0x10 | 11.2896 | 120 | 1 | | _ <del></del> | 1 | 11 | 0x3C<br>0x40 | 0x00 0000 | 11 | 0x10 | 11.2090 | | 1 | | | 1 | 11 | 0x40<br>0x40 | 0x00 0000 | 01 | 0x10<br>0x10 | 12.288 | | 1 | | | 0 | | UX40<br>— | — UXUU UUUU | - 01 | UX 10 | 24 | | +-'- | | | 1 | 11 | 0x40 | 0x00 0000 | 01 | 0x08 | 24.576 | | 2 | | 24.576 | 1 | 11 | 0x40<br>0x39 | 0x6C 0000 | 01 | 0x08<br>0x10 | 11.2896 | | 1 | | 24.5/0 | | 11 | 0x39<br>0x3E | 0x80 0000 | 11 | 0x10<br>0x10 | 11.2896 | | | | | 1 | 11 | 0x3E<br>0x40 | 0x00 0000 | 11 | 0x10<br>0x10 | 12.288 | | 1 | | | 1 | 11 | 0x40<br>0x3E | 0x80 0000 | 11 | | 24 | | 1 | | | | | | | | 0x08 | | | 2 | | | 0 | _ | _ | _ | _ | _ | 24.576 | _ | 1 — | #### Table 4-6. Common PLL Setting Examples (Cont.) | | SCLK<br>(MHz) | MCLK_SRC_SEL<br>(see p. 141) <sup>1</sup> | SCLK_PREDIV<br>(see p. 144) <sup>2</sup> | PLL_DIV_INT (see p. 152) | PLL_DIV_FRAC<br>(see p. 152) <sup>2</sup> | PLL_MODE<br>(see p. 152) | PLL_DIVOUT (see p. 152) 3 | MCLK <sub>INT</sub><br>(MHz) | PLL_CAL_RATIO<br>(see p. 152) | n [4] | |---|---------------|-------------------------------------------|------------------------------------------|--------------------------|-------------------------------------------|--------------------------|---------------------------|------------------------------|-------------------------------|-------| | Ī | 26 | 1 | 11 | 0x39 | 0xAB 52B5 | 01 | 0x11 | 11.2896 | 111 | 1 | | | | 1 | 11 | 0x3B | 0x13 B13B | 11 | 0x10 | 12 | 118 | 1 | | | | 1 | 11 | 0x3B | 0x13 B13B | 01 | 0x10 | 12.288 | 121 | 1 | - 1. If MCLK\_SRC\_SEL = 0, the PLL is bypassed and can be powered down by clearing PLL\_START (see p. 151). - 2. Refer to the register description for the decode. - 3. The text following this table explains the use of PLL DIVOUT, shown by the example configurations in Section 4.7.3.1 and Section 4.7.3.2. - 4. The variable *n* represents the divide ratio. See Eq. 4-6. Powering up the PLL can be accomplished in several configurations. Table 4-6 shows example configurations; the sequences in Section 4.7.3.1 and Section 4.7.3.2 can be used as models. MCLK<sub>INT</sub> combinations not shown in Table 4-6 can be determined by Eq. 4-5: #### Equation 4-5. Configuring SCLK, MCLK<sub>INT</sub> Configurations $$\mathsf{MCLK}_{\mathsf{INT}} = \frac{\mathsf{SCLK}}{\mathsf{SCLK}_{\mathsf{PREDIV}}} \times \frac{(\mathsf{PLL}_{\mathsf{DIV}} \; \mathsf{INT} + \mathsf{PLL}_{\mathsf{DIV}} \; \mathsf{FRAC})}{(500/512 \; \mathsf{or} \; 1029/1024 \; \mathsf{or} \; 1)} \times \frac{1}{\mathsf{PLL}_{\mathsf{DIVOUT}}}$$ The internal PLL output must be between ~150 and ~300 MHz. The PLL\_DIVOUT value must be an even integer. To maximize flexibility in sample-rate choice, MCLK<sub>INT</sub> must be nominally 12 or 24 MHz. PLL\_CAL\_RATIO determines the operating point for the internal VCO. For most configurations, the default value gives proper performance. However, to keep the VCO within range, some scenarios require PLL\_CAL\_RATIO to be set during the PLL power-up sequence (see Section 4.7.3). Use Eq. 4-6 to calculate the proper VCO setting at PLL start-up: #### Equation 4-6. Calculating the PLL\_CAL\_RATIO $$PLL\_CAL\_RATIO = \frac{MCLKINT \times 32 \times SCLK\_PREDIV}{n \times SCLK}$$ The value of n in Eq. 4-6 is determined by the following: - If the result is less than or equal to 151, by default, n equals 1. - If the result is less than 151, use the result to determine the PLL CAL RATIO setting. - If the result is greater than 151, select another divide factor of *n* configurations for SCLK (where *n* = 2,3, ...). The result must be between 50 and 151 (see the power-up sequence in Section 4.7.3.2). Use the same *n* value to multiply PLL\_DIVOUT during the power-up sequence; see Step 2 in Section 4.7.3.1. The functional value must be restored (Step 8). The same is shown in both standard examples. #### 4.7.3.1 PLL Power-Up Sequence (Example: SCLK = 4.096 MHz and MCLKINT = 12.288 MHz) In this example, SCLK = 4.096 MHz and MCLKINT = 12.288 MHz. - 1. Set SCLK PREDIV to Divide-by-1 Mode (0x00). - 2. Set PLL\_DIVOUT to Divide-by-16 Mode (0x10). This reflects a value of *n* = 1, because the PLL\_CAL\_RATIO generated by Eq. 4-6 equals 96. See that the PLL\_DIVOUT entry for this configuration in Table 4-6 used a Divide-by-16 Mode (0x10). - 3. Clear the three fractional factor registers, PLL DIV FRAC (see Section 7.7.2). - 4. Set the integer factor, PLL\_DIV\_INT to 48 (0x30). - 5. Set the PLL Mode multipliers, PLL MODE to 11 to bypass both 500/512 and 1029/1024 factors (0x03). - 6. Set the PLL\_CAL\_RATIO to 96 (0x60, see Section 7.7.5). - 7. Turn on the PLL by setting PLL\_START (see p. 151). - 8. As part of a standard sequence, after at least 800 $\mu$ s, the PLL\_DIVOUT value would need to restored to 16 (0x10), which is unnecessary here because that value did not change. # 4.7.3.2 PLL Power-Up Sequence (Example: SCLK = 12 MHz and MCLKINT = 24 MHz) In this example, SCLK = 12 MHz and MCLK<sub>INT</sub> = 24 MHz. - 1. Set SCLK PREDIV to Divide-by-4 Mode (0x02). - 2. Set PLL\_DIVOUT to Divide-by-16 Mode (0x10). This reflects a value of *n* = 2, because the PLL\_CAL\_RATIO generated by Eq. 4-6 was greater than 151. See that the PLL\_DIVOUT entry for this configuration in Table 4-6 used a Divide-by-8 Mode (0x08). - 3. Clear the three fractional factor registers, PLL DIV FRAC. - 4. Set the integer factor, PLL DIV INT to 64 (0x40). - 5. Set the PLL mode multipliers, PLL MODE to 11 to bypass both 500/512 and 1029/1024 factors (0x03). - 6. Set the PLL CAL RATIO to 128 (0x80). - Turn on the PLL by setting PLL\_START. - 8. After at least 800 μs, the PLL DIVOUT value must be restored from 16 to 8 (0x08). ### 4.7.3.3 Nonstandard PLL Setting (Example: SCLK = 19.2 MHz and MCLKINT = 12 MHz) In this example, SCLK = 19.2 MHz and MCLK<sub>INT</sub> = 12 MHz. (Note that a power-up sequence similar to Section 4.7.3.2 is required for this configuration due to n = 1.) - SCLK = 19.2 MHz = available reference clock. - MCLK<sub>INT</sub> = 12 MHz = desired internal MCLK. - SCLK PREDIV = 11 = divide SCLK by 8 as reference to PLL. - PLL\_DIV\_INT = 0x50 = multiply reference clock by 80, yielding PLL out = 192 MHz. - PLL DIV FRAC = 0x00 0000 = fractional portion equal to zero. - PLL MODE = 11 = 500/512 and 1029/1024 multipliers are bypassed. - PLL\_DIVOUT = 0x10 = divide PLL out by 16 to achieve MCLK<sub>INT</sub> of 12 MHz. Table 4-7 shows nonstandard PLL configurations. Table 4-7. Nonstandard PLL Settings | SCLK<br>(MHz) | MCLK_SRC_SEL<br>(see p. 141) | SCLK_PREDIV<br>(see p. 144) | PLL_DIV_INT (see p. 152) | PLL_DIV_FRAC<br>(see p. 152) | PLL_MODE (see p. 152) | PLL_DIVOUT (see p. 152) | MCLK <sub>INT</sub><br>(MHz) | PLL_CAL_RATIO<br>(see p. 152) | n [1] | |---------------|------------------------------|-----------------------------|--------------------------|------------------------------|-----------------------|-------------------------|------------------------------|-------------------------------|-------| | , | (See p. 141) | (See p. 144) | , | , , | (366 p. 132) | (366 p. 132) | , , | (See p. 132) | | | 9.6 | 1 | 10 | 0x6E | 0x40 0000 | 01 | 0x18 | 11.2896 | 75 | 1 | | | 1 | 10 | 0x50 | 0x00 0000 | 11 | 0x10 | 12 | 80 | 1 | | | 1 | 10 | 0x50 | 0x00 0000 | 01 | 0x10 | 12.288 | 82 | 1 | | | 1 | 10 | 0x6E | 0x400000 | 01 | 0x0C | 22.5792 | 150 | 1 | | | 1 | 10 | 0x50 | 0x00 0000 | 11 | 0x08 | 24 | 80 | 2 | | | 1 | 10 | 0x50 | 0x00 0000 | 01 | 0x08 | 24.576 | 82 | 2 | | 19.2 | 1 | 11 | 0x6E | 0x40 0000 | 01 | 0x18 | 11.2896 | 150 | 1 | | | 1 | 11 | 0x50 | 0x00 0000 | 11 | 0x10 | 12 | 80 | 2 | | | 1 | 11 | 0x50 | 0x00 0000 | 01 | 0x10 | 12.288 | 82 | 2 | | | 1 | 11 | 0x6E | 0x40 0000 | 01 | 0x0C | 22.5792 | 150 | 2 | | | 1 | 11 | 0x50 | 0x00 0000 | 11 | 0x08 | 24 | 107 | 3 | | | 1 | 11 | 0x50 | 0x00 0000 | 01 | 0x08 | 24.576 | 109 | 3 | <sup>1.</sup> The variable *n* represents the divide ratio. See Eq. 4-6. As shown in Fig. 4-22, the input to the PLL is the ASP\_SCLK/SWIRE\_CLK input pin. Figure 4-22. Clocking Architecture ## 4.7.3.4 Powering Down the PLL To power down the PLL, clear PLL START. ### 4.8 SoundWire Interface The MIPI-compliant SoundWire slave interface transports control and audio data. The external SoundWire master interface communicates with the CS42L42 SoundWire slave using SWIRE\_SD and SWIRE\_CLK (described in Table 1-1), which are shared with all devices on the SoundWire bus. The interface is an alternative to the ASP and I<sup>2</sup>C interfaces for audio and control-data transfer. SoundWire allows connection of all compatible audio sources and audio sinks over a single two-wire connection. The system includes the following features: - Transporting payload, control, and setup data on a single two-wire interface - Double data rate (DDR) transmission - · Direct slave-to-slave data transport - · Isochronous and asynchronous audio streams - Asynchronous wake events can be generated as part of Clock Stop Mode See the MIPI SoundWire Specification for details regarding features such as framing and synchronization. # 4.8.1 Physical Interface and Data Encoding The SoundWire interface has two logical signals: - SWIRE\_CLK—A system clock signal that is distributed from the master. - SWIRE\_SD—Data signal that can be driven by master or slave. The interface uses conventional single-ended voltage-level signaling. The data encoding is modified NRZI, where an unchanging physical value (i.e., an encoded logic zero) is not actively driven, but is maintained by a bus keeper within the master. The bus keeper facilitates detection of undriven bit-symbol periods to identify errors and to handle systems that are not fully populated. DDR signaling halves the required frequency of the clock signal, which reduces overall system power consumption. ### 4.8.2 Frame Structure A SoundWire bit stream is a continuous stream of bits encoded using the modified-NRZI scheme. The bit stream is divided into a repetitive sequence of blocks of bits (i.e., *frames*). A frame consists of bit-symbol periods (i.e., *bit slots*) that correspond to one-half cycle of the clock signal. Each frame is constructed as a two-dimensional array of these bit slots made from 48 to 256 rows with 2 to 16 columns. The number of rows and columns is programmable. This provides a simple way to identify periodic positions within the bit stream to multiplex data from multiple sources. Fig. 4-23 shows examples of frame organization. 12 MHz, 10 columns, 50 rows, 48 kHz framerate COL 3 5 6 8 9 0 1 2 4 7 GAP 7x2 GAP 1x2 192 kHz LEFT 96 kHz 4x6 LEFT 2x12 192 kHz RIGHT 16 kH<sub>7</sub> kHz 3 CH LEFT LEFT 192 kHz LEFT 1x24 1x24 4x6 96 kHz RIGHT 2x12 192 kHz RIGHT CMD 4x6 Mbit 1x48 PDM 192 kHz LEFT 1x50 4x6 96 kHz LEFT 2x12 192 kHz RIGHT 16 48 4x6 kHz kHz 3 CH RIGHT 192 kHz LEFT RIGHT 1x24 1x24 4x6 96 kHz RIGHT 2x12 192 kHz RIGHT GAP 1x2 Figure 4-23. Examples of SoundWire Frame Payload Organization Rows and columns are numbered from zero upwards. The transmission sequence of bit slots is done by an increasing order of rows, and, within each row, an increasing order of columns. The bit slots can be identified with a notation of [<Row>,<Column>]. Thus the first bit of a frame is [0,0], followed by [0,1], [0,2], up to [MaxRow,MaxCol]. The values on successive bit slots form a bit stream that interleaves all of the following: - · Control bits from the master - · Command bits from the master or monitor, and corresponding response bits from slaves or master - · Status bits from the slaves - Payload data that can be transferred master to slave, slave to master, or slave to slave. ## 4.8.3 Control Word A control word occupies the first 48 bits of Column 0 in any frame. Remaining bits of the frame not occupied by the control word are available for payload data. There are many options for organizing the payload data amongst the various channels and devices in the system. The control word is a 48-bit field in every SoundWire frame used by the master to read or write registers, control operations, and query slave status. It also provides frame synchronization information used by the slaves to keep in sync with the SoundWire Bus. The control word is split into multiple fields. There are three types of commands: - Ping—Every slave attached to the bus returns its status. The master sends a ping in any frame that is not performing a read or write command. - Write—Writes an 8-bit value from the command owner to one or more registers in one or more devices. - Read—Reads an 8-bit value from a register in one or more devices. Each control word field has an owner, defining which device can drive the bus during that bit slot. Some slots have multiple owners. This multiple ownership uses the modified NRZI scheme to avoid bus contention. For example, if multiple slaves assert PREQ (ping request, see Table 4-6) to pass a Logic 1 symbol by toggling the data pin in the same bit slot, all drivers on the bus are driving the data to the same value, so there is no contention. Attached slaves not asserting PREQ pass a Logic 0 symbol by not driving the bus, so there is no contention if other slaves assert PREQ at the same time. Fig. 4-24 shows field assignments for each command. Table 4-8 lists similar information, with explanations for each field. | В | it | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |--------------|--------------------------------|-----------------|-----------------|-----------------------------------|------------------|-----------------------------|-----------------------|-----------------------------|------------------------|------------------|-------------------------------------------------------------------------|-------|------------------|-----------------------|---------------------------|--------------------|---------| | Command | Ping | PREQ | Cor | PCODE[2<br>mmand ov<br>ster or Mo | /ner | _ | SSP<br>Master<br>Only | BREQ<br>Attached<br>monitor | BREL<br>Master<br>Only | | SlvStat_11[1:0] SlvStat_10[1:0] SlvStat_9[1:0] Slave 10 Slave 9 | | | | SlvStat_8[1:0]<br>Slave 8 | | | | | Read<br>Write | | | | | Commar | | dr[3:0]<br>(master or | monitor) | | | Comma | RegAdend owner ( | dr[15:8]<br>(master o | monitor) | | | | | Reserved Five reserved opcodes | | | | | | | - | _ | | | | | | | | | | В | it | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | Command | Ping | SlvStat<br>Slav | _7[1:0]<br>/e 7 | | :_6[1:0]<br>ve 6 | | SlvStat_5[1:0] | | | | | | | ync[7:0]<br>er Only) | | | | | | Read<br>Write | | | Comman | | ddr[7:0]<br>(Master or | Monitor) | | | | 0 | 4 | 4 | 0 | 0 | 0 | , | | <del> </del> | Reserved | | | | - | _ | | | | 1 | 0 | 1 | 1 | 0 | 0 | 0 | | | В | it | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | | Command | Ping | PHY_<br>SYNC | SlvStat<br>Sla | t_3[1:0]<br>ve 3 | SlvSta<br>Sla | t_2[1:0]<br>ve 2 | SlvSta<br>Sla | t_1[1:0]<br>ve 1 | SlvStat<br>Slav | t_0[1:0]<br>ve 0 | . 29.141111009110[0.0] 1 41.15 1 11.11 | | | | NAK<br>Master, | ACK<br>Master, | | | | Read | (Master | | | | ata[7:0] Addressed Slave(s) | | | (Master Striy) | | | | or<br>Monitor | Slave, | Slave, | | | | | Write | Only) | | RegDa | ata[7:0] C | ommand ( | Owner (M | aster or M | onitor) | | | | | | IVIOTILO | Monitor or Monitor | Monitor | | Reserved - | | | | | | | | | | | | | | | | | | Figure 4-24. Control Word Bit Assignments Bit 0 is the first bit transferred in the bit stream. If a field spans multiple bit slots, the most significant bit is sent first. For example, in Fig. 4-24, OPCODE[2] corresponds to Bit 1 (bit slot[1,0]), OPCODE[1] corresponds to Bit 2 (bit slot[2,0]), and so on. The monitor arbitrates for control of some fields of the command using the BREQ bit slot, which allows it to become the current command owner. The master acknowledges that it is giving up the bus through the BREL bit slot. The modified NRZI scheme ensures that, if neither the master nor monitor drive the command, the data pin is unchanged, causing OPCODE to be read as 000 (the Ping command). If the monitor drops off or releases the bus, it results in a frame with a Ping command but no BREQ; the master should react by regaining control on the next frame. The slave is not involved with, and is unaffected by, the identity of the command owner. Table 4-8 describes control-word bit slot fields. Table 4-8. Control Word Bit Slot Fields | Field | Command | Bit Slot Owner | Description | |-----------------------------|----------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PREQ | All | All attached slaves | Any attached slave can assert a ping request during this bit slot to notify the master of interesting status in Slv_Stat_x[1:0]. The master must perform a Ping command within 32 frames of the request. | | OPCODE[2:0] | All | Command owner | Identifies the type of command. Values not shown are reserved. 000 Ping 010 Read 011 Write | | BREQ | Ping | Monitor | Bus request from monitor requesting ownership of command fields in subsequent frames | | BREL | Ping | Master | Bus release from master acknowledging that monitor has ownership of command fields in subsequent frames. | | SSP | Ping | Master | Stream synchronization point. Setting SSP forces all active ports to synchronize their sample interval counters to the SoundWire frame boundary. | | SivStat_x[1:0] $(X = 0-11)$ | Ping | Slave with<br>DevID = X | Each slave has a unique 2-bit field to report status. 00 Slave not present or not attached. 01 Slave attached but not in an interrupt condition. 10 Slave attached and in an interrupt condition. 11 Reserved | | DevAddr[3:0] | Read/<br>Write | Command owner | Device address identifying which master or slaves are being accessed by the command, 0 Devices first attach as Device 0 1–11 Enumerated slaves are assigned a value in the range 12–13 Slaves can be programmed to also respond to these group addresses. 14 Reserved 15 Group alias to all slaves on the bus. | | Field | Command | Bit Slot Owner | Description | |------------------|----------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | RegAddr[15:0] | Read/<br>Write | Command owner | Register address identifying which register is being accessed by the command. Bits 14:0 contain the address. Section 4.8.9 describes how RegAddr is formed. | | RegData | Read | Addressed slave | Register data sent from the addressed device (slave or master) to command owner (master or monitor) | | RegData | Write | Command owner | Register data sent from command owner (master or monitor) to the addressed device (slave or master) | | StaticSync | All | Master | Fixed pattern 1011_0001 that facilitates the slave synchronizing to the bit stream and determining frame shape. | | PhySync | All | Master | Identifies whether the physical layer interface is running in Basic PHY or High PHY Mode. 0 Basic PHY This device supports only Basic PHY. 1 High PHY | | DynamicSync[3:0] | All | Master | Cyclic pattern that facilitates the slave synchronizing to the bit stream and determining frame shape. | | PAR | All | Command owner | Parity checksum generated by the owner of the command fields (master or monitor), checked by the other interfaces (slave, and monitor or master). | | NAK | All | All attached devices | Negative acknowledge | | ACK | All | All attached devices | Positive acknowledge | # 4.8.4 Register Access Response The SoundWire slave provides a response to each command in the Control Word NAK and ACK fields. A component of the response is derived from the result of the register access command, as listed in Table 4-9. Table 4-9. Command Response | Command<br>Response<br>(Priority Order) | | ACK | SoundWire<br>Address Range<br>(RegAddr[15:0]) | Conditions | | | | | | | | | | |-----------------------------------------|---|-----|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | COMMAND_ | 1 | 0 | All | Parity error | | | | | | | | | | | FAIL | | | | A bus clash is detected in the Control Word, except for shared bits: PREQ, NAK, ACK, and shared group read data or slave status (when DevAddr = {0,12,13,15}) where bus clash is expected and not reported. | | | | | | | | | | | | | | 0x1000–0xFFFF | APB bridge access is rejected because the bridge was busy with a previous access and could not accept a new one. Section 4.8.12 describes the APB. | | | | | | | | | | | | | | | <b>Note:</b> This behavior is not compliant with the <i>The MIPI SoundWire Specification 1.0</i> . | | | | | | | | | | | COMMAND_ | 0 | 0 | All | Slave is not attached to the SoundWire Bus. | | | | | | | | | | | IGNORED | | | | Response to a Ping command | | | | | | | | | | | | | | | Response to reserved opcodes | | | | | | | | | | | | | | | Response to Read/Write command whose DevAddr value does not address this slave | | | | | | | | | | | | | | 0x0000-0x0FFF | Access to an address where no register is implemented, including any register address associated with the unimplemented data ports (Ports 4–14). | | | | | | | | | | | | | | | Read from address containing only write-only register bits. | | | | | | | | | | | | | | | Write to address containing only read-only register bits | | | | | | | | | | | | | | | Read from Port 15 group alias | | | | | | | | | | | | | | | Read of any slave control port (SCP) device ID register if the slave is out of enumeration | | | | | | | | | | | | | | | Write to the SCP device number register if the slave is out of enumeration | | | | | | | | | | | COMMAND_ | 0 | 1 | 0x0000-0x0FFF | A read or write access to an existing register is not constrained by the conditions above | | | | | | | | | | | OK | | | 0x1000–0xFFFF | An APB bridge access was accepted and a COMMAND_OK response acknowledges that<br>the internal memory access has begun. This response does not convey whether the access<br>was to an implemented address or whether the address is valid for the command. | | | | | | | | | | | | | | | <b>Note:</b> For accesses within the range 0x1000–0x1FFF, the COMMAND_OK response is specific to the CS42L42. <i>The MIPI SoundWire Specification 1.0</i> requires a COMMAND_IGNORED response to be returned instead of the COMMAND_OK. | | | | | | | | | | A command response to register access restrictions does not depend on the data value being written, but is governed by whether the read or write access is allowed to that address. Writing an unsupported value to a register address does not cause the write command to be rejected. If multiple entries of Table 4-9 apply to the same SoundWire frame, any condition that triggers a COMMAND\_FAIL overrides a COMMAND\_IGNORED or COMMAND\_OK. Conditions that trigger a COMMAND\_IGNORED override conditions that trigger COMMAND\_OK. # 4.8.5 Frame Synchronization On initialization, the CS42L42 is unattached, makes no assumptions about frame size, does not react to control words, and does not drive values on the data pin. Instead, it performs a search for the static and dynamic sync words within the control word to determine the size of the frame and identify the frame boundaries before attaching to the SoundWire bus. When synchronization is confirmed, the CS42L42 attaches to the SoundWire bus with device number = 0 and waits for the master to perform the slave enumeration sequence to assign a unique nonzero device number. If attached to the SoundWire Bus, the CS42L42 constantly monitors the static and dynamic synchronization words of each frame to verify it is still in sync with the bus. If the CS42L42 detects two bit errors in the synchronization words within two SoundWire frames, it drops off the SoundWire bus and becomes unattached. The device then restarts its frame synchronization search to resynchronize to the SoundWire bus. ### 4.8.6 Slave Enumeration The CS42L42 initially attaches to the bus with a device number of zero (Slave0). Because multiple slaves can do so simultaneously, the master must perform an enumeration process to assign each a unique nonzero device number before the slave can be used. The master determines that a slave has attached as Slave0 through the SlvStat\_0 control word status bits. The master then begins reading the six slave control port (SCP) device ID registers in sequence (0x0050–0x0055). To account for possible multiple CS42L42 devices on the same bus, the AD0 and AD1 pins respectively determine the Instance ID bits [1:0] for each device. Note that AD0/AD1 pin values are latched on reset. Enumeration relies on the modified-NRZI bus property that one slave's Logic 1 overrides another slave's Logic 0 on the data bus. If a Slave0 detects a bus clash where its read data value of Logic 0 was overridden by another slave's Logic 1, it drops out of this enumeration sequence. At the end of the sequence, only one slave remains, to which the master assigns a unique, nonzero device number. Slave0 devices that fell out of the enumeration sequence do not respond to the attempt to set a device number until after a new sequence begins, starting with a read of the SCP device ID 0 register. Slaves out of enumeration also do not respond to reads of the device ID registers. After a slave is enumerated, and if SlvStat\_0 indicates remaining attached slaves, the master should repeat the sequence to enumerate remaining slaves. # 4.8.7 Payload Transport This section describes how payload data is organized within a SoundWire frame and the control registers that define where each port's payload data is located in the frame. Fig. 4-25 shows examples of how the data is positioned. Figure 4-25. Examples of Register Settings Defining a Port's Payload Data Location Basic parameters in Fig. 4-25 include the following: - SINTERVAL—Defines the sample interval in units of bit slots. - HSTART and HSTOP—Define the column boundaries of the transport window. - OFFSET—Defines the offset in units of bit slots from the start of the transport window where the data is located. - WORD LENGTH—Number of bits in each channel minus 1. Additional parameters are described in the SoundWire register descriptions in Section 7.1 and Section 7.2. - Payload channel sample—Refers to one sample per channel per sample interval. - Payload data block refers to blocks of data within a frame, as controlled by BLOCK\_PACKING\_MODE (see p. 132) and shown in Fig. 4-26: - Blocks-per-Channel Mode—Each payload data block contains one channel sample. There may be multiple payload data blocks per frame, each containing a sample from a different channel. - Blocks-per-Port Mode—One block for the port in the frame contains all the port's channel samples concatenated. Figure 4-26. Block Packing Mode Payload window—A contiguous set of columns in the frame, within which data is transferred for the respective port defined by the HSTART/HSTOP fields. Transport windows may overlap, with different data streams transferred in different bit slots. The payload subwindow is the subset of a payload window where the port's data resides, as controlled by the block-spacing mode. - · There are two types of payload data: - Normal payload (isochronous payload streams) - Flow-controlled (asynchronous payload streams)—Not supported on the CS42L42. # 4.8.8 Prepare/Enable Control The programming model of the state diagram of Fig. 4-27 must be followed to enable each channel within a port. This requires the following procedure to enable the channel: - 1. The master first prepares a channel by setting the channel's PREPARE\_CHANNELx register bit (see p. 130). If the channel is running and ready to transfer data on the SoundWire bus, data-path logic within the chip sets the input port STAT PORT READY (see p. 128). This value is reflected in the DPn prepare status register (see p. 130). - 2. The master waits until it reads the corresponding NOT FINISHED CHANNELx status bit (see p. 130) as cleared. - 3. The master sets the CHANNEL ENx bit (see p. 130) of the inactive bank. - 4. Master initiates a bank switch to enable the channel set in Step 3 by writing to the inactive bank SCP frame control register. - 5. Data transfer on the SoundWire bus begins in the next frame after the bank switch. It would be invalid programming for the master to set CHANNEL\_EN without waiting for the DPn\_PREPARE\_STATUS bit to indicate that the channel is ready for operation. Operation cannot be guaranteed in this case. - "NF" is the channel's NOT\_FINISHED status bit (see Section 7.2.5). - "P" is the channel's PREPARE\_CHANNELx bit (see Section 7.2.6). Figure 4-27. Prepare/Enable Control # 4.8.9 SoundWire Memory Map The SoundWire protocol specification requires some device-level register address blocks for each control/data port. Each port has a reserved address window, within which some register spaces are defined by the MIPI SoundWire Specification and others are implementation specific. Table 4-10 lists base addresses for the SoundWire control and data ports implemented on the CS42L42. Table 6-1 shows how the SoundWire register space fits into the CS42L42 register map. The "Page" value of Table 6-1 maps to the address field (RegAddr[15:0]) of SoundWire read/write commands as follows: - RegAddr[15] = Context switch between internal SoundWire registers and the non-SoundWire registers accessed using nonzero page values. - 0 = SoundWire register access - 1 = Advanced peripheral bus (APB, or "Page") register access - RegAddr[14:8] = 7 LSB bits of the 8-bit "Page" value from Table 6-1 (Page[7:0]) - RegAddr[7:0] = 8-bit register address For example, to access the register at page = 0x14 and address = 0x02, the SoundWire RegAddr[15:0] would be 0x9402 Port Number Port Name Base Address Notes 0 Control Port 0x0000 Control and status functions common to the whole slave Data Port 1 0x0100 1 Control and status functions specific to Data Port 1 (ADC output channel) Data Port 2 0x0200 Control and status functions specific to Data Port 2 (DAC channels) 2 3 Data Port 3 0x0300 Control and status functions specific to Data Port 3 (S/PDIF input channels) 4-14 Data Ports 4-14 0x0400-0x0EFF Reserved 15 Data Ports 1-14 0x0F00 Addressing alias used to write to Data Ports 1–14 with a single write command Table 4-10. Base Addresses for Data Port Registers # 4.8.10 Register Banking Some registers in the control and data ports are banked, meaning that there are two copies that can be accessed through different addresses. A bank switch to all SoundWire slaves connected to the master can be performed simultaneously using a device address = 15 group alias in the SoundWire control word. The banking mechanism allows the SoundWire master to set up new configurations in advance in the inactive register bank and then command all the slaves to change to that configuration simultaneously. This mechanism is required to apply changes simultaneously in frame shape or payload transport configurations to all slave devices on the SoundWire bus. Changing banked register values in the active bank for some registers can cause unpredictable behavior (e.g., changing payload location in the middle of the frame). When updating banked registers, the bank switch mechanism must be used to apply the changes on the next frame boundary. #### 4.8.10.1 Bank Switch Bank switching allows the master to change which of two register banks is active. This mechanism is used to enable channels, change the SoundWire frame size, or rearrange payload data for all slaves and all ports at the same moment. If any ports have a sample interval that spans multiple SoundWire frames, to avoid audio glitches, a bank switch must be applied on a frame boundary that is also a stream-synchronization point (SSP). The bank change is performed by writing to the SCP frame control register (see Section 7.1.12) in either Bank 0 or Bank 1. It can be performed to all slave devices at once using the DevAddr = 15 group alias in the control word. The recommended procedure to perform a bank switch while the data port is enabled and streaming is as follows: - 1. Update configuration registers in the inactive bank of all active SoundWire ports with new configuration. If a setting must remain the same, the inactive bank register must be programmed to the same value as the active bank. - 2. In the frame preceding a normal SSP alignment, using the device address = 15 alias to all SoundWire slaves, write to the inactive bank's SCP frame control register in either Bank 0 or Bank 1. This write causes the bank change to occur on the next SoundWire frame boundary to the bank whose SCP frame control register was written. ## 4.8.11 SoundWire Data Port Map Port 0 functions as SCP, which provides control for the slave. Section 6.1 lists each data port's registers, Table 4-10 lists the base addresses. Table 4-11 shows data-port mapping. Data Port Resource Channel 2 Channel 1 Port 1 ADC — Channel A Port 2 DAC Channel B Channel A Port 3 S/PDIF Channel B Channel A Table 4-11. Data Port Mapping Table 4-12 describes the supported read/write characteristics for SoundWire bit fields. | Type | Abbreviation | Description | |---------------------|--------------|-------------------------------------------------------------------------------| | Read/Write | R/W | Register value can be read or written by software | | Read/Write/Modified | RWM | Register value can be read or written by software, or modified by hardware. | | Read Only | R/O | Read-only status register, can be read but not written by software. | | Write One to Clear | R/W1C | Status register is cleared by software writing 1 to the bit. | | Write Only | W/O | Write-only bits trigger an action when written, but its value cannot be read. | Table 4-12. Register Bit Types # 4.8.12 Advanced Peripheral Bus (APB) Bridge Access Procedures Read/write commands to addresses 0x1000–0xFFFF outside the SoundWire IP pass through a translation bridge to the device's internal APB. The APB protocol and delays through the bridge do not allow the commands to complete within the SoundWire frame for all cases and require special procedures to perform read/write commands to this memory space. A consequence of the delay through the bridge is that register writes to locations outside the SoundWire IP are not aligned to a SoundWire frame boundary. Read-only status registers manage these transfers in the memory-access status and memory-read-last-address registers (see Section 7.1.17 and Section 7.1.20). If an access is attempted through the bridge before the previous transfer completes (indicated by CMD\_IN\_PROGRESS = 1, see p. 126), a COMMAND\_FAIL response is returned on the SoundWire bus. Otherwise, a COMMAND\_OK response is returned to acknowledge any other access through the bridge, regardless of whether the registers exist outside the SoundWire IP. By default, a timeout occurs after 8 bus cycles. TIMEOUT\_CTRL (see p. 127) can be used to extend this period. The period is 0 bus cycles if TIMEOUT\_DISABLE (see p. 127) is set. If issues arise in transferring information, unmasking M\_LATE\_RESP and M\_TIMEOUT\_ERR (see p. 126) allows timeout conditions to generate the corresponding interrupts. Section 4.8.12.2 and Section 4.8.12.3 describe procedures for accessing registers outside the SoundWire IP. These apply only to access to registers above address 0x1000. SoundWire registers within the address range 0x0000–0x0FFF can be accessed directly without special procedures. #### 4.8.12.1 Indirect versus Direct Access Procedures Depending on system configuration, there are two ways of access through the APB master. Both add access latency: - Indirect access: APB read data cannot be returned in time to be part of the control word RegData response field. Read data must be read from MEM\_READ\_DATA (see p. 128) later, as described in subsequent sections. - Direct access: APB read data can be returned in time to be included in the RegData response field of the control word. For direct access, no special procedures are required. Whether an access must use the indirect or direct procedure depends on operating parameters, such as the following: - The ratio of clock frequencies between the SoundWire and APB clocks. The control port/APB frequency is equal to the MCLK<sub>INT</sub> frequency. - Whether any APB slaves add wait cycles to the APB access. - The number of columns in the SoundWire frame. More columns in the frame allow more time for the APB access to complete in time to return data within a single SoundWire read command. Indirect access procedures are avoided if the access can be guaranteed to work with direct access. This is possible when the following relation evaluates as TRUE: Time in SoundWire command between the last Address bit and first RegData bit (10 rows) Internal time required to process the APB read command (including synchronization delay) The elements of this relation are calculated as follows: SoundWire clock period \* 10 Rows \* (Number of columns)/2 4.75 SoundWire Clock Periods + 4.25 APB clock periods + APB clock periods clock periods for wait cycles added by APB slave (if needed) To avoid issues occurring on the edge of the maximum delay, the 0.25 \* clock period provides margin. The number of APB cycles added due to wait states depends on the access desired. The only access requiring extra wait states is the reading and writing of EQ coefficients. For this function, indirect access must be used. However, for all other access functions, no extra APB wait states are required and direct access is allowed. The examples in Table 4-13 show how to use the calculation to determine whether direct access is allowed. Table 4-13. Direct- and Indirect-Access Comparison | | Example A | Example B | Example C | Example D | Example E | | |------------------------------------------|---------------------------------------|------------------------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------------|--------------------------------------------------------|--| | Parameters | Direct Access | Indirect Access— Example A with APB clock frequency halved | DirectAccess—Double<br>the columns in<br>Example B | Indirect Access—<br>Example A, APB slave<br>requests wait state | Direct Access— Example D, increasing number of columns | | | Frame size | 48 row x 2 column | 48 row x 2 column | 48 row x 4 column | 48 row x 2 column | 48 row x 4 column | | | Wait state | Always zero wait-state access on APB. | Always zero wait-state access on APB. | Always zero wait-state access on APB. | One wait state might be added to the APB. | One wait state might be added to the APB. | | | SoundWire clock frequency | SoundWire clock frequency = APB clock | SoundWire clock<br>frequency = 12 MHz | SoundWire clock<br>frequency = 12 MHz | SoundWire clock frequency = APB clock | SoundWire clock<br>frequency = APB clock | | | APB clock<br>frequency <sup>1</sup> | frequency. | APB clock = 6 MHz (APB period = 2*SoundWire clock period) | APB clock = 6 MHz (APB period = 2*SoundWire clock period) | frequency. | frequency. | | | Time for 10 rows to run on SoundWire bus | 10*2/2 = 10 SoundWire clock cycles. | 10*2/2 = 10 SoundWire clock cycles. | 10*4/2 = 20 SoundWire clock cycles. | 10*2/2 = 10 SoundWire clock cycles | 10*4/2 = 20 SoundWire clock cycles. | | | Processing time | 4.75 + 4.25 = 9 | 4.75 + 2*4.25 = 13.25 | 4.75 + 2*4.25 = 13.25 | 4.75 + 4.25 + 1 = 10 | 4.75 + 4.25 + 1 = 10 | | | Outcome | Time for 10 rows > processing time. | Time for 10 rows < processing time. | Time for 10 rows > processing time. | Time for 10 rows ≤ processing time. | Time for 10 rows > processing time. | | | Direct access allowed? | Direct access allowed | Not guaranteed; indirect access must be used. | Direct access allowed | Not guaranteed; indirect access must be used. | Direct access allowed | | <sup>1.</sup> The control port/APB frequency is equal to the MCLKINT frequency. # 4.8.12.2 Control-Word Write through the APB Bridge The following procedure for writing data through the APB bridge is required only if indirect access procedures are used. This is not needed if direct access is available. - 1. Verify that a prior command is not still active on the bridge by polling the memory access status register (Section 7.1.17) until CMD\_IN\_PROGRESS = 0. - 2. Perform a SoundWire write command via control word to the desired address. The responses are as follows: - COMMAND OK: Acknowledges that the APB transaction was initiated. - COMMAND\_FAIL: If CMD\_IN\_PROGRESS = 1, a new write could not be accepted due to a previous command still in progress and a SoundWire command response of COMMAND\_FAIL is returned. - 3. (Optional) Confirm transaction completion by reading CMD\_DONE = 1 (see p. 127). ## 4.8.12.3 Control-Word Read through the APB Bridge (Indirect Access Only) This section describes how to read control words if indirect access is used. A register read requires two read commands because read data cannot be fetched in time for the SoundWire response in the same command. The attempt to read from memory (address above 0x1000) triggers the access to begin across the bridge, while returning an initial response to the SoundWire COMMAND\_OK command and a data value of zero. When the read operation completes, the RDATA\_RDY status flag is set (see p. 127), the read data is stored in the memory read data register, and the address from where the data was read is stored in MEM\_READ\_LAST\_ADDR (see p. 128). **Note:** This procedure must be an atomic operation; that is, system software must ensure that no other process interrupts. A read or write access to other addresses through the APB bridge during this procedure risks overwriting the read data captured in MEM\_READ\_DATA (see p. 128). The following procedure is for reading from a register through the APB bridge: - 1. Verify that the bridge is not still active with a previous command by polling the memory access status register until CMD IN PROGRESS = 0. - 2. Perform the SoundWire read command via control word to the desired address, as normal. - The SoundWire command returns response COMMAND\_OK to acknowledge the APB transaction was initiated, regardless of whether the register exists. - If CMD\_IN\_PROGRESS = 1, a new read could not be accepted and a SoundWire command response of COMMAND\_FAIL is returned. - 3. Poll the memory access status to verify the read transaction completed. (CMD\_DONE = 1 and RDATA\_RDY = 1). The address the data was read from is also stored in MEM\_READ\_LAST\_ADDR for optional reference. - 4. Read MEM\_READ\_DATA to return the data last read from the address stored in MEM\_READ\_LAST\_ADDR. ### 4.8.13 SoundWire Clock Stop Mode and Wake-Up Event The Clock Stop Mode provides a mechanism allowing the master to shut off the SoundWire clock. The flow to enter Clock Stop Mode is as follows: - 1. The CS42L42 does not automatically change any functional states when going through the clock-stop process. As a result, if any function needs to be shut down or reconfigured, the master must first send the appropriate commands to configure the device. - Clear SCLK\_PRESENT. When SCLK\_PRESENT transitions from 1 to 0, the RCO becomes the system's MCLK. In addition to the plug insertion/removal and S0 button press events, Note the following behavior under this condition: - To meet the RCO power-up latency requirement, SWIRE\_SCLK must remain present for at least 150 $\mu$ s before entering Clock Stop Mode. - 2. The SoundWire master writes to CLOCK STOP\_PREPARE (see p. 122) to begin the shutdown. - 3. The SW\_CLK\_STP\_STAT\_SEL setting (see p. 137) determines which functional blocks report as powered down before CLOCK\_STOP\_NOT\_FINISHED (see p. 122) is cleared. This ensures that the desired functions within the device are complete before clock stop can proceed. - 4. The CS42L42 clears CLOCK\_STOP\_NOT\_FINISHED to indicate it is ready for the clock to be stopped. - The master performs a group status read until all slaves report ready for the clock to be turned off (CLOCK\_ STOP\_NOT\_FINISHED = 0). - 6. The master performs a group write to CLOCK\_STOP\_NOW (see p. 122), indicating the clock is about to stop. - 7. Immediately after Step 6, the master sends a stopping frame. The master owns all payload bits and must drive the data pin on the last bit slot to a physical low level. The CS42L42 does not drive payload bits associated with data ports. - 8. The master stops the SoundWire clock at the frame boundary at the end of the stopping frame. **Note:** If WAKE\_UP\_ENABLE = 1 and SW\_CLK is stopped, an S0 button press, a headphone plug, or a headphone unplug can cause the SoundWire wake event to occur. CLOCK\_STOP\_NOT\_FINISHED = 1 indicates that the slave is not ready to be shut off. A value of 0 indicates the slave is ready for the clock to be shut off. This allows for group reads of all slave devices to report whether any slave is not ready for the shutdown due to the modified NRZI encodings. If WAKE\_UP\_ENABLE is set (see p. 122) while the SoundWire clock is stopped, the wake event signal is triggered to the master to wake the SoundWire bus. If the wake event occurs in Clock Stop Mode, SWIRE\_SD is asserted. After the wake event signal is triggered, SCLK\_PRESENT must be set to transition from 0 to 1 (that is, from the internal RCO to the SWIRE\_SCLK/PLL). The transition can take 150 $\mu$ S. If the PLL is used, SCLK\_PRESENT must wait for the PLL to settle. The last opportunity to send an interrupt during a clock-stop sequence is the PREQ of the frame that writes to CLOCK\_STOP\_NOW. If the internal wake event described previously occurs in either that frame or the stopping frame, the wake event signal is latched and stored. After the clock is stopped at the end of the stopping frame, a SoundWire wake-up event occurs. This ensures that no internal wake event is missed. A wake event is seen by the master as the next PREQ bit. Fig. 4-28 shows clock-off timing. # 4.8.14 Programming Restrictions The following restrictions must be observed: - For registers that are banked, operation is not guaranteed when writing to the active bank of a register. The SCP frame control register is the only banked register that supports writes to the active bank. - Configuration changes must not be done in an on-the-fly method—bank changes must be used. - To ensure that new register values are not applied in the middle of a sample interval, bank changes must correspond to the SSP. - Although the MIPI specification allows the master to assert an SSP at any time, the CS42L42 does not allow the assertion if the sample interval ends in the next-to-last bit slot of the SoundWire frame such that a new interval would start in the last bit slot of that frame (e.g., preceding the frame boundary where the SSP is applied). This rare scenario could happen in a system where the master and slaves are already out-of-sync and data is already corrupt. - Nonbanked register fields, PORT\_DATA\_MODE and WORD\_LENGTH, must not be modified if the port is enabled. # 4.8.15 Configuration Guidelines with Examples Ex. 4-3 and Ex. 4-4 describe configurations for programming three data ports for 48- and 96-kHz operations, each with 24-bit data. Data Port 1 has one 24-bit channel; Data Ports 2 and 3 have two channels each. Fig. 4-29 shows the resulting frame structure, with details for each port (HSTART, HSTOP, OFFSETS, and WORD\_LENGTH). For each data port, registers are programmed to indicate the location in the SoundWire frame where each payload data is stored. Each port must be configured with a location such that its payload location does not overlap another port. The SoundWire master must also be configured with the same settings for each port. Example 4-3, Sample Interval Rate: 48 kHz | | Example 4-0. Cample interval Nate: 40 Kinz | | | | | | | | | |----------------------|--------------------------------------------|-------------|-------------|--|--|--|--|--|--| | Parameter | Data Port 1 | Data Port 2 | Data Port 3 | | | | | | | | WORD_LENGTH 1 | 23 | 23 | 23 | | | | | | | | HSTART | 1 | 1 | 1 | | | | | | | | HSTOP | 7 | 7 | 7 | | | | | | | | OFFSET1 | 0 | 28 | 84 | | | | | | | | OFFSET2 | 0 | 0 | 0 | | | | | | | | Offset (combined) | 0 | 28 | 84 | | | | | | | | SAMPLE_INTERVAL_LOW | 255 | 255 | 255 | | | | | | | | SAMPLE_INTERVAL_HIGH | 1 | 1 | 1 | | | | | | | | Sample Interval | 512 | 512 | 512 | | | | | | | | Example 4-4 | 4. Sampie interv | ai Rate: 96 KHZ | |-------------|------------------|-----------------| | Data Port 1 | Data Port 2 | Data Port 3 | | 23 | 23 | 23 | | 1 | 1 | 1 | | 7 | 7 | 7 | | 0 | 28 | 84 | | 0 | 0 | 0 | | 0 | 28 | 84 | | 255 | 255 | 255 | | 0 | 0 | 0 | | 256 | 256 | 256 | Both examples have the same configuration—SoundWire clock = 12.288 MHz, 64 rows, 8 columns, 512 bits per frame, SoundWire frame rate = 48 kHz. Configuration details are summarized in Ex. 4-3 and Ex. 4-4. The WORD LENGTH is the number of bits minus 1 in each channel's sample per port. The HSTART and HSTOP values define the payload transport window, the columns in the SoundWire frame that bound the port's payload data. Both examples set HSTART = 1 and HSTOP = 7, so that the payload data is in Columns 1–7. To avoid overlap with the control word, Column 0 is not included. The OFFSETx fields define the number of bits within the payload transport window that the start of the sample is delayed from the sample interval boundary. Each port has a different offset to avoid overlap. Note that this example uses the Block-per-Port Mode. The definition of the offset registers would change if Block-per-Channel Mode were used. Although spaces appear between each port's payload, shown in different colors in Fig. 4-29, that spacing is not required. Both examples start with the SoundWire frame rate set to 48 kHz. Using a 12.288-MHz SoundWire clock, a 64 x 8 frame yields a 48-kHz SoundWire frame rate. Setting the sample interval (the time in units of bit slots defining the rate at which the port's data samples are transferred) to match the SoundWire frame rate, as shown in Ex. 4-3, yields a 48-kHz sample interval. There are two bit slots per SoundWire clock cycle. Other sample interval rates can be multiplied or divided from this sample rate without changing the same SoundWire frame rate. Note the following: - The sample interval and the frame can have different lengths. - The sample interval must be a multiple or divide factor from the SoundWire frame length. Note that this does not have to be an integer multiple, but rather a common multiple, where periodically the SoundWire frame boundary aligns to the sample interval boundary. The SSP is the point at which all sample interval boundaries of all ports in the system align to the same SoundWire frame boundary. - · Each port can have a different sample interval. The sample interval is calculated in units of bit slots according to the following formula: Sample Interval = 256 \* SAMPLE\_INTERVAL\_HIGH + SAMPLE\_INTERVAL\_LOW + 1. Setting SAMPLE\_INTERVAL\_HIGH = 1 and SAMPLE\_INTERVAL\_LOW = 255 results in a sample interval for a 48-kHz frame at 12.288 MHz of 512 bit slots. Note that this also coincides with a frame size of 64 x 8 = 512. <sup>1.</sup>WORD\_LENGTH is the number of bits in each channel minus 1. Table 4-14 describes using different sample intervals with SoundWire frame rate of 48 kHz: ### Table 4-14. Sample interval/Sample Rate Examples | Sample Interval | Sample Rate | |------------------------------------|----------------------------------------------------------------------------------------------------| | Length of the SoundWire frame | 48-kHz sample rate with one sample for each channel per frame. | | Half the SoundWire frame length | Two samples per frame for a 96-kHz sample rate. (see Ex. 4-4) | | Twice the SoundWire frame length | One sample every second frame for a 24-kHz rate. | | N times the SoundWire frame length | One sample every Nth frame, generating a 48/N-kHz rate. 8 kHz is the minimum rate for the CS42L42. | Running all ports with 44.1 kHz requires a different SoundWire clock or frame shape that matches 44.1 kHz along with adjusting other parameters accordingly. An 11.2896-MHz SoundWire clock with a 64 x 8 frame shape works well with a frame rate of 44.1 kHz. Note that this does not apply to isochronous streams, which are converted to 48 kHz before being sent to the SoundWire block. Figure 4-29. Configuration Examples for a 64 x 8 SoundWire Frame—SoundWire Frame Visualization # 4.9 Audio Serial Port (ASP) The CS42L42 has an ASP to communicate audio and voice data between system devices, such as application processors and Bluetooth transceivers. ASP\_SCLK\_EN (see p. 143) must be set whenever DAO and DAI are used. The ASP can be configured to TDM, I<sup>2</sup>S, and left justified (LJ) audio interfaces. **Note:** A maximum of four input channels and two output channels are supported in TDM Mode. Any two input channels can be mapped to SPDIF TX, and they always bypass the ASRC. Although two output channels exist, the information from Channel 1 is replicated onto Channel 2 when enabled (ASP\_TX\_CH2\_EN, p. 168). As a result, Channel 2 can be used only if Channel 1 is used. This is targeted for 50/50 use, but can be used in any transmit situation. Bit resolution must be the same for both channels (ASP\_TX\_CH2\_RES = ASP\_TX\_CH1\_RES) along with matching MSB/LSB bit starts (ASP\_TX\_CH2\_BIT\_ST\_MSB = ASP\_TX\_CH1\_BIT\_ST\_MSB and ASP\_TX\_CH2\_BIT\_ST\_LSB). However, in 50/50 Mode, the active phase for each channel must not match (ASP\_TX\_CH2\_AP ≠ ASP\_TX\_CH1\_AP). # 4.9.1 Slave Mode Timing The ASP can operate as a slave to another device's timing, requiring ASP\_SCLK/SWIRE\_CLK and ASP\_LRCK/FSYNC to be mastered by the external device. If ASP\_HYBRID\_MODE is cleared (see p. 143), the serial port acts as a slave. If ASP\_HYBRID\_MODE is set, the port is in Hybrid-Master Mode (see Section 4.9.2). In Slave Mode, ASP\_SCLK and ASP\_LRCK are inputs. Although the CS42L42 does not generate interface timings in Slave Mode, the expected LRCK and SCLK format must be programmed as it is in Hybrid-Master Mode. Table 4-17 shows supported serial-port sample rate examples. Note that some rates require use of the PLL and/or SRC. # 4.9.2 Hybrid-Master Mode Timing In Hybrid-Master Mode, ASP\_LRCK is derived from ASP\_SCLK; the ASP\_SCLK/ASP\_LRCK ratio must be N x $F_S$ , where N is a large enough integer to support the total number of bits per ASP\_LRCK period for the audio stream to be transferred. In either 50/50 Mode or I<sup>2</sup>S/LJ Mode, the ASP\_SCLK/ASP\_LRCK ratio must be N<sub>E</sub> x $F_S$ , where N<sub>E</sub> is an even integer. The serial port generates an internal LRCK/FSYNC from an externally mastered ASP\_SCLK/SWIRE\_CLK, allowing single clock-source mastering to the CS42L42. In Hybrid-Master Mode, the serial port must provide a left-right/frame sync signal (ASP\_LRCK/FSYNC) given an externally generated bit clock (ASP\_SCLK). Table 4-15 shows supported serial-port sample-rate examples. Other rates are possible, but the rules stipulated above must be met. Note that some rates require use of the PLL or SRC. | SCLK | | Serial Port Sample Rate (kHz) | | | | | | | | | | | | | | | | | |-----------------|-----|-------------------------------|--------|----|----|-------|--------|----|----|------|--------|----|------|--------|----|-------|---------|-----| | Frequency (MHz) | 8.0 | 11.025 | 11.029 | 12 | 16 | 22.05 | 22.059 | 24 | 32 | 44.1 | 44.118 | 48 | 88.2 | 88.235 | 96 | 176.4 | 176.471 | 192 | | 1.4112 | _ | Х | _ | _ | _ | Х | | _ | _ | Х | _ | _ | Х | | _ | Х | _ | _ | | 2.8224 | _ | х | _ | _ | _ | х | _ | _ | _ | Х | _ | _ | Х | | _ | Х | _ | | | 5.6448 | _ | х | _ | _ | _ | Х | _ | _ | _ | Х | _ | _ | Х | _ | _ | Х | _ | | | 11.2896 | _ | х | _ | _ | _ | х | - | _ | _ | Х | _ | _ | Х | - | _ | Х | _ | | | 22.5792 | _ | х | _ | _ | _ | х | | _ | _ | Х | _ | _ | Х | - | _ | х | _ | | | 1.024 | Х | _ | _ | _ | Х | _ | _ | _ | Х | _ | _ | _ | _ | | _ | _ | _ | _ | | 2.048 | Х | _ | _ | _ | Х | _ | _ | _ | Х | _ | _ | _ | _ | | _ | _ | _ | | | 4.096 | Х | _ | _ | _ | Х | _ | _ | _ | Х | _ | _ | _ | _ | | _ | _ | _ | | | 8.192 | Х | _ | _ | _ | Х | _ | _ | _ | Х | _ | _ | _ | _ | | _ | _ | _ | | | 2 | Х | _ | _ | _ | х | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | | | 3 | Х | _ | х | Х | _ | _ | х | Х | _ | _ | х | _ | _ | х | _ | _ | Х | | | 4 | Х | _ | _ | _ | Х | _ | | _ | Х | _ | _ | _ | _ | | _ | _ | _ | | | 6 | Х | _ | Х | Х | Х | _ | Х | Х | _ | _ | Х | Х | _ | Х | _ | _ | Х | | | 12 | Х | _ | Х | Х | Х | _ | Х | Х | Х | _ | Х | Х | _ | Х | Х | _ | Х | _ | | 24 | Х | _ | Х | Х | х | _ | Х | Х | Х | _ | Х | Х | _ | х | Х | _ | Х | х | | 1.536 | Х | _ | _ | Х | Х | _ | _ | Х | Х | _ | _ | Х | _ | | Х | _ | _ | х | | 3.072 | Х | _ | _ | Х | Х | _ | _ | Х | Х | _ | _ | Х | _ | | Х | _ | _ | Х | | 6.144 | Х | _ | _ | Х | Х | _ | _ | Х | Х | _ | _ | Х | _ | _ | Х | _ | _ | Х | | 12.288 | Х | _ | _ | Х | Х | _ | _ | Х | Х | _ | _ | Х | _ | | Х | _ | _ | х | | 24.576 | Х | _ | _ | Х | х | _ | _ | Х | х | _ | _ | Х | _ | | Х | _ | _ | х | | 9.6 | Х | _ | _ | Х | Х | _ | | Х | х | _ | _ | Х | _ | _ | Х | _ | _ | Х | | 19.2 | Х | _ | _ | Х | Х | _ | | Х | Х | _ | _ | Х | _ | | Х | _ | _ | Х | Table 4-15. Supported Serial-Port Sample Rates Fig. 4-30 and Fig. 4-31 show the serial-port clocking architectures. Figure 4-30. ASP SCLK Architecture Figure 4-31. ASP LRCK Architecture As shown in Fig. 4-32, the LRCK period (FSYNC\_PERIOD\_LB and FSYNC\_PERIOD\_UB, see p. 142) controls the number of SCLK periods per frame. This effectively sets the frame length and the number of SCLK periods per Fs. Frame length may be programmed in single SCLK period multiples from 16 to 4096 SCLK:Fs. If ASP\_HYBRID\_MODE (see p. 143) is set, the SCLK period multiples must be set to 2 \* n \* Fs, where $n \in \{8, 9, ..., 2048\}$ . Figure 4-32. ASP LRCK Period, High Width FSYNC\_PULSE\_WIDTH\_LB and FSYNC\_PULSE\_WIDTH\_UB (see p. 142) control the number of SCLK periods for which the LRCK signal is held high during each frame. Like the LRCK period, the LRCK-high width is programmable in single SCLK periods, from at least one period to at most the LRCK period minus one. That is, the LRCK-high width must be shorter than the LRCK period. As shown in Fig. 4-33, if 50/50 Mode is enabled (ASP\_5050 = 1, see p. 143), the LRCK high duration must be programmed to the LRCK period divided by two (rounded down to the nearest integer when the LRCK period is odd). When the serial port is in 50/50 Mode, setting the LRCK high duration to a value other than half of the period causes erroneous operation. Fig. 4-34 shows how LRCK frame start delay (ASP FSD, see p. 143) controls the number of SCLK periods from LRCK synchronization edge to the start of frame data. Figure 4-34. LRCK FSD and SCLK Polarity Example Diagram #### 4.9.3 Channel Location and Resolution Each serial-port channel's location and offset is configured through the registers in Table 4-16. Location is programmable in single SCLK-period resolution. If set to the minimum location offset, a channel sends or receives on the first SCLK period of a new frame. Channel size is programmable in 8- to 32-bit byte resolutions. Note that only the S/PDIF port transmits up to 32 bits. ADC and DAC ports are limited to 24 bits and truncate the 8 LSBs of a 32-bit audio stream. | Channel | Resolution | MSB Location | LSB Location | |----------------------------|-----------------|------------------------|------------------------| | ASP Transmit Channel 1 | ASP_TX_CH1_RES | ASP_TX_BIT_CH1_ST_MSB | ASP_TX_BIT_CH1_ST_LSB | | ASP Transmit Channel 2 | ASP_TX_CH2_RES | ASP_TX_BIT_CH2_ST_MSB | ASP_TX_BIT_CH2_ST_LSB | | ASP Receive DAI0 Channel 1 | ASP_RX0_CH1_RES | ASP_RX0_CH1_BIT_ST_MSB | ASP_RX0_CH1_BIT_ST_LSB | | | | ASP_RX0_CH2_BIT_ST_MSB | | | ASP Receive DAI0 Channel 3 | ASP_RX0_CH3_RES | ASP_RX0_CH3_BIT_ST_MSB | ASP_RX0_CH3_BIT_ST_LSB | | ASP Receive DAI0 Channel 4 | ASP_RX0_CH4_RES | ASP_RX0_CH4_BIT_ST_MSB | ASP_RX0_CH4_BIT_ST_LSB | | ASP Receive DAI1 Channel 1 | ASP_RX1_CH1_RES | ASP_RX1_CH1_BIT_ST_MSB | ASP_RX1_CH1_BIT_ST_LSB | | ASP Receive DAI1 Channel 2 | ASP_RX1_CH2_RES | ASP_RX1_CH2_BIT_ST_MSB | ASP_RX1_CH2_BIT_ST_LSB | Table 4-16. ASP Channel Controls Channel size and location must not be programmed such that channel data exceeds the frame boundary. In other words, channel size and offset must not exceed the expected SCLK per LRCK settings. Size and location must not be programmed such that data from a given SCLK period is assigned to more than one channel. However, an exception exists for the DAI as the same data can be used for both received channels' location, if desired. For an example, see Section 5.1. Fig. 4-35 shows channel location and size with serial-port double-rate disabled. See ASP\_RX1\_2FS and ASP\_RX0\_2FS (p. 169). Figure 4-35. Example Channel Location and Size, ASP Double Rate Disabled ## 4.9.4 Isochronous Serial-Port Operation In Isochronous Mode, audio data can be transferred between the internal audio data paths and a serial port at isochronous frequencies slower than the LRCK frequency. In all cases, the sample rate/LRCK frequency ratio must be one for which there are points at which rising edges regularly align. **Notes:** Combining an isochronous audio stream on a channel (or on multiple channels) concurrently with a native audio stream on another channel (or other multiple channels) is not supported. The S/PDIF port does not support isochronous audio streams. In Isochronous Mode, if a stream's sample rate does not match the LRCK frequency, it must include nulls, indicated by the negative full-scale (NFS) code (1 followed by 0s) or by adding nonaudio bits (NSB Mode) to the data stream. SP RX NFS NSBB and SP TX NFS NSBB (see p. 163 and p. 164) select between the NFS and NSB modes. In NFS Mode, to achieve a desired isochronous output sample rate, a null-insert block adds NFS samples to the output stream. NFS samples input to the null-insert block are incremented and are passed to the output as valid, nonnull samples. In NSB Mode, a null-insert block adds 8 bits to the data stream and inserts null samples to achieve a desired isochronous output sample rate. Inserted null samples are defined as NFS including the nonaudio bits. NFS samples that are input to the null-insert block are passed as valid, nonnull samples to the output. Valid samples are indicated by a nonzero value in the null sample indicator bit. The null sample indicator bit is globally defined by the SP\_RX\_NSB\_POS (see p. 163) and SP\_TX\_NSB\_POS (see p. 164). Total data stream sample width, including the nonaudio bits, is N + 8 bits. Therefore, the maximum HD audio sample width is 24 bits in NSB Mode. In NFS Mode, a null-remove block deletes null samples, restoring the stream's original sample rate. NFS samples that are input to the null-remove block are removed from the data stream as invalid, null samples. In NSB Mode, a null-remove block deletes samples that have a zero null sample indicator bit, restoring the stream's original sample rate. Furthermore, the output data has the least-significant 8 bits of nonaudio data removed. Samples with a zero null sample indicator bit are removed from the data stream as invalid, null samples. In either NSB or NFS Mode, setting the Tx and Rx rate fields (SP\_TX\_FS, see p. 164, and SP\_RX\_FS, see p. 163) matters only if an isochronous mode is selected via SP\_TX\_ISOC\_MODE (see p. 164) and SP\_RX\_ISOC\_MODE (see p. 163). Supported isochronous rates are 48k, 96k, and 192k. The ASPx Tx/Rx rate bits are used only to help determine when to insert/ nulls and to provide the correct f<sub>SI</sub>/f<sub>SO</sub> to the SRCs while in Isochronous Mode. For null-remove operations, the rates do not need to match the actual data rate. Likewise, if data is being rendered or captured at its native rate, these registers have no effect. As Fig. 4-36 shows, the null-sample bit (NSB) flag may be any bit of the least-significant sample byte. NSB-encoded streams are assumed to contain 8 bits of nonaudio data as the LSB. Figure 4-36. NSB Null Encoding To send isochronous audio data to a serial port, the data pattern must be such that the LRCK/FSYNC transition preceding any given nonnull sample on the 48-kHz serial port does not deviate by more than one sample period from a virtual clock running at the desired sample rate. Use the following example to determine the data word as it appears on the serial port. ``` error = 0 for each LRCK if(error < 1/FLRCK) output = <<next sample>> error = error + (1/Fs - 1/FLRCK) else output = NULL error = error - 1/FLRCK ``` The null-sample sequences in Table 4-17 result from the example above for common sample rates. This method ensures that the internal receive data FIFO does not underrun or overrun, which would cause audio data loss. Depending on the internal audio data FIFOs' startup conditions and on the serial-port clock-phase relationships, isochronous data sent from a serial port may not adhere to the data patterns in Table 4-17. In all cases, the transmitted audio data rate matches the stream sample rate. | Sample Rate (kHz) | Isochronous Data Pattern for LRCK = 48 kHz | |-------------------|--------------------------------------------------------------------------------------------------------------------------| | 8.000 | 1 <sub>S</sub> 5 <sub>N</sub> (repeat) | | 11.025 | [[[1s3nx2]1s4n]x5 1s3n1s4n]x4 [[1s3nx2]1s4n]x4 1s3n1s4n [[[1s3nx2]1s4n]x5 1s3n1s4n]x3 [[1s3nx2]1s4n]x4 1s3n1s4n (repeat) | | 12.000 | 1 <sub>S</sub> 3 <sub>N</sub> (repeat) | | 16.000 | 1 <sub>S</sub> 2 <sub>N</sub> (repeat) | | 22.05 | [[1s1nx6]1n [1s1nx6]1n [1s1nx5]1n]x8 [1s1nx6]1n [1s1nx5]1n (repeat) | | 24.000 | 1 <sub>S</sub> 1 <sub>N</sub> (repeat) | | 32.000 | 2 <sub>S</sub> 1 <sub>N</sub> (repeat) | | 44.100 | [12s1n[11s1n]x2]x3 11s1n (repeat) | | 48.000 | 1 <sub>S</sub> (repeat) | Table 4-17. Isochronous Input Data Pattern Examples **Note:** N = Null sample, S = Normal sample #### 4.9.5 50/50 Mode Regardless of the state of ASP\_LRCK/FSYNC, in 50/50 Mode (ASP\_5050 = 1, see p. 143), the ASP can start a frame. The ASP STP setting (see p. 143) determines which LRCK/FSYNC phase starts a frame in 50/50 Mode, as follows: • If ASP STP = 0, the frame begins when LRCK/FSYNC transitions from high to low. See Fig. 4-37. acrine when I DOM/ECVNO transitions from law to high Cas Fig. 4.20 If ASP\_STP = 1, the frame begins when LRCK/FSYNC transitions from low to high. See Fig. 4-38. In 50/50 Mode, left and right channels are programmed independently to output when LRCK/FSYNC is high or low—that is, the channel-active phase. The active phase is controlled by the $ASP_TX_CHx_AP$ (see p. 168) and $ASP_RXx_CHy_AP$ (see Section 7.22). If $x_AP = 1$ , the respective channel is output if LRCK/FSYNC is high. If $x_AP = 0$ , the channel is output if LRCK/FSYNC is low. Note: Active phase has no function if 50/50 Mode = 0, ASP\_RX0\_2FS = 1, or ASP\_RX1\_2FS = 1. In 50/50 Mode, the channel location (see Section 4.9.3) is calculated within the channel-active phase. If there are N bits in a frame, the location of the last bit of each active phase is equal to (N/2) - 1. #### 4.9.6 Serial Port Status Each serial port has sticky, write-1-to-clear status bits related to capture and render paths. These bits are described in Section 7.6.4 and Section 7.6.5. Mask bits (Section 7.6.16 and Section 7.6.17) determine whether INT is asserted when a status bit is set. Table 4-18 provides an overview. If only one data-path direction (render/Tx or capture/Rx) of a serial port is used, the status bits of the unused direction may be set. To prevent spurious interrupts, mask the status bits of unused data path directions and of unused serial ports. | Name | Direction | Description | Register Reference | |---------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | Request<br>Overload | l | Set when too many input buffers request processing at the same time. If all channel registers are properly configured, this error status should never be set. | ASPRX_OVLD p. 145 | | LRCK Error | | | ASPRX_ERROR p. 145 | Table 4-18. Serial Port Status #### Table 4-18. Serial Port Status (Cont.) | Name | Direction | Description | Register Reference | |------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------| | LRCK Early | Tx/Rx | Set when the number of SCLK periods per LRCK phase (high or low) is less than the expected count as determined by $x\_LCPR$ and $x\_LCHI$ . | ASPRX_EARLY p. 145<br>ASPTX_EARLY p. 146 | | | | <b>Note:</b> The Rx LRCK early interrupt status is set during the first receive LRCK early event. Subsequent receive LRCK early events are indicated only if valid LRCK transitions are detected. | | | LRCK Late | Tx/Rx | Set when the number of SCLK periods per LRCK phase (high or low) is greater than the expected count as determined by x_LCPR and x_LCHI. | ASPRX_LATE p. 145<br>ASPTX_LATE p. 146 | | No LRCK | Tx/Rx | <b>Note:</b> Set when the number of SCLK periods counted exceeds twice the value of LRCK period (x_LCPR) without an LRCK edge. The Tx No LRCK interrupt status is set during the first instance of a no-transmit LRCK condition. Subsequent no-transmit LRCK conditions are not indicated until after valid LRCK transitions are detected. | ASPRX_NOLRCK p. 145<br>ASPTX_NOLRCK p. 146 | | SM Error | Tx | Set if the transmit state machine cannot retrieve data from output buffers (analogous to Rx Request Overload). If all channel registers are properly configured, this status is never set. | | | | | <b>Note:</b> The interrupt status is set during the first transmit SM error event. Subsequent SM error events are not indicated until after the FIFO exits the overflow state. | | ### 4.9.7 Recommended Serial-Port Power-Up and Power-Down Strategies Although multiple safeguards and controls are implemented to prevent a run on the FIFOs involved in passing data from the input port to the output port, the following power-up sequence is recommended. Section 5 gives detailed sequences. - 1. Configure all playback/record channel characteristics—bit resolution, channel select, source (DAI/DAO or SW), native/isochronous, sample rates, etc. - 2. Power up playback, record path, and ASRCs. - 3. Release the PDN ALL bit. - 4. Power up the serial ports (DAI/DAO). The following power-down sequence is recommended: - 1. Power down the playback and record paths. - 2. Power down the serial ports. #### 4.10 S/PDIF Tx Port The S/PDIF output port is integrated to provide a pass-through of encoded (e.g., AC3) or PCM data from the serial audio ports to an external optical driver. The S/PDIF port does not support isochronous audio streams. #### 4.10.1 S/PDIF Pass-Through Transmission The CS42L42 S/PDIF transmitter performs pass-through retransmission of stereo samples that are generated on an external device and transported over the TDM or SoundWire port. This transmitter can be programmed to retransmit any two of the 16-, 20-, 24-, or 32-bit S/PDIF encoded samples from the serial port by programming ASP\_RX0\_CH1\_RES (note that this is RX0 Channels 1–4 and RX1 Channels 1 and 2, see p. 170) and SPDIF\_RES (see p. 165). The supported S/PDIF rates are 32, 44.1, 48, 88.2, 96, 176.4, and 192 kHz and are configured through SPDIF\_TX\_STAT (see p. 167). The CS42L42 does not decode or interpret samples chosen for retransmission. Additionally, the S/PDIF path does not incorporate any SRCs in the data path. When the data source comes from the TDM source, the CS42L42 selects between data from the DAI0 or DAI1 as follows: - If DAIO, configure SPDIF\_CHA\_SEL/SPDIF\_CHB\_SEL (see p. 164) to map any of the four TDM slots (0–3) to the S/PDIF inputs. ASP\_RXO\_2FS = 0 (see p. 169). - If ASP\_RX1\_2FS = 1 (see p. 169), which means there is simultaneous operation on both the TDM and S/PDIF ports at different rates, the S/PDIF transmit port gets data from the DAI1 and ignores data from the DAI0. Channel 0 of DAI1 maps to left channel and Channel 1 of DAI1 maps to right channel. If the data source comes from the SoundWire port, signals are retimed and passed to the S/PDIF transmit port. SPDIF\_LRCK\_SRC\_SEL(see p. 141) selects the S/PDIF LRCK source. SPDIF\_LRCK\_CPOL (see p. 142) sets polarity. Configuration bits mentioned above must be programmed before powering up the DAI ports and the S/PDIF transmit port. ## 4.10.2 S/PDIF, Headphone, and ADC Simultaneous Clocking Configuration S/PDIF transmission requires an SCLK of 128 x Fs supplied either from the ASP\_SCLK/SWIRE\_CLK input pin or from the internal fractional-N PLL. When operating the S/PDIF transmitter with no other data converters enabled, the source of the transmission clock is freely chosen between the input pin and the PLL. When simultaneous operation of the data converters and the S/PDIF transmitter is desired, a 128 x Fs clock must be supplied from the ASP\_SCLK/SWIRE\_CLK input. Table 4-19 describes the supported clocks for simultaneous operation. LRCK (kHz) S/PDIF HP (Isochronous) HSIN (Isochronous) SCLK (MHz) PLL Output (MHz) 48 48 8, 11.025, 12, 16, 22.05, 8,11.025, 12, 16, 22.05, 24, 6.144, 12.288, 12.288, 24.576 24, 32, 44.1 32, 44.1 24.576 48 2 x 48 <sup>1</sup> 16, 22.05, 24, 32, 44.1, 16, 22.05, 24, 32, 44.1, 48 12.288, 24.576 12.288, 24.576 48, 88.2 96 96 96 2 x 96 <sup>1</sup> 32, 44.1, 48, 88.2, 96 32, 44.1, 48 24.576 24.576 192 192 Fs Fs Fs (Native) Fs (Native) 128xFs 11.2896, 12.288, 22.8796, 24.576 MHz 2 x Fs 1 Table 4-19. S/PDIF, Headphone, and ADC Simultaneous Clocking Support 1.ASP RX1 2FS = 1. For proper S/PDIF signal timing, the divide factor, selected with SPDIF\_CLK\_DIV (see p. 141), must be chosen by using the following formula: Divide factor = $MCLK_{INT}/(128 \text{ x Fs})$ (where Fs is the data rate to the S/PDIF block and not the external LRCK) For example, for an S/PDIF output Fs of 192 kHz, 128 X 192 kHz = 24.576 MHz. If ASP\_SCLK is 24.576 MHz, the divide factor must be 1 (SPDIF CLK DIV = 000). **Note:** Due to SPDIF\_CLK\_DIV being limited to 1, 2, 3, 4, and 8, a 32-kHz S/PDIF Fs is not supported with a 24.576-MHz ASP\_SCLK/SWIRE\_CLK. #### 4.10.3 Interface Formats This section describes the frame and subframe formats, channel coding, and Keep-Alive Mode. #### 4.10.3.1 Frame Format A frame (see Fig. 4-39) is uniquely composed of two subframes (see Fig. 4-40). Samples taken from both channels are transmitted by time multiplexing in consecutive subframes. The first subframe normally starts with Preamble M; however, to identify the start of the block structure used to organize the channel status information, the preamble changes to B once every 192 frames. The second subframe always begins with Preamble W. The frame format is the same for one- and two-channel operations. Data is carried in the first subframe and may be duplicated in the second. If the second subframe does not carry duplicate data, the validity flag (Time Slot 28) must be set to Logic 1. Figure 4-39. S/PDIF Frame Format #### 4.10.3.2 Subframe Format Each subframe is divided into 32 time slots, numbered 0–31, as shown in Fig. 4-40. Figure 4-40. Subframe Format (Linear PCM Application) #### 4.10.3.3 Channel Coding To minimize DC buildup on the transmission line, to facilitate clock recovery from the data stream, and to make the interface insensitive to the polarity of connections, Time Slots 4–31 are encoded in biphase mark. Each bit to be sent is represented by a symbol comprising two consecutive binary states. The first state is always different from the second state of the previous symbol. The second state is identical to the first if the bit to be sent is Logic 0, but it is different if the bit is Logic 1 (see Fig. 4-41). Figure 4-41. S/PDIF Channel Coding #### 4.10.3.4 Keep-Alive Mode The Keep-Alive Mode in the S/PDIF transmitter output is used to force a valid S/PDIF stream (clocking and status information without data bits) to be output from the SPDIF\_TX pin while the system is in a low power state. This allows an external S/PDIF receiver to remain locked to the S/PDIF stream from the CS42L42 and resume playback without delay if an output stream is later opened. The status information is provided according to the channel status bits in Table 4-20. The state of the SPDIF\_TX pin depends on SPDIF\_TX\_DIGEN (see p. 167) and SPDIF\_TX\_PDN (see p. 166). Table 4-20 shows all control-bit combinations and the resulting state of the SPDIF\_TX pin. Note that SPDIF\_TX\_KAE (see p. 166) has no function in the Keep-Alive Mode on the CS42L42. Table 4-20. S/PDIF Output Keep-Alive Control | SPDIF_TX_DIGEN (see p. 166) | SPDIF_TX_PDN (see p. 166) | SPDIF_TX | |-----------------------------|---------------------------|-----------------------| | Х | 1 | Off (drive low) | | 0 | 0 | Clock + status | | 1 | 0 | Clock + status + data | # 4.11 Sample-Rate Converters (SRCs) SRCs bridge different sample rates at the serial ports within the digital-processing core. SRCs are used for the following: - Two ASP input channels (Channels 1 and 2). The other two ASP input channels are used for S/PDIF transmit and bypass the SRC. - One ASP output channel (Channel 1). - Two SoundWire input channels (Channels 1 and 2). The other two SoundWire input channels are used for S/PDIF transmit and bypass the SRC. - One SoundWire output channel (Channel 1) - SRCs are bypassable by setting either SRC\_BYPASS\_DAC (see p. 133) or SRC\_BYPASS\_ADC. An SRC's digital-processing side (as opposed to its serial-port side) connects to the ADC or DAC. Multirate DSP techniques are used to up-sample incoming data to a very high rate and then down-sample to the outgoing rate. Internal filtering is designed so that a full-input audio bandwidth of 20 kHz is preserved if the input and output sample rates are at least 44.1 kHz. If the output sample rate becomes less than the input sample rate, the input is automatically band limited to avoid aliasing artifacts in the output signal. The following restrictions must be met: - The F<sub>so</sub>-to-F<sub>si</sub> ratio must be no more than 1:6 or 6:1. For example, if the DAC is at 48 kHz, the input to the SRC must be at least 8 kHz. - SRC operation cannot be changed on-the-fly. Before changing the SRC operation (e.g., changing SRC frequencies or bypassing or adding the SRCs), the user must follow the power sequences provided in Section 4.9.7. - The MCLK frequency must be as close as possible to, but not less than the minimum SRC MCLK frequency, MCLK<sub>MIN</sub>, which must be at least 125 times the higher of the two sample rates (F<sub>SI</sub> or F<sub>SO</sub>). For example, if F<sub>SO</sub> is 48 kHz and F<sub>SI</sub> is 32 kHz, the MCLK must be as close as possible to, but not less than, an MCLK<sub>MIN</sub> of 6.0 MHz. The MCLK frequency for the SRCs is configured through CLK\_IASRC\_SEL (see p. 144) and CLK\_OASRC\_SEL (see p. 144). Table 4-21 shows settings for the supported sample rates and corresponding MCLK<sub>INT</sub> frequencies. Table 4-21. Supported Sample Rates and Corresponding MCLK<sub>INT</sub> Encodings | Fsint | | Serial Port Sample Rate (kHz) | | | | | | | | | | | | | | | | | |-------|-----|-------------------------------|--------|----|----|-------|--------|----|----|------|--------|----|------|--------|----|-------|---------|-----| | (kHz) | 8.0 | 11.025 | 11.029 | 12 | 16 | 22.05 | 22.059 | 24 | 32 | 44.1 | 44.118 | 48 | 88.2 | 88.235 | 96 | 176.4 | 176.471 | 192 | | 44.1 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 01 | 01 | 01 | 10 | 10 | 10 | | 48 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 01 | 01 | 01 | 10 | 10 | 10 | Note: SRC MCLKINT Freq= 00 (6 MHz), 01 (12 MHz), 11 (24 MHz), configured in CLK\_IASRC\_SEL (see p. 144) and CLK\_OASRC\_SEL (see p. 144) Jitter in the incoming signal has little effect on rate-converter dynamic performance. It does not affect the output clock. A digital PLL continually measures the heavily low-pass-filtered phase difference and the frequency ratio between input and output sample rate clocks. It uses the data to dynamically adjust coefficients of a linear time-varying filter that processes a synchronously oversampled version of the input data. The filter output is resampled to the output sample rate. For input serial ports, input and output sample-rate clocks are respectively derived from the external serial-port sample clock ( $x_LRCK$ ) and the internal Fs clock. For output serial ports, they are derived in reverse order. FS\_EN (see p. 143) must be set according to the $F_{SI}$ or $F_{SO}$ SRC sample rates. Minimize the SRCs' lock time by programming the serial-port interface sample rates into the x\_FS registers (see Section 7.18.2 and Section 7.18.1). If the rates are unknown, programming these registers to "don't know" would likely increase lock times. Proper operation is not assured if sample rates are misprogrammed. #### 4.12 Headset Interface The headset interface, shown in Fig. 4-42, is a collection of low-power circuits within the CS42L42's ADC data path. It provides an intelligent interface to an external headset. It also communicates with an applications processor to relay command and status information. The headset communicates to the interface by shorting its mic line to ground (via the S0 button) The interface generates HSBIAS, a programmable ultrahigh PSRR headset bias output for an external microphone. A low-voltage headset bias supply (VP = 3.0–3.2 V range) mode is supported. Signaling to the headset to set its operating voltage is facilitated via the bias output Audible transients that would occur as certain headset plugs are unplugged are minimized by using the headset bias Hi-Z feature Split digital-power domains (VD\_FILT and VP) within the headset interface support an ultralow-power standby mode where only the VP supply is used. An output signal may be used to tell the system to wake from its low-power state when a headset plug is inserted or removed or a mic short event (S0 button press) occurs. The interface may be reset by three types of resets with progressively less effect. Figure 4-42. Headset Interface Block Diagram The control port includes registers that source individually maskable interrupts. Event-change debouncing is used to filter applicable status registers. Shadow registering can record multiple events allowing for less frequent register reading. Latchable duplicate registers are used to pass information to the Standby Mode supply domain. #### Notes: - If HSBIAS is Hi-Z, the headset interface is in an invalid mode. - PDN ALL must not be set if any of this following is true: - —Normal Mode is selected (DETECT MODE ≠ 00). - —Mic DC-level detection is enabled (PDN\_MIC\_LVL\_DETECT = 0; see p. 155). - —HS bias sense detection is enabled (HSBIAS SENSE EN = 1; see p. 153). ## 4.13 Headset Type Detect The CS42L42 can detect whether headset Pins 3 and 4 are either the mic or ground signal and can set the appropriate connections via internal switches, as shown in Fig. 4-43. Figure 4-43. Headset Type Detect—Overview External switches can improve system cross-talk performance by providing a lower impedance path to ground for HP and mic currents. In this case, minimize the impedance from the connection to the headset connector to ground through the external switches. This includes any switch, trace, and series filter impedance. ## 4.13.1 Headset-Type Detection Operation of the headset-detect circuit is determined by the HSDET\_CTRL setting (see p. 140), described as follows: If HSDET\_CTRL = 00 or 01, any internal switches can be set manually via the headset switch control bits (SW\_x\_ y, see Section 7.4.13). If HSDET\_CTRL = 10 or 11, the SW\_x\_y bits do not affect the state of the internal switches. These settings are stored in the VP power domain, so that the switches remain correctly configured, even if the VCP, VL, VA, or VD\_FILT supplies are powered off. The HSDET logic and status bits are stored in the VD\_FILT power domain. To prevent audible pop/clicks in the HPs, it may be desirable in some applications to precharge the HSBIAS and HSBIAS\_FILT capacitors before setting the switches to their final values. Set SW\_HSB\_HS3/4 and SW\_HSB\_FILT\_HS3/4 to minimize transients at the HPs associated with charging capacitors. After the capacitors are charged, the switches can be changed to their desired states. Note that headset S0 button-detect features are not available until internal switches have been configured. Also, depending on the headset type detected, switch settings, and board connections, it may be necessary to set ADC\_INV (see p. 158) to have the proper signal polarity. Section 5 provides a recommended headset-type detection sequence. Table 4-22. Automatic Headset Detect Decode | HSDET TYPE | Headset Plug | | | | DC Test Comparator Results <sup>1</sup> | | | |-------------|--------------|-------------|-------|-------|-----------------------------------------|---------------------------|--| | IISDEI_IIFE | Pin 1 | Pin 2 | Pin 3 | Pin 4 | HSDET_TYPE 1 Switch State | HSDET_TYPE 2 Switch State | | | 1 | Left audio | Right audio | GND | MIC | High | Low | | | 2 | Left audio | Right audio | MIC | GND | Low | High | | | 3 | Left audio | Right audio | GND | GND | Low | Low | | | 4 | | Optical | | | High | High | | 1. After performing an automatic headset-detection sequence, the output of the headset comparators may not be valid even if switch configurations are correct for a given plugged-in headset type. GNDHS HSDET\_TYPE REF **HSB FILT** HSB HS4 HS3 HS4 HS3 HS4 HS3 HS4 HS<sub>3</sub> 0 0 0 0 1 0 0 0 2 1 0 1 1 3 1 1 1 0 0 1 1 1 0 0 0 1 1 0 Table 4-23. Headset Type Detect—Switch States after Autodetection (0 = Switch Open; 1 = Switch Closed) # **4.14 Plug Presence Detect** The CS42L42 uses TIP\_SENSE and RING\_SENSE to detect plug presence. The sense pins are debounced to filter out brief events before being reported to the corresponding presence-detect bit and generating an interrupt if appropriate. #### 4.14.1 Plug Types The plug-sense scheme supports the following plug types: Tip—Ring—Sleeve (TRS)—Consists of a segmented metal barrel with the tip connector used for HPOUTA, a ring connector used for HPOUTB, and a sleeve connector used for HSGND. - Tip-Ring-Ring-Sleeve (TRRS)—Like TRS, with an additional ring connector for the HSIN connection. There are two common pinouts for TRRS plugs: - One uses the tip for HPOUTA, the first ring for HPOUTB, the second ring for HSGND, and the sleeve for HSIN. - OMTP, or China, headset, which swaps the third and fourth connections, so that the second ring carries HSIN and the sleeve carries HSGND. ## 4.14.2 Tip-Sense/Ring-Sense Methods The following methods are used to detect the presence or absence of a plug: - Tip sense (TS)—A sense pin is connected to a terminal on the receptacle such that, if no plug is inserted, the pin is floating. If a plug is inserted, the pin is shorted to the tip (T) terminal. The tip is sensed by having a small current source in the device pull up the pin if it is left floating (no plug). If a plug is inserted and the sense pin is shorted to HPOUTA, the sense pin is assumed to be pulled low via clamps at the HP amp output when it is in power down. If the HP amp is running, the sense pin is shorted to the output signal and, therefore, is pulled below a certain threshold via the output stage of the HP amp. Thus, a low level at the sense pin indicates plug inserted, and a high level at the sense pin indicates plug removed. - Inverted tip sense (ITS)—Like tip sense, but with a connector whose sense pin is shorted to the tip terminal if the plug is removed and is left floating if it is inserted. Therefore, a low level at the sense pin indicates plug removed and a high level at the sense pin indicates plug inserted. Inversion is controlled by the following: - The invert (TIP\_SENSE\_INV, p. 155), which goes to the analog and affects a number of other features. - The tip-sense invert (TS\_INV, p. 139), which affects only the configuration bits in Section 6.5. - Ring sense (RS)—Like tip sense, except that the sense pin is shorted to the second ring terminal (HS3) when a plug with a metal barrel (TRS or TRSS) is inserted, and floating when a plug with a plastic barrel (OPT) is inserted or the plug is removed. If a metal plug is inserted and the sense pin is shorted to HS3, it is assumed that the sense pin is pulled low (to HSGND) or below a certain threshold (to HSBIAS) via switches in the HS type-detect block. As a result, a low level at the sense pin indicates metal plug inserted and a high level at the sense pin indicates plug removed (plastic plug inserted or plug removed). - Inverted ring sense (IRS)—Like ring sense, except that the connector is constructed such that the sense pin is shorted to the second ring terminal (HS3) when the plug is removed and is left floating when it is inserted. Therefore, a low level at the sense pin indicates *plug removed*; a high level indicates *metal or plastic plug inserted*. ## 4.14.3 Ring-Sense Configuration The RING\_SENSE pin can be used as a ground sense for the connected plug if the inserted plug is determined to be of type TRS or TRRS. If the RING\_SENSE pin is used as a ground reference, the impedance between the RING\_SENSE plug connector and the plug degrades the common-mode rejection of the output, which in turn affects output offset, step deviation, and pop/click attenuation. The CS42L42 includes a RING\_SENSE impedance-detection circuit to aid in the decision to use the RING\_SENSE input pin as a HP ground reference. The impedance-detection circuit can be activated to test whether plug-connector-to-plug impedance exceeds ~1 k $\Omega$ . RS\_TRIM\_T (see p. 137) determines the detection threshold. Pull-up resistance is controlled by the bits shown in Table 4-24. RING\_SENSE\_PU\_HIZ (see p. 137) RS\_TRIM\_R (See p. 137) Nominal Pull-Up Resistance 0 x 16.2 kΩ 1 0 2.25 MΩ 1 1 1.125 MΩ Table 4-24. Threshold Detection #### 4.14.4 Tip-Sense and Ring-Sense Debounce Settings Fig. 4-45 shows the tip-sense and ring-sense controls and the associated interrupt, status, and mask registers. Figure 4-45. Tip-Sense and Ring-Sense Controls The tip-and ring-sense debounce register fields behave and interact as follows: - TS UNPLUG DBNC. Shows tip sense status after being unplugged with the associated debounce time. - TS PLUG DBNC. Shows tip sense status after being plugged in with the associated debounce time. - RS UNPLUG DBNC. Shows ring sense status after being unplugged with the associated debounce time. - RS PLUG DBNC. Shows the ring sense status after being plugged in with the associated debounce time. Note: TS INV must be set to have TS PLUG/TS PLUG DBNC status match TIP SENSE PLUG status. The debounce bits are described in Section 7.4.10. Multiple debounce settings can be configured for insertion, removal, ring sense, and tip sense: - TIP SENSE DEBOUNCE (see p. 155) controls the tip-sense removal debounce time. - TS\_FALL\_DBNCE\_TIME and TS\_RISE\_DBNCE\_TIME (see p. 139) and RS\_FALL\_DBNCE\_TIME and RS\_ RISE\_DBNCE\_TIME (see p. 138) settings configure the corresponding debounce times. #### 4.14.5 Setup Instructions The following steps are required to activate the tip-/ring-sense debounce interrupt status: - 1. Clear PDN ALL (see p. 136). - 2. Set TIP SENSE EN (see p. 154) for analog front-end of tip sense. - 3. Set LATCH TO VP (see p. 155) to latch analog controls into analog circuits. - 4. Set RING SENSE PDNB (see p. 137) to enable debounce block for ring sense plug/unplug. - 5. Write TIP\_SENSE\_CTRL (see p. 154) to 01 or 11 to enable debounce for tip sense plug/unplug. - 6. Clear interrupt masks (0x1320, see Section 7.6.22). Interrupt status (see Section 7.6.12) does not contain an event-capture latch—a read always yields the current condition. Table 4-25 describes the plug/unplug status for both tip and ring. | Plug Status | Unplug Status | Interpretation | |-------------|---------------|-------------------------------------------| | 0 | 0 | Tip is fully unplugged/not present | | 1 | 0 | Reserved | | 0 | 1 | Tip connection is in a transitional state | Tip is fully plugged/present Table 4-25. Tip and Ring Plug/Unplug Status ## 4.14.6 Plug-Sense Gating In some configurations, the presence of an optical plug can be determined only by the presence, or absence, of an associated plug. In the common combo plug implementation, the receptacle can accommodate either a headphone (TRS/TRRS) or an S/PDIF (OPT) connector. However, if ring sense is used to distinguish between two jacks, the absence of any plug may be falsely interpreted as the presence of an optical plug. Likewise, if the optical plug has a metal tip and tip sense is used to determine the presence of a TRS/TRSS plug, the presence of an optical plug may also be falsely interpreted as the presence of a headphone plug. To lessen those constraints, TS\_RS\_GATE (p. 138) can be used to apply the following gating rules, as would be appropriate for a combo plug: - RING SENSE present is asserted only if both RING SENSE detected and TIP SENSE detected are true. - TIP SENSE present is not asserted if RING SENSE detected is true. TIP\_SENSE- and RING\_SENSE-detected states are derived as usual and already consider inversion. Table 4-26 shows how TIP\_SENSE- and RING\_SENSE-present states are determined afterwards and represent what is passed to the host. TIP SENSE RING SENSE TIP SENSE Present TS RS GATE **RING SENSE Present** Detected (TS\_PLUG\_DBNC = 0, see p. 139) (RS\_PLUG\_DBNC = 0, see p. 139) (see p. 138) Detected 0 0 F 0 0 0 1 F 0 1 0 0 1 0 0 1 1 0 1 F (Gating prevents a false-positive pin presence.) 0 F (Gating prevents a false-positive pin presence.) Table 4-26. Plug Sense Gating # 4.15 Power-Supply Considerations Because some power supply combinations can produce unwanted system behavior, note the following: - Control-port transactions can occur 1 ms after VP, VD FILT, VCP, and VL exceed the minimum operating voltage. - If VP supply is off, it is recommended that all other supplies are also off. VP must be the first supply turned on. - RESET must be asserted until VP is valid. - If VD FILT is supplied externally (DIGLDO PDN = GND), VL must be supplied before VD FILT. - · VA, VL, and VCP can come up in any order. - Due to the VD\_FILT POR, VD\_FILT must be turned off before VA, VL, or VCP are turned off; otherwise, current could be drawn from supplies that remain on. Table 4-27 shows the maximum current for each supply when VP is on, but other supplies are on or off (all clocks are off and all registers are set to default values, i.e., reset). | | Supply | | | Curre | Notes | | | |-----|--------|-----|----------|------------------|----------|----------|-------------------------------| | VCP | VA | VL | $I_{Vp}$ | I <sub>VCP</sub> | $I_{VA}$ | $I_{VL}$ | Notes | | Off | Off | On | 25 | 0 | 0 | 328 | _ | | Off | On | Off | 14 | 0 | 0 | 0 | VA may source or sink current | | Off | On | On | 25 | 0 | 0 | 328 | VA may source or sink current | | On | Off | Off | 14 | 0 | 0 | 0 | _ | | On | Off | On | 25 | 0 | 0 | 328 | _ | | On | On | Off | 14 | 0 | 0 | 0 | VA may source or sink current | | On | On | On | 25 | 0 | 0 | 328 | | Table 4-27. Typical Leakage Current during Nonoperational Supply States (with VP Powered On) Notes: - Values shown reflect typical voltage and temperature. Leakage current may vary by orders of magnitude across the maximum and minimum recommended operating supply voltages and temperatures listed in Table 3-2. - Test conditions: Clock/data lines are held low, RESET is held high, and all registers are set to their default values. Table 4-28 shows requirements and available features for valid power-supply configurations. Table 4-28. Valid Power-Supply Configurations | Configuration | Notes | |----------------------------------|-------------------------------------------------------------------------------------------------| | On: VP | Limited set of headset plug-detect and WAKE output features, see Section 4.12 and Section 4.13. | | Off: VD_FILT = VCP = VL = VA | | | On: VP = VL | Limited set of headset plug-detect and WAKE output features, see Section 4.12 and Section 4.13. | | Off: VD_FILT = VCP = VA = OFF | Digital I/O ESD diodes are powered to prevent conduction in pin-sharing applications. | | On: VP = VD_FILT = VCP = VL = VA | Full chip functionality | ### 4.15.1 VP Monitor The CS42L42 voltage comparator monitors the VP power supply for potential brown-out conditions due to power-supply overload or other fault conditions. To perform according to specifications, VP is expected to remain above 3.0 V at all times. The VP monitor is enabled by setting VPMON\_PDNB (see p. 137) and must be powered up after VP is above 3.0 V to eliminate erroneous faulty condition detection. Fig. 4-46 shows the behavior of the VP monitor. Figure 4-46. VP Monitor The following describes the VP monitor behavior with respect to the voltage level: - If VP drops below 3.0 V, HSBIAS, HP output, RING\_SENSE, and TIP\_SENSE performance may be compromised. - If VP drops below 2.6 V, the VPMON\_TRIP status bit is set (see p. 148). An interrupt is triggered if M\_VPMON\_TRIP = 0 (see p. 151). This bit must be unmasked/enabled only if VP is above the detection-voltage threshold. It must be masked/disabled by default to eliminate erroneous interrupts while VP is ramping or is known to be below the threshold voltage. - A brown-out condition remains until VP returns to a voltage level above 3.0 V. - The VP monitor circuit becomes unreliable at VP levels below 2.4 V as it may trigger a power-on reset sequence by the device. - The VP monitor is intended to detect slow transitioning signals about the 2.6-V threshold. Pulses of short duration are filtered by the monitor and may not trigger at the 2.6-V threshold, but at a value much lower than expected. ## 4.16 Control-Port Operation Control-port registers are accessed through the I<sup>2</sup>C or SoundWire interfaces, allowing the codec to be configured for the desired operational modes and formats. Accessing the control-port registers is mutually exclusive to the I<sup>2</sup>C port or SoundWire port, depending on the SWIRE\_SEL configuration (see Table 1-1). Because the SWIRE\_SEL logic state is latched at POR, dynamic switching between SoundWire and I<sup>2</sup>C control is not supported. ## 4.16.1 I<sup>2</sup>C Control-Port Operation The I<sup>2</sup>C control port can operate completely asynchronously with the audio sample rates. However, to avoid interference problems, the I<sup>2</sup>C control port pins must remain static if no operation is required. The control port uses the I<sup>2</sup>C interface, with the codec acting as a slave device. The I<sup>2</sup>C control port can operate in the following modes, which are configured through the I<sup>2</sup>C debounce register in Section 7.3.12: - Standard Mode (SM), with a bit rate of up to 100 kbit/s - · Fast Mode (FM), with a bit rate of up to 400 kbit/s - Fast Mode Plus (FM+), with a bit rate of up to 1 Mbit/s. **Note:** ASP\_SCLK is not required to be on when the control port is accessed, for state machines affected by register settings to advance. SDA is a bidirectional data line. Data is clocked into and out of the CS42L42 by the SCL clock. Fig. 4-47–Fig. 4-50 show signal timings for read and write cycles. A Start condition is defined as a falling transition of SDA while the clock is high. A Stop condition is defined as a rising transition of SDA while the clock is high. All other SDA transitions occur while the clock is low. The register address space is partitioned into 8-bit page spaces that each comprise up to 127 8-bit registers. Address 0x00 of each page is reserved as the page indicator, PAGE. Writing to address 0x00 of any page changes the page pointer to the address written to address 0x00. To initiate a write to a particular register in the map, the page address, 0x00, must be written following the chip address. Subsequent accesses to register addresses are treated as offsets from the page address written in the initial transaction. To change the page address, initiate a write to address 0x00. To determine which page is active, read address 0x00. Figure 4-47. Control-Port Timing, I2C Write of Page Address The first byte sent to the CS42L42 after a Start condition consists of a 7-bit chip address field and a R/W bit (high for a read, low for a write) in the LSB. To communicate with the CS42L42, the chip address field must match 1\_0010, followed by the state of the AD1 and AD0 pins. **Note:** Because AD0 and AD1 logic states are latched at POR, dynamic addressing is not supported. If the operation is a write, the next byte is the memory address pointer (MAP); the 7 LSBs of the MAP byte select the address of the register to be read or written to next. The MSB of the MAP byte, INCR, selects whether autoincrementing is to be used (INCR = 1), allowing successive reads or writes of consecutive registers. Each byte is separated by an acknowledge (ACK) bit, which the CS42L42 outputs after each input byte is read and is input to the CS42L42 from the microcontroller after each transmitted byte. For write operations, the bytes following the MAP byte are written to the CS42L42 register addresses pointed to by the last received MAP address, plus however many autoincrements have occurred. Note that, while writing, any autoincrementing block accesses that go past the maximum 0x7F address write to address 0x00—the page address. The writes then continue to the newly selected page. Fig. 4-48 shows a write pattern with autoincrementing. Figure 4-48. Control-Port Timing, I<sup>2</sup>C Writes with Autoincrement For read operations, the contents of the register pointed to by the last received MAP address, plus however many autoincrements have occurred, are output in the next byte. While reading, any autoincrementing block access that goes past the maximum 0x7F address wraps around and continues reading from the same page address. Fig. 4-49 shows a read pattern following the write pattern in Fig. 4-48. Notice how read addresses are based on the MAP byte from Fig. 4-48. Figure 4-49. Control-Port Timing, I<sup>2</sup>C Reads with Autoincrement To generate a read address not based on the last received MAP address, an aborted write operation can be used as a preamble (see Fig. 4-50). Here, a write operation is aborted (after the ACK for the MAP byte) by sending a Stop condition. Figure 4-50. Control-Port Timing, I2C Reads with Preamble and Autoincrement The following pseudocode illustrates an aborted write operation followed by a single read operation, assumes page address has been written. For multiple read operations, autoincrement would be set to on (as shown in Fig. 4-50). ``` Send start condition. Send 10010 (AD1) (AD0)0 (chip address and write operation). Receive acknowledge bit. Send MAP byte, autoincrement off. Receive acknowledge bit. Send stop condition, aborting write. Send start condition. Send 10010 (AD1) (AD0)1 (chip address and read operation). Receive acknowledge bit. Receive byte, contents of selected register. Send acknowledge bit. Send stop condition. ``` #### 4.17 Reset The CS42L42 offers the reset options described in Table 4-29. Table 4-29. Reset Summary | Reset | Cause | Result | |-------------------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Device hard reset | Asserting RESET | If RESET is asserted, all registers (both VP and VD_FILT domains) and all state machines are immediately set to their defaults. No operation can begin until RESET is deasserted. Before normal operation can begin, RESET must be asserted at least once after the VP supply is first brought up. | | | | Note: Table 4-30 lists how this reset affects SoundWire registers. | | Power-on reset (POR) | Power up | If VD_FILT is lower than the POR threshold, the VD_FILT register fields and the state machines are held in reset, setting them to their default values/states. This does not reset the VP registers. The POR releases the reset when the VD_FILT supply goes above the POR threshold. | | | | VL and VA supplies must be turned at the same time the VD_FILT supply is turned on. | | | | Note: Table 4-30 lists how this reset affects SoundWire registers. | | Force reset (SoundWire defined) | Setting FORCE_<br>RESET | Setting FORCE_RESET (see p. 122) asserts a SoundWire Hard Reset, described in Table 4-30. After a FORCE_RESET, the master must issue a reboot command (set SFT_RST_REBOOT; see p. 165) and wait for 2.5 ms. | | Bus reset (SoundWire defined) | Master driving<br>4096 Logic 1s | Bus reset asserts a SoundWire Hard Reset, described in Table 4-30. After a bus reset, the master must issue a reboot command (set SFT_RST_REBOOT; see p. 165) and wait for 2.5 ms. | | Clock stop mode reset (SoundWire defined) | Exit clock stop;<br>CLOCK_STOP_<br>MODE = 1. | Clock Stop Mode reset asserts a SoundWire Hard Reset, described in Table 4-30. After the clock is restarted, the master must issue a reboot command (set SFT_RST_REBOOT; see p. 165) and wait for 2.5 ms. | | | | <b>Note:</b> The MIPI SoundWire specification refers to this as a <i>ClockStopMode1</i> reset source and uses <i>ClockStopMode0</i> to refer to the operation when CLOCK_STOP_MODE = 0 (see p. 122). | | Sync loss reset (SoundWire defined) | Loss-of-frame synchronization | Sync loss does not reset debug related SoundWire status bits as the other resets do. Disables active serial data paths. Occurs when sync loss errors result in detachment from the bus. See Table 4-30. | Table 4-30 describes the effects of resets on register fields. The SoundWire Slave IP supports asynchronous resets, whose effects are described in Table 4-30. Table 4-30. Register Resets | Registers | POR/Device<br>Hard Reset | SoundWire<br>Hard Reset <sup>1</sup> | SoundWire Synchronization Loss Reset | |--------------------------------------------------------------------|--------------------------|--------------------------------------|--------------------------------------| | SCP/DPn interrupt mask (Sections 7.1.2, 7.1.14, 7.1.16, and 7.2.2) | | Reset to | Reset to default | | CURRENT_BANK in the SCP control register (Section 7.1.3) | default | default | | | SCP device number (Section 7.1.5) | | | | | Memory access status (Section 7.1.17) | | | | | Memory read last address 0 and 1 (Section 7.1.20) | | | | | INVERT_BANK bit in DPn Port control registers (Section 7.2.3) | | | | | DP <i>n</i> channel prepare status (Section 7.2.5) | | | | | DPn channel enable (Section 7.2.7) | | | | | SCP/DPn/general interrupt status (Section 7.1.1, Section 7.2.1, | Reset to | Reset to | Not reset | | Section 7.1.13, Section 7.1.15) | default | default | | | All other SoundWire registers (address range below 0x1000) | Reset to | Not reset | Not reset | | | default | | | | Non-SoundWire registers (address range 0x1000 and above) | Reset to | Reset to | Not reset | | | default | default | | <sup>1.</sup> Bus reset, setting FORCE\_RESET bit, or on exit from Clock Stop Mode if CLOCK STOP MODE is set. See Table 4-29. ## 4.18 Interrupts The following sections describe the CS42L42 interrupt implementation. ## 4.18.1 SoundWire Interrupts The SoundWire interrupt mechanism allows SoundWire slaves to alert the SoundWire master to abnormal events or error conditions. SoundWire interrupts are implemented as defined by the SoundWire Specification. Their statuses are combined into an interrupt status reported on the SoundWire bus, through the SoundWire General Interrupt Status 1 register; see Section 7.1.13). If this register indicates the presence of an interrupt condition, software must examine the standard interrupts to determine the source. Table 4-31 lists the SoundWire interrupts and corresponding mask registers. Note that, unlike other interrupts implemented on the CS42L42, SoundWire interrupt mask bits are masked if cleared, rather than if set. Table 4-31. SoundWire Interrupt Status Registers and Corresponding Mask Registers—Page 0x00 | Interrupt Source State | Interrupt Mask Register | | |-------------------------------------------------------|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------| | Section | | | | | SCP Interrupt Status 1 (Section 7.1.1)<br>General Interrupt Status 1 (Section 7.1.13) | SCP Interrupt Mask 1 (Section 7.1.2)<br>General Interrupt Mask 1 (Section 7.1.14) | | Section 7.2, "SoundWire Data Port (1–3) Descriptions" | DPn Interrupt Status (Section 7.2.1) | DPn Interrupt Mask (Section 7.2.2) | ### 4.18.2 Standard Interrupts The interrupt output pin, $\overline{\text{INT}}$ , is used to signal the occurrence of events within the device's interrupt status registers. Events can be masked individually by setting corresponding bits in the interrupt mask registers. Table 4-32 lists interrupt status and mask registers. The configuration of mask bits determines which events cause the immediate assertion of $\overline{\text{INT}}$ : - When an unmasked interrupt status event is detected, the status bit is set and $\overline{\text{INT}}$ is asserted. - When a masked interrupt status event is detected, the interrupt status bit is set, but INT is not affected. Once asserted, $\overline{\text{INT}}$ remains asserted until all status bits that are unmasked and set have been read. Interrupt status bits are sticky and read-to-clear: Once set, they remain set until the register is read and the associated interrupt condition is not present. If a condition is still present and the status bit is read, although $\overline{\text{INT}}$ is deasserted, the status bit remains set. To clear status bits set due to initiation of a path or block, the status bits must be read after the corresponding module is enabled and before normal operation begins. Otherwise, unmasking previously set status bits causes assertion of $\overline{\text{INT}}$ . Table 4-32. Interrupt Status Registers and Corresponding Mask Registers—0x13 | Interrupt Source Status Register | Interrupt Mask Register | |--------------------------------------------------------------|------------------------------------------------------------| | ADC Overflow Interrupt Status (Section 7.6.1) | ADC Overflow Interrupt Status (Section 7.6.1) | | Mixer Interrupt Status (Section 7.6.2) | Mixer Interrupt Mask (Section 7.6.14) | | SRC Interrupt Status (Section 7.6.3) | SRC Interrupt Mask (Section 7.6.15) | | ASP RX Interrupt Status (Section 7.6.4) | ASP RX Interrupt Mask (Section 7.6.16) | | ASP TX Interrupt Status (Section 7.6.5) | ASP TX Interrupt Mask (Section 7.6.17) | | Codec Interrupt Status (Section 7.6.6) | Codec Interrupt Mask (Section 7.6.18) | | Detect Interrupt Status 1 (Section 7.6.7) | Detect Interrupt Mask 1 (Section 7.9.10) | | SRC Partial Lock Interrupt Status (Section 7.6.9) | SRC Partial Lock Interrupt Mask (Section 7.6.19) | | VP Monitor Interrupt Status (Section 7.6.10) | VP Monitor Interrupt Mask (Section 7.6.20) | | PLL Lock Interrupt Status (Section 7.6.11) | PLL Lock Mask (Section 7.6.21) | | Tip/Ring Sense Plug/Unplug Interrupt Status (Section 7.6.12) | Tip/Ring Sense Plug/Unplug Interrupt Mask (Section 7.6.22) | Note, however, that if $\overline{\text{INT}}$ is configured to operate in Short-Detect Mode (DETECT\_MODE = 1, see the DETECT\_MODE setting on p. 155), interrupt detection is otherwise disabled. - If set to short-detect only, $\overline{\text{INT}}$ is dedicated to the short-detection block of the headset interface; no other sources can trigger assertion of $\overline{\text{INT}}$ - If set to inactive (DETECT\_MODE = 00) Normal Mode (DETECT\_MODE = 11), INT responds to any unmasked interrupt status event. - After exiting Short-Detect Mode, previously asserted interrupt sources may generate additional interrupts. To avoid unwanted interrupts, clear the interrupt sources before exiting Short-Detect Mode. **Note:** Setting PDN\_ALL clears all interrupts, unless PDN\_MIC\_LVL\_DETECT = 0 and/or HSBIAS\_SENSE\_EN = 1, DETECT\_MODE ≠ 00, and an interrupt has occurred. To clear an interrupt, clear DETECT\_MODE. As Table 4-33 indicates, interrupt sources are categorized into two groups: - Condition-based interrupt source bits are set when the condition is present and they remain set until the register is read and the condition that caused the bit to assert is no longer present. - Event-based interrupt source bits are cleared when read. In the absence of subsequent source events, reading one of these status bits returns a 0. Table 4-33. Interrupt Source Types | Group | Status Registers | Interrupt Source Type | |----------------------------------------|------------------|-----------------------| | Tip sense and ring sense debounce (see | TS_UNPLUG_DBNC | Event | | Section 7.4.10) | TS_PLUG_DBNC | Event | | | RS_UNPLUG_DBNC | Event | | | RS_PLUG_DBNC | Event | | ADC (see Section 7.6.1) | ADC_OVFL | Event | | Mixer Interrupt | EQ_BIQUAD_OVFL | Event | | (see Section 7.6.2) | EQ_OVFL | Event | | · | MIX_CHA_OVFL | Event | | | MIX_CHB_OVFL | Event | | Serial port | ASPRX_OVLD | Event | | (see Section 7.6.3, Section 7.6.4, and | ASPRX_ERROR | Event | | Section 7.6.5) | ASPRX_LATE | Event | | | ASPRX_EARLY 1 | Event | | | ASPRX_NOLRCK 1 | Condition | | | ASPTX_SMERROR 1 | Event | | | ASPTX_LATE | Event | | | ASPTX_EARLY | Event | | | ASPTX_NOLRCK | Condition | | | SRC_OUNLK | Condition | | | SRC_IUNLK | Condition | | | SRC_OLK | Condition | | | SRC_ILK | Condition | | Global (see Section 7.6.6) | HSDET_AUTO_DONE | Event | | | PDN_DONE | Condition | | Table 4-33. | Interrupt Source | Types | (Cont.) | |-------------|------------------|-------|---------| | | | | | | Group | Status Registers | Interrupt Source Type | |--------------------------------------|-------------------|---------------------------------------------| | Headset (see Section 7.6.7 and | HSBIAS SENSE | All are events. | | Section 7.6.8) | TIP_SENSE_PLUG | | | | TIP_SENSE_UNPLUG | | | | DETECT_TRUE_FALSE | | | | DETECT_FALSE_TRUE | | | | SHORT_RELEASE | | | | SHORT_DETECTED | | | DAC and ADC (see Section 7.6.9) | DAC_LK | Condition | | , | ADC_LK | Condition | | VP monitor (see Section 7.6.10) | VPMON_TRIP | Condition | | PLL (see Section 7.6.11) | PLL_LOCK | Condition | | Tip sense and ring sense plug/unplug | TS_UNPLUG | Events. Although a true event interrupt | | status (see Section 7.6.12) | TS_PLUG | clears when read, these dynamically reflect | | | RS_UNPLUG | the state of the debounced input signal. | | | RS_PLUG | | <sup>1.</sup>Reading this bit following an early LRCK/SM error/no LRCK returns a 1. Subsequent reads return a 0. Valid LRCK transitions or exiting the transmit overflow condition rearms the detection of the corresponding event. See Table 4-18 for details. ## 4.19 FILT+ Operation FILT+ provides the internal voltage reference for the A/D and D/A converters. When powering-up the codec, FILT+ rises to its operating voltage in less than 10 ms when exiting from Power Down Mode (PDM) state. If the integrated fractional-N PLL, and/or headset-detection block is enabled while the ADC or headphone interface is disabled when FILT+ is at its operating voltage, FILT+ will start discharging and drop to 0 V. When the ADC or headphone interface is later enabled, it may take up to 1 second for FILT+ to rise again to its operating voltage. In this scenario, the ADC or headphone interface may begin operation before FILT+ is fully charged, causing unwanted distortion. To prevent this issue, set PDN\_ALL and SPDIF\_TX\_PDN, and clear PLL\_START before applying any recommended power-up sequence. # 5 System Applications This section provides recommended procedures and instruction sequences for standard operations. # 5.1 Power-Up Sequence **Note:** Set PDN\_ALL and SPDIF\_TX\_PDN, and clear PLL\_START before applying any recommended power-up sequence. Ex. 5-1 is the procedure for implementing HP playback from the ASP. This example sequence configures the CS42L42 for SCLK = 12.288 MHz, LRCK = 48 kHz, and TDM playback, in Slave Mode. Example 5-1. Power-Up Sequence | ГЕР | | Task | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | |-----|------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | Appl | y all relevant power | supplies, then assert RST before applying SCLK an | d LRCK to the | e CS42L42. | | 2 | Wait | 2.5 ms. | | | | | 3 | Pow | er up the codec. | Power Down Control 2. 0x1102 | 0x83 | | | | | | Reserved DISCHARGE_FILT+ SRC_PDN_OVERRIDE ASP_DAI1_PDN DAC_SRC_PDNB | 100<br>0<br>0<br>0<br>1 | — FILT+ is not clamped to ground. SRC is powered up. ASP is powered up. DAC SRC is powered up. | | | | | ADC_SRC_PDNB | 1 | ADC SRC is powered up. | | | | figure the device's A | SP and ASP SRC. | | | | | | Configure switch | Oscillator Switch Control. 0x1107 | 0x01 | | | | | from RCO to SCLK. | Reserved<br>SCLK_PRESENT | 0000 000<br>1 | SCLK is present. | | | | Power down the | Oscillator Switch Status. 0x1109 | 0x01 | | | | | RCO. | Reserved OSC_PDNB_STAT OSC_SW_SEL_STAT | 0000 0<br>0<br>01 | RCO powered down RCO selected for internal MCLK | | | | Configure device's | MCLK Control. 0x1009 | 0x02 | | | | | internal sample rate<br>with the applied<br>MCLK signal. | Reserved INTERNAL_FS Reserved | 0000 00<br>1<br>0 | Internal sample rate is MCLK/256= 48 kHz. | | | | Select MCLK | MCLK Source Select. 0x1201 | 0x00 | | | | | source. | Reserved | 0000 00 | <del></del> | | | | | MCLKDIV<br>MCLK SRC SEL | 0<br>0 | Divide by 1. SCLK pin is MCLK source. | | | 15 | Configure the | FSYNC Period, Lower Byte. 0x1205 | 0xFF | SCEN PILL IS MICEN SOUICE. | | | | FSYNC period. | FSYNC PERIOD LB | | 256 SCLKs per LRCK lower byte. | | | | Configure the | FSYNC Period, Upper Byte. 0x1206 | 0x00 | 230 SCLNS per LNCN lower byte. | | | | FSYNC period. | FSYNC PERIOD UB | | 00 SCLKs per LRCK upper byte | | | | · · | FSYNC Pulse Width, Lower Byte. 0x1203 | 0000 0000<br>0x1F | 30 SCENS per ENON apper byte | | | | pulse width. | FSYNC PULSE WIDTH LB | | LRCK is one SCLK Wide. | | | | • | | 0x00 | LRCK IS ONE SCLK WIDE. | | | | clock. | ASP Clock Configuration 1. 0x1207 | 00 | | | | | | Reserved ASP_SCLK_EN ASP_HYBRID_MODE ASP_SCPOL_IN_ADC ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN | 0<br>0<br>0<br>0<br>0 | ASP SCLK disabled. LRCK is an input from an external source. SCLK input drive polarity for ADC is normal. SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. | | | | | ASP Frame Configuration. 0x1208 | 0x10 | | | | | frame. | Reserved ASP_STP ASP_5050 ASP_FSD | 000<br>1<br>0<br>000 | Frame begins when LRCK transitions low to high LRCK duty cycle per FSYNC_PULSE_WIDTH_LB/U Zero SCLK frame start delay | | | 4.10 | Configure the | Serial Port Receive Isochronous Control. 0x2502 | 0x04 | | | | | AudioPort interface. | Reserved SP_RX_RSYNC Reserved SP_RX_ISOC_MODE | 0<br>0<br>00 01<br>00 | — Serial port default receive synchronization. — Serial port receive in native mode. | | | 4.11 | Configure serial port | Serial Port Receive Channel Select. 0x2501 | 0x04 | • | | | | receive channel positions. | Reserved SP_RX_CHB_SEL SP_RX_CHA_SEL | 0000<br>01<br>00 | SP RX Channel B position is 1.<br>SP RX Channel A position is 0. | | | Task | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | |-----|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | Serial Port Receive Sample Rate. 0x2503 | 0x8C | | | | rate. | Reserved<br>SP RX FS | 100<br>0 1100 | — SP receive sample rate = 48 kHz. | | | 4.13Configure the ASP | ASP Receive Enable. 0x2A01 | 0x00 | SP Teceive Sample rate – 46 kmz. | | | receiver. | ASP RX1 CH[2:1] EN | 00 | RX1 buffer is disabled. | | | | ASP_RX0_CH[4:1]_EN | 00 00 | RX0 buffer is disabled. | | | | ASP_RX1_2FS | 0 | ASP DAI1 is standard sample rate. | | | | ASP_RX0_2FS | 0 | ASP DAI0 is standard sample rate. | | | 4.14 Configure Channel 1<br>size to 24 bits per<br>sample. | ASP Receive DAI0 Channel 1 Phase and Resolution. 0x2A02 | 0x02 | | | | sample. | Reserved<br>ASP RX0 CH1 AP | 0<br>0 | In 50/50 mode, channel data valid if LRCK is low. | | | | Reserved | 0000 | — Charmer data valid if ERCK is low. | | | | ASP_RX_CH1_RES | 10 | Size is 24 bits per sample. | | | 4.15Configure location of | ASP Receive DAI0 Channel 1 Bit Start MSB. 0x2A03 | 0x00 | | | | the Channel 1 MSB with respect to SOF. | Reserved | 0000 0000 | | | | · | AGI _100_CITI_DIT_GT_WOD | 0 | ASP receive bit start MSB = 0. | | | 4.16 Configure location of<br>the Channel 1 LSB | ASP Receive DAI0 Channel 1 Bit Start LSB. 0x2A04 | 0x00 | | | | with respect to SOF. | ASP_RX0_CH1_BIT_ST_LSB | 0000 0000 | DASP transmit bit start LSB = 0. | | | | SRC Input Sample Rate. 0x2601 | 0x40 | | | | sample rate detection. | Reserved | 010 | ASD comple rate is suited at a d | | | | SRC_SDIN_FS | | ASP sample rate is autodetected. | | | | ASP Receive DAI0 Channel 2 Phase and Resolution. 0x2A05 | | | | | <b> P-12-1</b> | Reserved<br>ASP_RX0_CH2_AP | 0<br>0 | In 50/50 mode, channel data valid if LRCK is low. | | | | Reserved | 00 00 | _ | | | | ASP_RX_CH2_RES | 10 | Size is 24 bits per sample. | | | 4.19Configure location of<br>the Channel 2 MSB | ASP Receive DAI0 Channel 2 Bit Start MSB. 0x2A06 | 0x00 | | | | with respect to SOF. | Reserved ASP_RX0_CH2_BIT_ST_MSB | 0000 000 | ASP receive bit start MSB = 0. | | | • | ASP Receive DAI0 Channel 2 Bit Start LSB. 0x2A07 | 0x18 | ASP receive bit start WSB = 0. | | | the Channel 2 LSB<br>with respect to SOF. | ASP RX0 CH2 BIT ST LSB | | ASP transmit bit start LSB = 24. | | | 4.21Disable the SRC | Serial Port SRC Control. 0x1007 | 0x10 | | | | bypass. | Reserved | 000 | _ | | | | EQ_BYPASS | 1 | Bypass equalizer | | | | I2C_DRIVE<br>ASP DRIVE | 0<br>0 | I <sup>2</sup> C output drive strength normal ASP output drive strength normal | | | | SRC_BYPASS_DAC | 0 | SRC not bypassed for DAC path | | | | SRC_BYPASS_ADC | 0 | SRC not bypassed for ADC path | | 5 | Enable SCLK. | ASP Clock Configuration 1. 0x1207 | 0x20 | | | | | Reserved<br>ASP SCLK EN | 00<br>1 | ASP SCLK enabled. | | | | ASP HYBRID MODE | Ó | LRCK is an input generated from SCLK. | | | | | | | | | | ASP_SCPOL_IN_ADC | 0 | SCLK input drive polarity for ADC is normal. | | | | ASP SCPOL IN DAC | 0 | SCLK input drive polarity for DAC is normal. | | | | | | | | | | ASP_SCPOL_IN_DAC<br>ASP_LCPOL_OUT | 0 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. | | | Enable the ASP receiver channels. | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP Receive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN | 0<br>0<br>0 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. | | | | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_Receive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN ASP_RX0_CH[4:1]_EN | 0<br>0<br>0<br>0<br>0x3C<br>00<br>11 11 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. | | | | ASP-SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_Receive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN ASP_RX0_CH[4:1]_EN ASP_RX1_2FS | 0<br>0<br>0<br>0<br>0x3C<br>00<br>11 11<br>0 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. ASP DAI1 is standard sample rate. | | | channels. | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_Receive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN ASP_RX0_CH[4:1]_EN | 0<br>0<br>0<br>0<br>0x3C<br>00<br>11 11 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. | | | | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_REceive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN ASP_RX0_CH[4:1]_EN ASP_RX1_2FS ASP_RX0_2FS | 0<br>0<br>0<br>0x3C<br>00<br>11 11<br>0 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. ASP DAI1 is standard sample rate. | | | channels. | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_REceive Enable. 0x2A01 ASP_RX1_CH[2:1] EN ASP_RX0_CH[4:1] EN ASP_RX1_2FS ASP_RX0_2FS DAC Control 1. 0x1F01 Reserved DACB_INV | 0<br>0<br>0<br>0<br>0x3C<br>00<br>11 11<br>0<br>0<br>0x00<br>0x00 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. ASP DAI1 is standard sample rate. ASP DAI0 is standard sample rate. DACA signal not inverted. | | 7 | channels. Configure the DAC. | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_REceive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN ASP_RX0_CH[4:1]_EN ASP_RX1_2FS ASP_RX0_2FS DAC Control 1. 0x1F01 Reserved DACB_INV DACA_INV | 0<br>0<br>0<br>0x3C<br>00<br>11 11<br>0<br>0x00<br>0x00 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. ASP DAI1 is standard sample rate. ASP DAI0 is standard sample rate. | | 7 | Configure the DAC. Configure the appropriate | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_REceive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN ASP_RX0_CH[4:1]_EN ASP_RX1_2FS ASP_RX0_2FS DAC Control 1. 0x1F01 Reserved DACB_INV DACA_INV evolume controls and DAC source selects. | 0<br>0<br>0<br>0<br>0<br>0<br>11 11<br>0<br>0<br>0<br>0x00<br>0x00<br>0000 00<br>0 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. ASP DAI1 is standard sample rate. ASP DAI0 is standard sample rate. DACA signal not inverted. | | 7 | Configure the DAC. Configure the appropriate 8.1 Set Mixer A input to | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_REceive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN ASP_RX0_CH[4:1]_EN ASP_RX1_2FS ASP_RX0_2FS DAC Control 1. 0x1F01 Reserved DACB_INV DACA_INV evolume controls and DAC source selects. Mixer Channel A Input Volume. 0x2301 | 0<br>0<br>0<br>0<br>0x3C<br>00<br>11 11<br>0<br>0<br>0x00<br>0x00<br>0<br>0x00 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. ASP DAI1 is standard sample rate. ASP DAI0 is standard sample rate. DACA signal not inverted. | | 7 · | Configure the DAC. Configure the appropriate | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_REceive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN ASP_RX0_CH[4:1]_EN ASP_RX1_2FS ASP_RX0_2FS DAC Control 1. 0x1F01 Reserved DACB_INV DACA_INV evolume controls and DAC source selects. Mixer Channel A Input Volume. 0x2301 Reserved Reserved | 0<br>0<br>0<br>0<br>0<br>0<br>11 11<br>0<br>0<br>0<br>0<br>0000 00<br>0<br>0<br>0 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. ASP DAI1 is standard sample rate. ASP DAI0 is standard sample rate. DACA signal not inverted. DACB signal not inverted. | | 7 | Configure the DAC. Configure the appropriate 8.1 Set Mixer A input to 0 dB. | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_REceive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN ASP_RX0_CH[4:1]_EN ASP_RX1_2FS ASP_RX0_2FS DAC Control 1. 0x1F01 Reserved DACB_INV DACA_INV evolume controls and DAC source selects. Mixer Channel A Input Volume. 0x2301 Reserved MIXER_CHA_VOL | 0<br>0<br>0<br>0<br>0<br>0<br>11 11<br>0<br>0<br>0<br>0<br>0000 00<br>0<br>0<br>0 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. ASP DAI1 is standard sample rate. ASP DAI0 is standard sample rate. DACA signal not inverted. | | 7 | Configure the DAC. Configure the appropriate 8.1 Set Mixer A input to 0 dB. | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_REceive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN ASP_RX0_CH[4:1]_EN ASP_RX1_2FS ASP_RX0_2FS DAC Control 1. 0x1F01 Reserved DACB_INV DACA_INV evolume controls and DAC source selects. Mixer Channel A Input Volume. 0x2301 Reserved MIXER_CHA_VOL Mixer ADC Input Volume. 0x2302 | 0<br>0<br>0<br>0<br>0<br>0<br>11 11<br>0<br>0<br>0<br>0<br>0000 00<br>0<br>0<br>0 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. ASP DAI1 is standard sample rate. ASP DAI0 is standard sample rate. DACA signal not inverted. DACB signal not inverted. | | 7 | Configure the DAC. Configure the appropriate 8.1 Set Mixer A input to 0 dB. 8.2 Mute the mixer ADC | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_REceive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN ASP_RX0_CH[4:1]_EN ASP_RX1_2FS ASP_RX0_2FS DAC Control 1. 0x1F01 Reserved DACB_INV DACA_INV evolume controls and DAC source selects. Mixer Channel A Input Volume. 0x2301 Reserved MIXER_CHA_VOL | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>11 11<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. ASP DAI1 is standard sample rate. ASP DAI0 is standard sample rate. DACA signal not inverted. DACB signal not inverted. | | 7 | Configure the DAC. Configure the appropriate 8.1 Set Mixer A input to 0 dB. 8.2 Mute the mixer ADC input 8.3 Set Mixer B input to | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_REceive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN ASP_RX0_CH[4:1]_EN ASP_RX1_2FS ASP_RX0_2FS DAC Control 1. 0x1F01 Reserved DACB_INV DACA_INV evolume controls and DAC source selects. Mixer Channel A Input Volume. 0x2301 Reserved MIXER_CHA_VOL Mixer ADC Input Volume. 0x2302 Reserved | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>11 11<br>0<br>0<br>0<br>0<br>0000 00<br>0<br>0<br>0 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. ASP DAI1 is standard sample rate. ASP DAI0 is standard sample rate. — DACA signal not inverted. DACB signal not inverted. — Input A is set to 0 dB. | | 3 | Configure the DAC. Configure the appropriate 8.1 Set Mixer A input to 0 dB. 8.2 Mute the mixer ADC input | ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN ASP_REceive Enable. 0x2A01 ASP_RX1_CH[2:1]_EN ASP_RX0_CH[4:1]_EN ASP_RX1_2FS ASP_RX0_2FS DAC Control 1. 0x1F01 Reserved DACB_INV DACA_INV evolume controls and DAC source selects. Mixer Channel A Input Volume. 0x2301 Reserved MIXER_CHA_VOL Mixer ADC Input Volume. 0x2302 Reserved MIXER_ADC_VOL | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>11 11<br>0<br>0<br>0<br>0000 00<br>0<br>0<br>0 | SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. RX1 buffer is disabled. RX0 buffer is enabled. ASP DAI1 is standard sample rate. ASP DAI0 is standard sample rate. — DACA signal not inverted. DACB signal not inverted. — Input A is set to 0 dB. | | TEP | TASK | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | |---------|----------------------------------------------|------------------------------|-------|------------------------------------------------| | 9 Conf | Configure the HP control. HP Control. 0x2001 | | 0x03 | | | | | Reserved | 0000 | _ | | | | ANA MUTE B | 0 | Channel B is unmuted. | | | | ANA MUTE A | 0 | Channel A is unmuted. | | | | FULŪ SCALĒ VOL | 1 | Full-scale volume is -6dB for headphone output | | | | Reserved | 1 | <del>_</del> | | 10 Powe | er up the codec | Power Down Control 1. 0x1101 | 0x96 | | | | | ASP DAO PDN | 1 | ASP output path is powered down. | | | | ASP DAI PDN | 0 | ASP input path is powered up. | | | | MIXĒR PĪN | 0 | Mixer is powered up. | | | | EQ PDN | 1 | Equalizer powered down | | | | HP PDN | 0 | HPOUT powered up. | | | | ADC PDN | 1 | ADC powered down. | | | | Reserved | 1 | <u> </u> | | | | PDN ALL | 0 | Codec powered up. | # 5.2 Power-Down Sequence 11 The headphone amplifier is operational after 10 ms. Ex. 5-2 is the procedure for powering down the HP playback. #### **Example 5-2. Power-Down Sequence** | STEP | TASK | | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | |------|-------|-----------------------|---------------------------------------------------------------------------------------------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | . Cor | nfigure the DAC/Mixer | Channels. | | | | | 1.1 | Mute Mixer A input. | Mixer Channel A Input Volume. 0x2301 | 0x3F | | | | | | Reserved<br>MIXER_CHA_VOL | 00<br>11 1111 | Input A is muted. | | | 1.2 | Mute Mixer A input. | Mixer ADC Input Volume. 0x2302 | 0x3F | | | | | | Reserved<br>MIXER_ADC_VOL | 00<br>11 1111 | Mixer ADC input is muted. | | | 1.3 | Mute Mixer B input. | Mixer Channel B Input Volume. 0x2303 | 0x3F | | | | | | Reserved<br>MIXER_CHB_VOL | | Input B is muted. | | | 1.4 | Mute Channel A and | HP Control. 0x2001 | 0x0F | | | | | B inputs. | Reserved ANA_MUTE_B ANA_MUTE_A FULL_SCALE_VOL Reserved | 0000<br>1<br>1<br>1<br>1 | Channel B is muted. Channel A is muted. Full-scale volume is –6 dB for headphone output. | | | 1.5 | Disable ASP_TX. | ASP Receive Enable. 0x2A01 | 0x00 | | | | | | ASP_RX1_CH[2:1]_EN<br>ASP_RX0_CH[4:1]_EN<br>ASP_RX1_2FS<br>ASP_RX0_2FS | 00<br>00 00<br>0<br>0 | RX1 buffer is disabled. RX0 buffer is disabled. ASP DAI1 is standard sample rate. ASP DAI0 is standard sample rate. | | | 1.6 | Disable SCLK. | ASP Clock Configuration 1. 0x1207 | 0x00 | | | | | | Reserved ASP_SCLK_EN ASP_HYBRID_MODE ASP_SCPOL_IN_ADC ASP_SCPOL_IN_DAC ASP_LCPOL_OUT ASP_LCPOL_IN | 00<br>0<br>0<br>0<br>0<br>0 | ASP SCLK disabled. LRCK is an output generated from SCLK. SCLK input drive polarity for ADC is normal. SCLK input drive polarity for DAC is normal. LRCK output drive polarity is normal. LRCK input polarity (pad to logic) is normal. | | | | er down the HP | Power Down Control 1. 0x1101 | 0xFE | | | | ampl | ifier. | ASP_DAO_PDN ASP_DAI_PDN MIXER_PDN EQ_PDN HP_PDN ADC_PDN Reserved PDN_ALL | 1<br>1<br>1<br>1<br>1<br>1<br>1 | ASP output path powered down ASP SDOUT input path is powered down Mixer is powered down Equalizer powered down HPOUT powered down ADC powered down Codec powered up | | | | er down the ASP and | Power Down Control 2. 0x1102 | 0x8C | | | | SRC | | Reserved DISCHARGE_FILT+ SRC_PDN_OVERRIDE ASP_DAI1_PDN DAC_SRC_PDNB ADC_SRC_PDNB | 100<br>0<br>1<br>1<br>0<br>0 | FILT+ is not clamped to ground. SRC is powered down. ASP is powered down. DAC SRC is powered down. ADC SRC is powered down. ADC SRC is powered down. | | Example 5-2, P | Power-Down | Sequence | (Cont.) | |----------------|------------|----------|---------| |----------------|------------|----------|---------| | STEP | TASK | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | |------|-------------------------------|-----------------------------------------------|-------------|-----------------------------------------| | 4 | Power down the codec. | Power Down Control 1. 0x1101 | 0xFF | | | | | ASP_DAO_PDN | 1 | ASP output path powered down | | | | ASP_DAI_PDN | 1 | ASP SDOUT input path is powered down | | | | MIXĒR_PDN | 1 | Mixer is powered down | | | | EQ_PDN | 1 | Equalizer powered down | | | | HP_PDN | 1 | HPOUT powered down | | | | ADC_PDN | 1 | ADC powered down | | | | Reserved | 1 | | | | | PDN_ALL | 1 | Codec powered down. | | 5 | Read PDN_DONE to | Codec Interrupt Status. 0x1308 | 0x01 | | | | confirm that the codec is | Reserved | 0000 00 | _ | | | completely powered down. | HSDET AUTO DONE | 0 | HS detection is disabled or incomplete. | | | | PDN_DŌNE _ | 1 | Power-down done. | | 6 | Repeat Step 5 until the PD | N_DONE status bit indicates the codec has pov | wered down. | | | 7 | Discharge the capacitor | Power Down Control 2. 0x1102 | 0x9C | | | | attached to the FILT+ pin. | Reserved | 100 | _ | | | | DISCHARGE FILT+ | 1 | FILT+ is clamped to ground. | | | | SRC PDN OVERRIDE | 1 | SRC is powered down. | | | | ASP_DAI1_PDN | 1 | ASP is powered down. | | | | DAC_SRC_PDNB | 0 | DAC SRC is powered down. | | | | ADC_SRC_PDNB | 0 | ADC SRC is powered down. | | 8 | If required, remove the SCI | _K signal. | | | | 9 | If required, remove all relev | ant power supplies from the codec. | | | ## 5.3 SoundWire Power Sequences This section provides SoundWire power-up and power-down sequences. ### 5.3.1 SoundWire Power-Up Sequence Ex. 5-3 is the procedure for implementing ADC record, HP playback, and S/PDIF Tx playback from SoundWire. This sequence configures the CS42L42 for SWIRE\_CLK = 12.288 MHz, 48-kHz sample interval rate, and a 64 x 8 SoundWire frame, as described in Ex. 4-3. This example is a minimum configuration specifically for Ex. 4-3. Different SWIRE\_CLK, sample interval rates, or SoundWire frames may require additional configurations. Example 5-3. SoundWire Power-Up Sequence | STER | <b>)</b> | TASK | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | | | |------|-------------------------------------------------------------------------------|------------------------------------|------------------------------------------------------|----------------------|-----------------------------------|--|--| | 1 | | v all relevant power supp | lies, then assert RESET before applying SWIRE_CLK to | the CS42L4 | 42. | | | | 2 | 2 Enumerate the codec. | | | | | | | | | 2.1 Read SCP Device ID 0, 1, 2, 3, 4, and 5 and confirm the codec device IDs. | | | | | | | | | 2.2 | Assign Group ID and | SCP Device Number. Base + 0x46 | 0x01 | | | | | | | device number | Reserved<br>GROUP_ID<br>DEVICE_NUMBER | 00<br>00<br>0001 | Group ID device number | | | | 3 | Wait | for 2.5 ms for codec inte | | | | | | | 4 | | igure the device's clockir | | | | | | | | 4.1 | Configure switch from RCO to SCLK. | Oscillator Switch Control. 0x1107 | 0x01 | | | | | | | | Reserved | 0000 0000 | | | | | | | | SCLK_PRESENT | 1 | SCLK is present. | | | | | 4.2 | Confirm the RCO is | Oscillator Switch Status. 0x1109 | 0x01 | Read (repeat until value is 0x01) | | | | | | powered down | Reserved | 0000 0 | _ | | | | | | | OSC_PDNB_STAT | 0 | RCO powered down | | | | _ | | | OSC_SW_SEL_STAT | 01 | RCO selected for internal MCLK | | | | 5 | | 0 11 1 | ume controls and DAC source selects | | | | | | | 5.1 | Set Mixer A input to 0 dB | Mixer Channel A Input Volume. 0x2301 | 0x3F | | | | | | | | Reserved<br>MIXER_CHA_VOL | 00<br>11 1111 | —<br>Mixer ADC is set muted. | | | | | 5.2 | Set Mixer B input to 0 dB | Mixer Channel B Input Volume. 0x2303 | 0x00 | | | | | | | | Reserved<br>MIXER_CHB_VOL | 00<br>00<br>00<br>00 | Input B is set to 0 dB. | | | ### Example 5-3. SoundWire Power-Up Sequence (Cont.) | TASK | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | |----------------------------------------------|------------------------------------------------------------|--------------|-----------------------------------------------------------| | Configure the HP control. | HP Control. 0x2001 | 0x01 | | | | Reserved | 0000 | <del></del> | | | ANA_MUTE_B<br>ANA_MUTE_A | 0<br>0 | Channel B is unmuted. Channel A is unmuted. | | | FULL SCALE VOL | 0 | Full-scale volume is 0 dB for headphone out | | | Reserved | ĭ | — | | Configure S/PDIF clocking | S/PDIF Clock Configuration. 0x1202 | 80x0 | | | | Reserved | 00 | | | | SPDIF_CLK_DIV<br>SPDIF_LRCK_SRC_SEL | 00 1 | S/PDIF clock divide factor of 2. | | | SPDIF_LRCLK_CPOL | 0<br>0 | Use internally generated LRCLK Normal LRCLK polarity | | | Reserved | ŏ | — | | Configure the S/PDIF control. | S/PDIF Control 2. 0x2802 | 0x01 | | | 3 | SPDIF TX L | 0 | This data stream is a copy. | | | SPDIF_TX_PRO | ŏ | Consumer format | | | SPDIF_TX_AUDIOB | 0 | PCM format | | | SPDIF_TX_CP | 0 | Copy inhibited | | | SPDIF_TX_PRE<br>SPDIF_TX_VCFG | 0<br>0 | No preemphasis Validity bit follows internal codec status | | | SPDIF TX V | Ö | Validity bit follows internal codec status | | | SPDIF_TX_DIGEN | 1 | Enable S/PDIF Transmit | | Power up S/PDIF transmitter. | | 0x00 | | | | SPDIF_TX_RAW | 0 | S/PDIF outputs 24-bit data with control info | | | SPDIF_TX_KAE | 0 | Don't care | | D | SPDIF_TX_PDN | 0 | Power up S/PDIF transmitter | | Power up the codec. | Power Down Control 1. 0x1101 | 0xD2 | | | | ASP_DAO_PDN | 1 | ASP output path is powered down. | | | ASP <sup>-</sup> DAI PDN<br>MIXER PDN | 1<br>0 | ASP input path is powered down. Mixer is powered up. | | | EQ PDN | 1 | Equalizer is powered down | | | HP PDN | Ö | HPOUT is powered up. | | | ADC_PDN | 0 | ADC is powered up. | | | Reserved | 1<br>0 | — Codes is newered up | | Carferina Danta 4 44 acres as | PDN_ALL | U | Codec is powered up. | | Configure Ports 1-14 common | <u> </u> | 0,,00 | | | 11.1 Ports 1-14 Control | DP1-14 Port Control (Section 7.2.3). 0x0F02 | 0x00 | | | | Reserved<br>INVERT BANK | 000<br>0 | Use bank as directed in the control word | | | PORT DATA MODE | 00 | Normal port mode | | | Reserved | 00 | _ ' | | 11.2 Ports 1-14 Block Contro | DP1-14 Block Control 1 (Section 7.2.4). 0x0F03 | 0x17 | | | | Reserved | 00 | OA hit data | | 44.0.00.14.00.1.00.1 | WORD_LENGTH | | 24-bit data | | 11.3 Port 1-14 Sample Contro<br>1—Bank 1 | I DP1-14 Sample Control 1 (Banked, Section 7.2.8). 0x0F32 | 0xFF | | | | SAMPLE_INTERVAL_LOW | 1111 111 | 1 Sample interval = 512 | | 11.4 Port 1-14 Sample Contro<br>2—Bank 1 | DP1-14 Sample Control 2 (Banked, Section 7.2.9). 0x0F33 | 0x01 | | | | SAMPLE_INTERVAL_HIGH | 0000 0000 | 1 Sample interval = 512 | | 11.5 Ports 1-14 Horizontal<br>Control—Bank 1 | DP1-14 Horizontal Control (Banked, Section 7.2.12). 0x0F36 | 0x17 | | | | HSTART<br>HSTOP | 0001<br>0111 | Subframe begins in Column 1<br>Subframe ends in Column 7 | | 11.6 Ports 1-14 Block<br>Control 3—Bank 1 | DP1-14 Block Control 3 (Banked, Section 7.2.13). 0x0F37 | 0x00 | | | | Reserved | 0000 0000 | ) — | | | BLOCK PACKING MODE | 0 | Block-per-Port Mode | | P | Task | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | |-------|-------------------------------------|---------------------------------------------------------|-------------------|------------------------------------------------------------------------------------------------------------------| | | figure Ports 1 (ADC) | NEGIOTEIV <b>E</b> IT TIEEES | VALUE | DESCRIPTION | | | | -DP1 Offset Control 1 (Banked, Section 7.2.10). 0x0134 | 0x00 | | | | Bank 1 | OFFSET1 | 0000 0000 | Block offset = 0 | | 12.2 | Port 1 Offset Control 2— | -DP1 Offset Control 2 (Banked, Section 7.2.11). 0x0135 | 0x00 | | | | Bank 1 | OFFSET2 | 0000 0000 | Block offset = 0 | | 12.3 | Port 1 Prepare Control | DP1 Prepare Control (Section 7.2.6). 0x0105 | 0x01 | | | | · | Reserved | 000000 | | | | | PREPARE_CHANNEL2<br>PREPARE_CHANNEL1 | 0<br>1 | Channel deactivated Channel commanded to prepare for activity | | 12.4 | Read Port 1 prepare | DP1 Prepare Status (Section 7.2.5). 0x0104 | 0x00 | | | | Status. Repeat until value is 0x00. | Reserved NOT_FINISHED_CHANNEL2 NOT_FINISHED_CHANNEL1 | 0000 00<br>0<br>0 | — Channel finished Channel finished | | 12.5 | Port 1 Channel Enable- | -DP1 Channel Enable (Banked, Section 7.2.7). 0x0130 | 0x01 | | | | Bank 1 | Reserved | 000000 | _ | | | | CHANNEL_EN2<br>CHANNEL_EN1 | 0 | Channel disabled<br>Channel enabled | | | figure Port 2 (headphone | | | | | 13.1 | Port 2 Offset Control 1—<br>Bank 1 | -DP2 Offset Control 1 (Banked, Section 7.2.10). 0x0234 | 0x1C | | | | | OFFSET1 | | Block offset = 28 | | 13.2 | Port 2 Offset Control 2—<br>Bank 1 | -DP2 Offset Control 2 (Banked, Section 7.2.11). 0x0235 | 0x00 | | | | | OFFSET2 | | Block offset = 28 | | 13.3 | Port 2 Prepare Control | DP2 Prepare Control (Section 7.2.6). 0x0205 | 0x03 | | | | | Reserved PREPARE_CHANNEL2 PREPARE_CHANNEL1 | 0000 00<br>1<br>1 | <ul> <li>Channel commanded to prepare for activity</li> <li>Channel commanded to prepare for activity</li> </ul> | | 13.4 | Read Port 2 Prepare | DP2 Prepare Status (Section 7.2.5). 0x0204 | 0x00 | · · · · · · · · · | | | Status. Repeat until | Reserved | 000000 | _ | | | value is 0x00. | NOT_FINISHED_CHANNEL2<br>NOT_FINISHED_CHANNEL1 | 0<br>0 | Channel finished Channel finished | | 13.5 | | -DP2 Channel Enable (Banked, Section 7.2.7). 0x0230 | 0x03 | | | | Bank 1 | Reserved | 000000 | | | | | CHANNEL_EN2<br>CHANNEL_EN1 | 1<br>1 | Channel enabled<br>Channel enabled | | Con | figure Port 3 (S/PDIF data | <del>_</del> | ' | Grianner enabled | | | <u> </u> | - DP3 Offset Control 1 (Banked, Section 7.2.10). 0x0334 | 0x54 | | | 17.1 | Bank 1 | OFFSET1 | | Block offset = 84 | | 14 2 | Port 3 Offset Control 2— | - DP3 Offset Control 2 (Banked, Section 7.2.11). 0x0335 | 0x00 | y Diodit Chioct O4 | | 17.2 | Bank 1 | OFFSET2 | | Block offset = 84 | | 14.3 | Port 3 Prepare Control | DP3 Prepare Control (Section 7.2.6). 0x0305 | 0x03 | y Diodit Chock O4 | | 14.0 | or or or repaire control | Reserved | 000000 | _ | | | | PREPARE_CHANNEL2<br>PREPARE_CHANNEL1 | 1 | Channel commanded to prepare for activity Channel commanded to prepare for activity | | 14.4 | Read Port 3 prepare | DP3 Prepare Status (Section 7.2.5). 0x0304 | 0x00 | | | | status. Repeat until value is 0x00. | Reserved | 0000 00 | | | | | NOT_FINISHED_CHANNEL2<br>NOT_FINISHED_CHANNEL1 | 0 | Channel finished<br>Channel finished | | 14.5 | | -DP3 Channel Enable (Banked, Section 7.2.7). 0x0330 | 0x03 | | | | Bank 1 | Reserved | 0000 00 | Channel analysis | | | | CHANNEL_EN2<br>CHANNEL_EN1 | 1<br>1 | Channel enabled<br>Channel enabled | | SCF | P Frame Control—Bank 1 | | 0x1B | Trigger bank switch to Bank 1 | | - 501 | amo control bank l | ROW CONTROL | 0001 1 | 64 rows | | | | COLUMN CONTROL | 011 | 8 columns | ## 5.3.2 SoundWire Power-Down Sequence with Clock Stop Ex. 5-4 powers down ADC record, HP playback, and S/PDIF Tx playback from SoundWire. This example sequence is a minimum configuration specifically for Ex. 4-3. This sequence configures the CS42L42 for SWIRE\_CLK = 12.288 MHz, 48-kHz sample-interval rate, and 64 x 8 SoundWire frame, as described in Ex. 4-3. Different SWIRE\_CLK, sample interval rates, or SoundWire frames may require additional configurations. If clock stop is not used, omit Steps 10-15. This procedure assumes that Bank 1 is the initial active SoundWire register bank. **Example 5-4. SoundWire Power-Down Sequence** | STEP | 1 | Task | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | |------|-------|----------------------------------------------------|-----------------------------------------------------------|-----------------|-------------------------------------------------------------------| | 1 | Conf | igure the DAC/ADC mixe | | | | | | 1.1 | Mute Mixer A input. | Mixer Channel A Input Volume. 0x2301 | 0x3F | | | | | | Reserved<br>MIXER_CHA_VOL | 00<br>11 1111 | — Input A is muted. | | | 1.2 | Mute the mixer ADC | Mixer ADC Input Volume. 0x2302 | 0x3F | · | | | | input. | Reserved | 00 | | | | 4.0 | Mada Missa Disasa | MIXER_ADC_VOL | | Mixer ADC input is muted. | | | 1.3 | Mute Mixer B input. | Mixer Channel B Input Volume. 0x2303 Reserved | 0x3F<br>00 | | | | | | MIXER_CHB_VOL | | Input B is muted. | | | 1.4 | Mute Channel A and B | HP Control. 0x2001 | 0x0F | <u> </u> | | | | inputs. | Reserved | 0000 | | | | | | ANA_MUTE_B<br>ANA_MUTE_A | 1 | Channel B is muted. Channel A is muted. | | | | | FULI_SCALE_VOL | 1 | Full-scale volume is –6 dB for headphone output. | | 0 | Disal | his Dawid O O shammala | Reserved | 1 | | | 2 | 2.1 | ble Port 1, 2, 3 channels Write to inactive Bank 0 | DP1–14 Channel Enable 0x0F20 | 0x00 | | | | 2.1 | (Port 1–14 Channel | Reserved | 000000 | _ | | | | Énable–Bank 0) | CHANNEL EN2 | 0 | Channel disabled | | | | | CHANNEL_EN1 | 0 | Channel disabled | | | 2.2 | Write. Trigger bank switch to Bank 0. | SCP Frame Control (Banked, Section 7.1.12). 0 ROW CONTROL | | C4 ****** | | | | | COLUMN_CONTROL | 0001 1 | 64 rows<br>8 columns | | 3 | Depr | epare Ports 1–3 | <del>-</del> | | | | | 3.1 | Write Port 1–14 Prepare | DP1–14 Prepare Control 0x0F05 | 0x00 | | | | | Control | Reserved | 0000 00 | | | | | | PREPARE_CHANNEL2<br>PREPARE_CHANNEL1 | 0 | Channel deactivated Channel deactivated | | | 3.2 | Read Port 1 Prepare | DP1 Prepare Status (Section 7.2.5). 0x0104 | 0x00 | | | | | Status. Repeat until value is 0x00. | Reserved | 000 000 | | | | | | NOT_FINISHED_CHANNEL1 | 0 | Channel finished | | | 3.3 | Read Port 2 Prepare<br>Status. Repeat until | DP2 Prepare Status (Section 7.2.5). 0x0204 Reserved | 0x00<br>0000 00 | | | | | value is 0x00. | NOT FINISHED CHANNEL2 | 0000 00 | Channel finished | | | | | NOT_FINISHED_CHANNEL1 | 0 | Channel finished | | | 3.4 | Read Port 3 Prepare<br>Status. Repeat until | DP3 Prepare Status (Section 7.2.5). 0x0304 | 0x00 | | | | | value is 0x00. | Reserved<br>NOT_FINISHED_CHANNEL2 | 0000 00 | — Channel finished | | | | | NOT_FINISHED_CHANNEL1 | Ö | Channel finished | | 4 | | er down S/PDIF | S/PDIF Control 1. 0x2801 | 0x01 | | | | แลกร | smitter. | Reserved<br>SPDIF TX RAW | 0000 0 | Reserved S/PDIF outputs 24-bit data with control info | | | | | SPDIF_TX_KAE | 0 | Don't care | | | | | SPDIF_TX_PDN | 11 | Power down S/PDIF transmitter | | 5 | Powe | | Power Down Control 1. 0x1101 | 0xFE | AOD autout and harmonic distance | | | mixe | | ASP_DAO_PDN<br>ASP_DAI_PDN | 1 | ASP output path powered down ASP SDOUT input path is powered down | | | | | MIXĒR PDN | 1 | Mixer is powered down | | | | | EQ_PDN<br>HP_PDN | 1<br>1 | Equalizer powered down<br>HPOUT powered down | | | | | ADC_PDN | 1 | ADC powered down | | | | | Reserved PDN_ALL | 1<br>0 | Codec powered up | | 6 | | er down the ASP and | Power Down Control 2. 0x1102 | 0x8C | · · · · · · · · · · · · · · · · · · · | | | SRC | | Reserved | 100 | | | | | | DISCHARGE_FILT+<br>SRC_PDN_OVERRIDE | 0<br>1 | FILT+ is not clamped to ground.<br>SRC is powered down. | | | | | ASP DAI1 PDN | 1 | ASP is powered down. | | | | | DAC_SRC_PDNB<br>ADC_SRC_PDNB | 0<br>0 | DAC SRC is powered down. ADC SRC is powered down. | | | - | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | 7.50 C. to to powered down. | | TEP | Task | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | |-----|---------------------------------------------------------|-------------------------------------------|----------|-----------------------------------------------------| | 7 | Power down the codec. | Power Down Control 1. 0x1101 | 0xFF | | | | | ASP_DAO_PDN | 1 | ASP output path is powered down. | | | | ASP_DAI_PDN | 1 | ASP input path is powered down. | | | | MIXER_PDN | 1 | Mixer is powered up. | | | | EQ_PDN | 1 | Equalizer powered down | | | | HP_PDN | 1 | HPOUT powered up. | | | | ADC_PDN<br>Reserved | 1 | ADC powered up. | | | | PDN ALL | i | Codec powered up. | | 8 | Read PDN_DONE to confirm | Codec Interrupt Status. 0x1308 | 0x01 | | | | that the codec is completely powered down. Repeat until | Reserved | 0000 00 | | | | value is 0x01 | HSDET_AUTO_DONE | 0 | HS detection is disabled or incomplete. | | _ | | PDN_DONE | 1 | Power-down done. | | 9 | Discharge the capacitor attached to the FILT+ pin. | Power Down Control 2. 0x1102 | 0x9C | | | | attached to the FIET - pin. | Reserved DISCHARGE FILT+ | 100 | — FILT, is slaves ad to succeed | | | | SRC PDN OVERRIDE | 1 | FILT+ is clamped to ground.<br>SRC is powered down. | | | | ASP DAI1 PDN | 1 | ASP is powered down. | | | | DAC SRC PDNB | Ó | DAC SRC is powered down. | | | | ADC_SRC_PDNB | Ŏ | ADC SRC is powered down. | | 0 | | Oscillator Switch Control. 0x1107 | 0x00 | | | | RCO. | Reserved | 0000 000 | | | | | SCLK_PRESENT | 0 | SCLK not present | | 1 | Confirm RCO is powered up. Read the Oscillator Switch | Oscillator Switch Status. 0x1109 | 0x05 | | | | Status and repeat until the | Reserved | 0000 0 | | | | value reaches 0x05. | OSC_PDNB_STAT | 1<br>01 | RCO powered up<br>RCO selected for internal MCLK | | | Down on familial atom was | OSC_SW_SEL_STAT | | RCO selected for internal wich | | 2 | Prepare for clock stop now | SCP System Control (Section 7.1.4) 0x0045 | 0x01 | | | | | Reserved<br>WAKE UP ENABLE | 0000 | Asynchronous wake disabled. | | | | CLOCK STOP MODE | 0 | Slave must not lose context in Clock Stop Mode | | | | Reserved | ŏ | — | | | | CLOCK_STOP_PREPARE | 1 | The CS42L42 is notified to prepare for clock sto | | 3 | Confirm device is ready for | SCP Control (Section 7.1.3) 0x0044 | 0x00 | | | | clock stop. Read SCP Control. | FORCE_RESET | 0 | No action | | | Repeat until CLOCK_STOP_<br>NOT_FINISHED is 0. | | 0 | Current register bank is Bank 0 | | | NOT_I INICITED IS 0. | Reserved | 00 00 | Name of an emotion | | | | CLOCK_STOP_NOW | 0<br>0 | Normal operation | | | Cond algebrates many | CLOCK_STOP_NOT_FINISHED | | Ready for clock stop | | 4 | Send clock stop now | SCP Control (Section 7.1.3) 0x0044 | 0x02 | No action | | | | FORCE RESET<br>CURRENT BANK | 0<br>0 | No action<br>Current register bank is Bank 0 | | | | Reserved | 00 00 | — Current register parity is parity 0 | | | | CLOCK STOP NOW | 1 | Clock stops after one more frame. | | | | CLOCK_STOP_NOT_FINISHED | Ó | Ready for clock stop. | # Page 0x30 Read Sequence The following sequence is required to read from Page 0x30: - 1. Power up Page 0x30 by clearing bit 7 of register 0x1102. - 2. Enable Page 0x30 reads by writing the value 0x01 to register 0x1801. 15 The master sends a stopping frame and stops SWIRE\_CLK at the frame boundary at the end of that frame. 3. Perform the read from Page 0x30. # 5.5 PLL Clocking Data-path logic is in the MCLK domain, where SCLK is expected to be 12 or 24 MHz. For clocking scenarios where ASP SCLK is neither 12 nor 24 MHz, the PLL must be turned on to provide the desired internal MCLK. At startup, the system sets the SCLK bypass as default mode and switches to PLL output after it settles. PLL start-up time is a maximum of 1 ms. # 5.6 Standby Mode and Headset Clamps When the CS42L42 enters Standby Mode, headset clamps must first be disabled—HS\_CLAMP\_DISABLE = 1, see p. 141. ## 5.7 Detection Sequence from Wake Ex. 5-5 is the procedure for implementing automatic headset-type detection from Standby Mode. Following a wake event, the system responds to the WAKE being asserted, the INT pin being asserted, or both (depending on WAKE/INT configuration) by taking the audio device out of Standby Mode, as shown in Steps 1–9. Example 5-5. Headset Type and Load-Detection Sequence | DESCRIPTION | |-------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | | 10 —<br>Internal sample rate is MCLKINT/250.<br>— | | | | Mask mic button detect wake. Mask HP detect wake. WAKE latched low after a trigger event. Reserved Normal operation. | | | | Enable setting of VP sticky status latches. Sticky processed status events are selected. 1 Detect percentage is set to default specified level. | | | | | | See Section 7.6.7 for decode. HP plug event has occurred. No HP unplug event has occurred. | | <ul> <li>Reserved</li> </ul> | | | | See Section 7.6.8 for decodes. | | | | · | | | | Mask mic button detect wake. Mask HP detect wake. Output is latched low. Reserved WAKE output deasserted. | | | | Mask mic button detect wake. Mask HP detect wake. Output is latched low. Reserved | | Normal WAKE output operation. | | | | Transfer VD_FILT fields to VP fields. Unprocessed status events are selected. 1 Detect percentage is set to default specified level. | | | | ASP DAO is powered down. ASP DAI is powered down. Mixer is powered down. EQ is powered down. HP is powered down. ADC is powered down. | | | ## Example 5-5. Headset Type and Load-Detection Sequence (Cont.) | P | TASK | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | |--------|---------------------------------------------|----------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------| | 11.2 | Release FILT+ clamp to ground. | Power Down Control 2. 0x1102 | 0x87 | | | | ground. | Reserved<br>DISCHARGE FILT+ | 100<br>0 | — Ell T+ is not clamped to ground | | | | SRC PDN OVERRIDE | 0 | FILT+ is not clamped to ground. SRC is powered down, per smart logic. | | | | ASP DAI1 PDN | 1 | ASP DAI1 is powered down. | | | | DAC_SRC_PDN | 1 | DAC SRC is powered down. | | | | ADC_SRC_PDN | 1 | ADC SRC is powered down. | | 11.3 | Configure the HP ground | DAC Control 2. 0x1F06 | 0x86 | | | | clamp and pull-down | HPOUT_PULLDOWN | 1000 | Headphone pull-down resistor disabled | | | | HPOUT_LOAD†<br>HPOUT_CLAMP | 0<br>1 | 1-nF Mode. Headphone clamp disabled | | | | DAC_HPF_EN | 1 | DAC HPF is enabled. | | | | Reserved | 0 | | | 11.4 | Configure the | Miscellaneous Detect Control. 0x1B74 | 0x07 | | | | headset-detection block. | _ | 000 | Reserved | | | | DETECT_MODE †† | 0.0 | Detect mode set to inactive. | | | | HSBIAS CTRL †† PDN_MIC_LVL_DETECT | 11<br>1 | HSBIAS set to 2.7-V Mode.<br>Level detect is powered down. | | 11.5 | Wait to the for the | e HSBIAS to ramp up, as specified in Ta | | | | 11.6 | | | | the HobiAo to famp up. | | 11.0 | Configure the HSDET_<br>AUTO DONE interrupt | Codec Interrupt Mask. 0x131B | 0x01 | | | | mask. | Reserved<br>M_HSDET_AUTO_DONE | 0000 00 | Interrupt is unmasked. | | | | M_PDN_DONE | 1 | Interrupt is masked. | | 11.7 | Configure the HSDET | Headset Detect Control 2. 0x1120 | 0x80 | • | | | mode to ensure initial | HSDET CTRL | 10 | HSDET mode set to automatic, disabled. | | | conditions. | HSDET_SET | 00 | HS3 is GND, HS4 is HSBIAS (setting is ignored). | | | | HSBIAS_REF<br>Reserved | 0 | HSx_REF is the ground reference. | | | | HSDET AUTO TIME | 00 | Cycle time set to 10 µs. | | 11.8 | Wait 100 µs. | | | Cycle anne certe to per | | 11.9 | Configure HS DET | Headset Detect Control 1. 0x111F | 0x77 | | | 11.0 | comparator reference | HSDET COMP2 LVL | 0111 | Reference level is set to 2.00 V. | | | levels. | HSDET_COMP1_LVL | 0111 | Reference level is set to 1.00 V. | | 11.10 | Configure the HSDET | Headset Detect Control 2. 0x1120 | 0xC0 | | | | mode. | HSDET CTRL | 11 | HSDET mode set to automatic, active. | | | | HSDET_SET | 00 | HS3 is GND, HS4 is HSBIAS (setting is ignored). | | | | HSBIAS_REF | 0 | HSx_REF is the ground reference. | | | | Reserved<br>HSDET_AUTO_TIME | 0<br>00 | Cycle time set to 10 µs. | | Servic | e the HSDET AUTO DONE | | | Cycle unio cot to 10 pc. | | 12.1 | Read HSDET_AUTO | Codec Interrupt Status. 0x1308 | 0x02 | | | 12.1 | DONE to confirm the | Reserved | 0000 00 | _ | | | detection cycle is complete | HSDET AUTO DONE | 1 | Autotype detect has completed the detection cycle. | | | | PDN_DONE | 0 | Codec is powered up. | | 12.2 | | Headset Detect Status. 0x1124 | _ | | | | confirm the headset type. | HSDET_COMP2_OUT | Х | Refer to Table 4-22 for decode. | | | | HSDET_COMP1_OUT | X | Refer to Table 4-22 for decode. | | | | Reserved<br>HSDET TYPE | 0000<br>xx | Refer to Table 4-22 for decode. | | 12.3 | Configure the HSDET | Headset Detect Control 2. 0x1120 | 0x80 | TOTAL TO TUDIO T-22 IOI UCOUUC. | | 12.3 | mode. | | | LICOUT mode not to outprostic disabled | | | | HSDET_CTRL<br>HSDET_SET | 10<br>00 | HSDET mode set to automatic, disabled.<br>HS3 is GND, HS4 is HSBIAS (setting is ignored). | | | | HSBIAS REF | 0 | HSx_REF is the ground reference. | | | | Reserved | 0 | _ | | | | HSDET_AUTO_TIME | 00 | Cycle time set to 10 µs. | | | | e switches are set to the appropriate sta<br>ected, continue with Step 14. | ites automation | cally. Go to Step 16. | | | | <u> </u> | | | | | ystem manually determines | | 0.40 | | | 14.1 | Set HSDET mode to Manual—Active. | Headset Detect Control 2. 0x1120 | 0x40 | HODET was decasted. | | | manda Adivo. | HSDET_CTRL<br>HSDET_SET | 01<br>00 | HSDET mode set to manual, active.<br>HS3 is GND, HS4 is HSBIAS (setting is ignored). | | | | HSBIAS REF | 00 | HSx_REF is the ground reference. | | | | Reserved | 0 | _ | | | | HSDET_AUTO_TIME | 00 | Cycle time set to 10 µs. | | 14.2 | Open the SW_HSB_HS3 | Headset Switch Control. 0x1121 | 0xA6 | | | | switch and close SW_HSB | | 10 | Ref-to-HSx (HS3 closed; HS4 open) | | | | 0 · · _ · · · _ · · · · · · · | | | | | HS4 for a Type 1 headset. | SWTHSBTFILT HSx †† | 10 | HSBIAS_FILT-to-HSx (HS3 closed; HS4 open) | | | | SW_HSB_FILT_HSx ††<br>SW_HSB_HSx ††<br>SW_GNDHS_HSx †† | | HSBIAS_FILT-to-HSx (HS3 closed; HS4 open)<br>HSBIAS-to-HSx (HS3 open; HS4 closed)<br>GNDHS-to-HSx (HS3 closed; HS4 open) | #### Example 5-5. Headset Type and Load-Detection Sequence (Cont.) | STEP | Task | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | |---------|-------------------------------------------------------|-------------------------------------------|------------------|------------------------------------------------------| | 14.3 | Read the output of the | Headset Detect Status. 0x1124 | _ | | | | HSDET comparator for the | HODET CONFZ OUT | XX | Refer to Table 4-22 for decode. | | | Type 1 headset result. | HSDET_COMP1_OUT | XX | Refer to Table 4-22 for decode. | | | | Reserved | 00 | I have a defended a money de | | | | HSDET_TYPE | XX | Unused in this mode | | 14.4 | Close the SW_HSB_HS3 | Headset Switch Control. 0x1121 | 0x59 | | | | switch for a Type 2 headset | OW INEL TIOK !! | 01 | Ref-to-HSx (HS3 open; HS4 closed) | | | | SW_HSB_FILT_HSx †† | 01 | HSBIAS_FILT-to-HSx (HS3 open; HS4 closed) | | | | SW_HSB_HSx <sup>††</sup> | 10 | HSBIAS-to-HSx (HS3 closed; HS4 open) | | | | SW_GNDHS_HSx †† | 01 | GNDHS-to-HSx (HS3 open; HS4 closed) | | 14.5 | Read the output of the | Headset Detect Status. 0x1124 | _ | | | | HSDET comparator for the | HSDET COMP2 OUT | XX | Refer to Table 4-22 for decode. | | | Type 2 headset result. | HSDET_COMP1_OUT | XX | Refer to Table 4-22 for decode. | | | | Reserved | 00 | _ | | | | HSDET_TYPE | XX | Unused in this mode | | 15 Base | d on the results of the compa | rator reading, set all of the switches to | their appropri | iate states. | | 15.1 | Set switches. | Headset Switch Control. 0x1121 | 0xXX | | | | | SW REF HSx †† | XX | See Section 7.4.13, "Headset Switch Control." | | | | SW_HSB_FILT_HSx †† | XX | | | | | SW_HSB_HSxTt | XX | | | | | SW_GNDHS_HSx †† | XX | | | 15.2 | Set HSDET mode to | Headset Detect Control 2. 0x1120 | 0x00 | | | | Manual—Disabled. | HSDET CTRL | 00 | HSDET mode set to manual, disabled. | | | | HSDET SET | 00 | HS3 is GND, HS4 is HSBIAS (setting is ignored). | | | | HSBIAS_REF | 0 | HSx_REF is the ground reference. | | | | Reserved | 0 | | | | | HSDET_AUTO_TIME | 00 | Cycle time set to 10 µs. | | | ernal switches are used, set the<br>et appropriately. | nem according to Table 4-23, making s | ure to disable ( | GNDHS_HS3 and GNDHS_HS4 after external switch states | | 17 Enab | le the HPOUT ground clamp | DAC Control 2. 0x1F06 | 0x02 | | | and c | onfigure the HP pull-down | HPOUT PULLDOWN | 0000 | 0.9 kΩ | | | | HPOUT_LOAD† | 0 | 1-nF Mode. | | | | HPOUT CLAMP | 0 | Clamp to ground if channels are powered down | | | | DAC HPF EN | 1 | DAC HPF is enabled. | | | | Reserved _ | 0 | _ | | 10 14 | | | | an fan tha haaduhana ananlifian | <sup>18</sup> After type detection completes, load detection is initiated to ensure proper compensation for the headphone amplifier. **Note:** Several bits must be set to ensure proper load detection; some are not explicitly set in the load-detect portion of the sequence (Steps 19–31). This is because these values are either set in the type-detection portion of the sequence or are the default values (assuming that they have not been programmed otherwise). However, ensure the bit values listed below are set when beginning the load-detection portion of the sequence: PDN\_ALL = 0, ADC\_PDN = 1, HP\_PDN = 1, ANA\_MUTE\_A = 1, ANA\_MUTE\_B = 1, LATCH\_TO\_VP = 1, HSBIAS\_CTRL = 00, ADPTPWR = 100, ASR\_RATE = 0111, DSR\_RATE = 0001. After load detection is complete, the fields listed above must be restored to their previous values. | 9 Power down the HP. | Power Down Control 1. 0x1101 | 0xFE | | |----------------------------------------|--------------------------------------|-----------|-------------------------------------------------------| | | ASP DAO PDN | 1 | ASP DAO is powered down. | | | ASP_DAI_PDN | 1 | ASP DAI is powered down. | | | MIXER_PDN | 1 | Mixer is powered down. | | | EQ_PDN | 1 | EQ is powered down. | | | HP_PDN | 1 | HP is powered down. | | | ADC_PDN | 1 | ADC is powered down. | | | Reserved | 1 | | | | PDN_ALL † | 0 | Codec is powered up. | | 0 Set HSBIAS_CTRL to Hi-Z Mode. | Miscellaneous Detect Control. 0x1B74 | 0x01 | | | | Reserved | 000 | _ | | | DETECT_MODE †† | 0 0 | Detect mode set to inactive. | | | HSBIAS_CTRL †† | 00 | HSBIAS set to Hi-Z Mode. | | | PDN_MIC_LVL_DETECT | 1 | Level detect is powered down. | | 1 Set ADPTPWR to Fixed, Mode 3 | Class H Control. 0x1101 | 0x04 | | | (±VCP/3). | Reserved | 00000 | _ | | | ADPTPWR | 100 | Fixed, Mode 3 (±VCP/3) | | 2 Set the analog and digital soft ramp | Soft Ramp Rate. 0x100A | 0x71 | | | rates. | ASR RATE | 0111 | Analog soft ramp is 16 Fs periods between steps. | | | DSR_RATE | 0001 | Digital soft ramp is 2 Fs period between steps. | | 3 Enable HP load detect. | HP Load Detect Enable. 0x1927 | 0x01 | | | | Reserved | 0000 0000 | )— | | | HP_LD_EN | 1 | HP load detect enabled. | | 4 Read HPLOAD_DET_DONE to | HP Load Detect Done. 0x1926 | 0xXX | | | ensure load detection is complete. | Reserved | 0000 0000 | )— | | Repeat until value is 1. | HPLOAD_DET_DONE | Х | 0: Load detect not finished, 1: Load detect finished. | | Example 5-5. | Headset Type and | Load-Detection | Sequence | (Cont.) | |--------------|------------------|----------------|----------|---------| | | | | | | | TEPTASK | REGISTER/BIT FIELDS | VALUE | DESCRIPTION | |---------------------------------------------------------------------|--------------------------------------|--------------|---------------------------------------------------------------------------------------------------| | Read load R/C status. | Load-Detect R/C Status. 0x1925 | 0xXX | | | | Reserved | 000 | _ | | | CLA STAT | X | HPOUT LOAD is programmed according to the values | | | Reserved | 00 | read back. | | | RLA_STAT | XX | | | 6 Set HPOUT_LOAD according to | DAC Control 2. 0x1F06 | 0x0X | | | CLA_STAT and RLA_STAT values. | HPOUT_PULLDOWN | 0000 | 0.9 kΩ | | values. | HPOUT_LOAD† | X | 0: 1-nF Mode, 1: 10-nF Mode. | | | HPOUT_CLAMP | 0 | Clamp to ground if channels are powered down | | | DAC_HPF_EN | 1 | DAC HPF is enabled. | | | Reserved | 0 | _ | | 7 Restore ADPTPWR Adapt-to-Signal Mode. | Class H Control. 0x2101 | 0x07 | | | Adapt-to-olgridi Mode. | Reserved | 00000 | <del>-</del> | | | ADPTPWR | 111 | Adapt to signal. | | | Miscellaneous Detect Control. 0x1B74 | 0x07 | | | Mode. | Reserved | 000 | <del>_</del> | | | DETECT_MODE †† | 0,0 | Detect mode set to inactive. | | | HSBIAS CTRL †† | 11 | HSBIAS set to 2.7-V Mode. | | | PDN_MIC_LVL_DETECT | 1 | Level detect is powered down. | | 9 Power up the HP again. | Power Down Control 1. 0x1101 | 0xF6 | | | | ASP_DAO_PDN | 1 | ASP DAO is powered down. | | | ASP_DAI_PDN | 1 | ASP DAI is powered down. | | | MIXER_PDN | 1 | Mixer is powered down. | | | EQ_PDN | 1 | EQ is powered down. | | | HP_PDN | 0 | HP is powered up. | | | ADC_PDN | 1 | ADC is powered down. | | | Reserved<br>PDN_ALL †† | 0 | Codec is powered up. | | 0.00446 | | | Codec is powered up. | | <ol> <li>Set the analog and digital soft ramp<br/>rates.</li> </ol> | | 0xA4 | Analan auf name is 22 Fa naminda hatusan ataus | | . 4.195. | ASR_RATE<br>DSR_RATE | 1010<br>0100 | Analog soft ramp is 33 Fs periods between steps. Digital soft ramp is 8 Fs periods between steps. | | 1 Disable HP load detection. | HP Load Detect Enable. 0x1927 | 0x00 | Digital soft famp is of a periods between steps. | | Disable HE load detection. | | | | | | Reserved<br>HP_LD_EN | 0000 000 | HP load detect disabled. | | 12 Load detection is complete | TII _LD_LIN | | Til load detect disabled. | | Load detection is complete. Graph To VP to disable | Mis Data at Commel 4, 0x4005 | 0x1F | | | VP domain register configuration. | Mic Detect Control 1. 0x1925 | ***** | | | vi domain register comigaration. | LATCH_TO_VP | 0 | No transfer of VD_FILT fields to VP fields. | | | EVENT_STATUS_SEL | 0 | Unprocessed status events are selected. | | | HS_DETECT_LEVEL | | Detect percentage is set to default specified level. | | 4 If necessary, set ADC1x_INV to | ADC Control. 0x1D01 | 0x0C | | | correct the signal polarity. | Reserved | 00 | <del>_</del> | | | ADC_NOTCH_DIS | 0 | ADC digital notch filter enabled. | | | | Λ. | Normal operation | | | ADC_FORCE_WEAK_VCM | 0 | Normal operation | | | Reserved | 1 | _ ' | | | Reserved<br>ADC_INV | 1<br>1 | ADC signal polarity inverted. | | | Reserved | 1<br>1<br>0 | _ ' | <sup>†</sup> Indicates bit fields for which the provided values are typical, but are not required for configuring the key functionality of the sequence. In the target application, these fields can be set as desired without affecting the configuration goal of this start-up sequence. The description of PDN\_ALL on p. 136 describes the interdependency between LATCH\_TO\_VP and PDN\_ALL. # 5.8 VD\_FILT/VL ESD Diode Note the following: - If VD FILT is supplied externally, VL must be supplied before VD FILT. - If the internal LDO is enabled, it generates VD FILT from VL. - If the LDO is disabled (DIGLDO\_PDN asserted) and VD\_FILT is supplied externally; however, the LDO diode could be forward biased in cases where VD\_FILT is supplied first. - If the LDO is disabled and VD\_FILT and VL are respectively powered via separate 1.2- and 1.8-V supplies, it is recommended to have an ESD diode between VD\_FILT and VL. <sup>††</sup> Indicates bit fields for which changes do not take effect until LATCH\_TO\_VP is set. # 5.9 External Output Switch Considerations The CS42L42 headset interface can be used with two external switches tying HPOUTA/B to HPSENSA/B, thus using a closed-loop method that enables the headphone amplifier to include the switch impedance in its feedback point. This method can improve output performance if the guidelines listed in Section 4.4.2 are followed. However, if these switches are used, HP\_PDN (see p. 135) must be managed properly. HP\_PDN must be set before opening these switches and the switches must be closed before clearing HP\_PDN. If the headphone amplifier is still powered up while the switches are open, improper output occurs even if the headphone output is muted. # 6 Register Quick Reference Table 6-1 lists the register page addresses for each module. Section 4.8.9 describes how the page value maps to the address field (RegAddr[15:0]) for SoundWire read/write commands. Table 6-1. Register Base Addresses | Module Group | Page | Module | Reference | |------------------|-----------|---------------------------------------------------------------------------|------------------------| | SoundWire | 0x00 | Control port 0 | Section 6.2 on p. 109 | | See Section 6.1. | 0x01-0x03 | Data ports 1–3 (See Table 4-10. "Base Addresses for Data Port Registers") | Section 6.3 on p. 110 | | | 0x04-0x0E | Reserved | _ | | | 0x0F | Data port 15 (See Table 4-10. "Base Addresses for Data Port Registers") | Section 6.3 on p. 110 | | Chip-Level | 0x10 | Global | Section 6.4 on p. 111 | | | 0x11 | Power-down and headset detect | Section 6.5 on p. 112 | | | 0x12 | Clocking | Section 6.6 on p. 113 | | | 0x13 | Interrupt | Section 6.7 on p. 113 | | | 0x14 | Reserved | _ | | | 0x15 | Fractional-N PLL | Section 6.8 on p. 114 | | | 0x16-0x18 | Reserved | _ | | | 0x19 | Headphone load detect | Section 6.9 on p. 115 | | | 0x1A | Reserved | _ | | Analog Input | 0x1B | Headset Interface | Section 6.10 on p. 115 | | | 0x1C | Headset bias | Section 6.11 on p. 116 | | | 0x1D | ADC | Section 6.12 on p. 116 | | | 0x1E | Reserved | _ | | Analog Outputs | 0x1F | DAC | Section 6.13 on p. 116 | | | 0x20 | HP control | Section 6.14 on p. 117 | | | 0x21 | Class H | Section 6.15 on p. 117 | | | 0x22 | Reserved | _ | | Internal Modules | 0x23 | Mixer volume | Section 6.16 on p. 117 | | | 0x24 | Equalizer | Section 6.17 on p. 117 | | | 0x25 | AudioPort interface | Section 6.18 on p. 118 | | | 0x26 | SRC | Section 6.19 on p. 118 | | | 0x27 | DMA | Section 6.20 on p. 118 | | Serial Ports | 0x28 | S/PDIF | Section 6.21 on p. 116 | | | 0x29 | ASP transmit | Section 6.22 on p. 119 | | | 0x2A | ASP receive | Section 6.23 on p. 120 | | _ | | Reserved | _ | | ID registers | 0x30 | ID registers | Section 6.24 on p. 121 | | _ | 0x31–0xFF | Reserved | _ | #### Notes: - Default values are shown below the bit field names. - Default bits marked "x" are reserved or undetermined. - Fields shown in red are controls that are also located in the VP power supply domain. - Fields shown in turquoise are status indicators from the VP power supply domain that are selectively raw or sticky. - Fields shown in orange are affected by the FREEZE bit (see p. 133). # 6.1 SoundWire Address Maps Table 6-2 provides the address maps for the SoundWire slave ports. Table 6-2. Slave Control Port Register Address Map | Address | Name | Banked? | Access Restrictions | Notes | |---------------|-------------------------------------|--------------|---------------------|----------------------------------------------------| | 0x0000-0x003F | | _ | None | _ | | 0x0040 | SCP Interrupt Status 1 | No | R/W1C | Interrupt status | | 0x0041 | SCP Interrupt Mask 1 | No | None | Interrupt enable mask | | 0x0042-0x0043 | Reserved | _ | None | _ | | 0x0044 | SCP Control | No | None | Miscellaneous control | | 0x0045 | SCP System Control | No | None | System control | | 0x0046 | SCP Device Number | No | None | Device selection control | | 0x0047-0x004F | Reserved | _ | None | _ | | 0x0050 | SCP Device ID 0 | No | R/O | Device identification | | 0x0051 | SCP Device ID 1 | No | R/O | Device identification | | 0x0052 | SCP Device ID 2 | No | R/O | Device identification | | 0x0053 | SCP Device ID 3 | No | R/O | Device identification | | 0x0054 | SCP Device ID 4 | No | R/O | Device identification | | 0x0055 | SCP Device ID 5 | No | R/O | Device identification | | 0x0056-0x005F | Reserved | _ | None | _ | | 0x0060 | SCP Frame Control | Yes (Bank 0) | W/O | (Bank 0) Controls frame shape (rows and columns) | | 0x0061-0x006F | Reserved | _ | None | _ | | 0x0070-0x007F | (Bank 1) | Yes (Bank 1) | Same as Bank 0 | Bank 1 registers have the same bit definitions as | | | | | | corresponding Bank 0 registers at +0x60-+0x6F | | | Reserved | _ | None | _ | | 0x00C0 | General Interrupt Status 1 Register | No | R/O | CS42L42-defined interrupt status | | 0x00C1 | General Interrupt Mask 1 Register | No | None | CS42L42-defined interrupt enable mask | | 0x00C2 | General Interrupt Status 2 Register | No | R/O | CS42L42-defined interrupt status | | 0x00C3 | General Interrupt Mask 2 Register | No | None | CS42L42-defined interrupt enable mask | | 0x00C4-0x00CF | Reserved | _ | Reserved | Reserved | | 0x00D0 | Memory Access Status | _ | R/O | Memory access status | | 0x00D1 | Memory Access Control | _ | R/W | Memory access control | | 0x00D2 | Memory Access Timeout | | R/W1C | Memory access timeout control | | 0x00D3 | Reserved | _ | R/O | Reserved | | 0x00D4 | Memory Read Last Address 0 | _ | R/O | Status registers reporting address of read through | | 0x00D5 | Memory Read Last Address 1 | _ | R/O | the APB bridge via control-word command. | | 0x00D6-0x00D7 | Reserved | _ | R/O | Reserved | | 0x00D8 | Memory Read Data | No | R/O | Last data value returned on a control-word read | | 0x00D9-0x00FF | Reserved | _ | R/O | Reserved | Table 6-3. Data Port Registers Address Map | Address Offset | Name <sup>1</sup> | Banked? | Access Restrictions | Notes | |----------------|------------------------|---------|---------------------|--------------------------------------------------------------| | +0x00-+0x01 | Reserved | _ | _ | _ | | +0x02 | DPn Port Control | No | None | Miscellaneous port control functions (PortFlowMode optional) | | +0x03 | DPn Block Control 1 | No | None | Word length | | +0x04 | DPn Prepare Status | No | R/O | Channel prepare status | | +0x05 | DPn Prepare Control | No | None | Channel prepare control | | +0x06-+0x1F | Reserved | _ | _ | _ | | +0x20 | DPn Channel Enable | Yes | None | Bank 0 channel enables | | +0x21 | Reserved | _ | _ | _ | | +0x22 | DPn Sample Control 1 | Yes | None | Bank 0 payload control | | +0x23 | DPn Sample Control 2 | Yes | None | Bank 0 payload control | | +0x24 | DPn Offset Control 1 | Yes | None | Bank 0 payload control | | +0x25 | DPn Offset Control 2 | Yes | None | Bank 0 payload control | | +0x26 | DPn Horizontal Control | Yes | None | Bank 0 payload control | | +0x27 | DPn Block Control 3 | Yes | None | Bank 0 payload control | | +0x28-+0x2F | Reserved | _ | _ | _ | | +0x30-+0x37 | (Bank 1) | Yes | Same as Bank 0 | Bank 1 registers have the same bit definitions as | | | | | | corresponding Bank 0 registers at +0x20–+0x2F | | +0x38-+0xFF | Reserved | _ | _ | _ | <sup>1.</sup> For real data ports, n is in the range 1–3. # 6.2 Slave Control Port Registers | | | | | Slave Control P | ort Registers | | | | | |-------------------------|----------------------------------------|------------------------------|-------------------|-------------------|-------------------|--------------------------|------------------------|------------------------------|----------------------------| | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x0000-0x003F | | | | | | _ | | | | | 0x0040 | SCP Interrupt<br>Status | _ | PORT3_<br>CASCADE | PORT2_<br>CASCADE | PORT1_<br>CASCADE | _ | GEN_INT_<br>CASCADE | STAT_BUS_<br>CLASH | STAT_PARITY<br>W1C | | p. 121 | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0041 | SCP Interrupt<br>Mask 1 | 0 | | - | _ | | | MASK_BUS_<br>CLASH | MASK_PARITY | | | | | | | _ | - | | | R/W | | p. 121 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0042-0x0043<br>0x0044 | SCP Control | FORCE_<br>RESET | CURRENT_<br>BANK | | <u> </u> | <del>-</del><br>- | | CLOCK_<br>STOP_NOW | CLOCK_STOP<br>NOT_FINISHED | | | | W/O | R/O | | R | /O | | W/O | R/O | | p. 122 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | 0x0045 | SCP System<br>Control | | - | _ | | WAKE_UP_<br>ENABLE | CLOCK_<br>STOP MODE | _ | CLOCK_STOP_<br>PREPARE | | | Control | | | _ | | R/W | R/W | _ | R/W | | p. 122 | - | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | | 0x0046 | SCP Device | | | - | UP_ID | Ī | - | NUMBER | | | | Number | - | _ | - | | F | 2/W | | | | p. 123 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0047-0x0049 | Reserved | | | 1 | | _ | | | | | 0x0050 | SCP Device ID 0 | SOU | INDWIRE_VERS | ION (DeviceID[4 | | 2/0 | INSTANCE (D | eviceID[43:40]) | | | p. 123 | | 0 | 0 | 0 | 0 | 0 | 0 | See | p. 123 | | 0x0051 | SCP Device ID 1 | | | MIPI_M/ | ANUFACTURER_<br>F | _ID[15:8] (Device<br>2/O | eID[39:32]) | | | | p. 123 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | 0x0052 | SCP Device ID 2 | | | MIPI_M | ANUFACTURER<br>F | k/O | | | | | p. 124 | | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | | 0x0053 | SCP Device ID 3 | | | | | 2/O | | | | | p. 124 | 0000 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | | 0x0054 | SCP Device ID 4 | | | | | (DeviceID[15:8])<br>2/O | | | | | p. 124 | - | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | 0x0055 | SCP Device ID 5 | • | | | | eviceID[7:0]) | | • | • | | 0,,000 | 00. 201.00.20 | | | | | 2/O | | | | | p. 124 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0056-0x005F | | | | | | _ | | | | | 0x0060 | SCP Frame Control | | | ROW_CONTRO | | //O | CC | DLUMN_CONTE | ROL | | p. 125 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0061-0x00BF | | | | | | _ | | | | | 0x00C0 | General Interrupt<br>Status 1 Register | GEN_INT_<br>STAT2<br>CASCADE | | | - | _ | | | SCP_IMP_<br>DEF1 | | | | R/O | | | - | _ | | | R/W1C | | p. 125 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x00C1 | General Interrupt<br>Mask 1 Register | | | | _ | | | | M_SCP_IMP_<br>DEF1 | | | | | | | _ | | | | R/W | | p. 125 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x00C2 | General Interrupt<br>Status 2 Register | | | _ | | | INT_STAT_<br>LATE_RESP | INT_STAT_<br>TIMEOUT_<br>ERR | _ | | | | | | _ | | | R/W1C | R/W1C | _ | | p. 126 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x00C3 | General Interrupt<br>Mask 2 Register | | | _ | | | M_LATE_<br>RESP | M_<br>TIMEOUT_<br>ERR | _ | | | | | | _ | | | R/W | R/W | _ | | p. 126 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x00C4-0x00CF | Reserved | <del>-</del> | <del>-</del> | | | | | | | | | | | | | | | | | | | | | | | Slave Control F | Port Registers | | | | | |---------------|--------------------------|---|---|-----------------|----------------|---------------------|---------------------|--------------|-----------| | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Memory Access<br>Status | | - | _ | - | LAST_LATE | CMD_IN_<br>PROGRESS | CMD_DONE | RDATA_RDY | | | | | - | _ | | | R | /O | | | p. 126 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Memory Access | | | | _ | • | | LATE | RESP | | | Control | | | | _ | | | R/W | R/W | | p. 127 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | 0x00D2 | Memory Access<br>Timeout | | - | _ | | TIMEOUT_<br>DISABLE | | TIMEOUT_CTRI | - | | | | | - | _ | | | R | W | | | p. 127 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x00D3 | Reserved | | | | | | | | | | 0x00D4 | Memory Read Last | | | | MEM_READ_L | AST_ADDR[7:0] | | | | | | Address 0 | | | | F | R/O | | | | | p. 128 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Memory Read Last | | | | MEM_READ_L | AST_ADDR[15:8 | ] | | | | | Address 1 | | | | F | R/O | | | | | p. 128 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x00D6-0x00D7 | Reserved | | | | | _ | | | | | | Memory Read | | | | MEM_REA | D_DATA[7:0] | | | | | | Data 0 | | | | F | R/O | | | | | p. 128 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x00D9-0x00FF | Reserved | - | | | | _ | - | - | - | # 6.3 Slave Data Port 1–3, 15 Registers Port 1 base address = 0x0100; Port 2 base address = 0x0200; Port 3 base address = 0x0300; Port 15 base address = 0x0F00 | | | | SI | ave Data Port | 1-3, 15 Registers | | | | | |-------------|-------------------------------|---|----|---------------|--------------------|--------|----------|-----------------------------|-----------------------------| | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | +0x00 | DPn Interrupt Status | | ' | | | | | STAT_PORT_<br>READY | STAT_TEST_<br>FAIL | | | | | | | _ | | | R/ | W1C | | p. 128 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | +0x01 | DPn Interrupt Mask | | | | _ | | | PORT_<br>READY_M | TEST_FAIL_M | | | | | | | _ | | | F | Z/W | | p. 129 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | +0x02 | DPn Port Control | | _ | | INVERT_BANK | PORT_D | ATA_MODE | | _ | | | | | _ | | ' | | R/W | ' | | | p. 129 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | +0x03 | DPn Block Control 1 | | _ | | - ' | WORE | _LENGTH | <u>'</u> | | | | | | _ | | | | R/W | | | | p. 129 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | +0x03-+0x04 | Reserved | | | 1 | _ | | | | | | +0x04 | DPn Prepare Status | | | | _ | | | NOT<br>FINISHED<br>CHANNEL2 | NOT<br>FINISHED<br>CHANNELT | | | | | | | R/C | ) | | | | | p. 130 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | +0x05 | DPn Prepare<br>Control | | -! | | | | | PREPARE<br>CHANNEL2 | PREPARE_<br>CHANNEL1 | | | | | | | R/W | V | | | | | p. 130 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | +0x06-+0x1F | Reserved | | ! | ' | | | | ! | | | +0x20 | DP <i>n</i> Channel<br>Enable | | | | _ | | | CHANNEL_<br>EN2 | CHANNEL_EN | | | | | | | R/W | V | | • | | | p. 130 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | +0x21 | Reserved | | • | • | | | • | • | • | | +022 | DPn Sample<br>Control 1 | | | | SAMPLE_INTE<br>R/W | | | | | | p. 130 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | +0x23 | DPn Sample<br>Control 2 | | | | SAMPLE_INTE<br>R/W | | | | | | p. 131 | | 0 | 0 | 0 | 0 | v<br>0 | 0 | 0 | 0 | | p. 101 | | U | U | U | U | U | U | U | <u> </u> | | | | | Sla | ve Data Port 1- | 3, 15 Registers | <b>;</b> | | | | | | | |-------------|---------------------|-------------|---------|-----------------|-----------------|----------|---|------|----------------------------|--|--|--| | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | +0x24 | DPn Offset | | • | • | OF | FSET1 | • | • | • | | | | | | Control 1 | | | | | R/W | | | | | | | | p. 131 | | 0 0 0 0 0 0 | | | | | | | | | | | | +0x25 | DPn Offset | | OFFSET2 | | | | | | | | | | | | Control 2 | | RW | | | | | | | | | | | p. 131 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | +0x26 | DPn Horizontal | | HST | ART | | | H | STOP | | | | | | | Control | | | | | R/W | | | | | | | | p. 131 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | +0x27 | DPn Block Control 3 | | | | _ | • | | | BLOCK_<br>PACKING_<br>MODE | | | | | | | | | | _ | | | | R/W | | | | | p. 132 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | +0x28-+0xFF | Reserved | | | | | _ | | | | | | | # 6.4 Global Registers | | I <sup>2</sup> C Addre | ess: 10010(AD1)( | AD0)[R/W] throu | gh 10010(AD1) | (AD0)0 = 0x94(W | /rite); 10010(AD | I)(AD0)1 = 0x95 | (Read) | | |-----------|----------------------------|------------------|-----------------|---------------|--------------------|------------------|-----------------|----------------------|---------------------| | | | | F | Page 0x10—Glo | bal Registers | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | | | | PA | GE | | | | | | | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | 0x01 | Device ID A and B | | DEV | IDA | | | DE\ | /IDB | | | p. 132 | (Read Only) | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | | 0x02 | Device ID C and D | | DEV | IDC | | | DE\ | /IDD | | | p. 132 | (Read Only) | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | | 0x03 | Device ID E and F | | DEV | IDE | | | - | _ | | | p. 132 | (Read Only) | 0 | 0 | 1 | 0 | x | X | x | X | | 0x04 | Reserved | | | | _ | _ | | | | | | | x | x | x | x | X | X | x | X | | 0x05 | Revision ID (Read | | AREVID MTLREVID | | | | | | | | p. 132 | Only) | x | X | x | x | x | x | x | x | | 0x06 | Freeze Control | | | | _ | | | | FREEZE | | p. 133 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x07 | Serial Port SRC<br>Control | | _ | | EQ_BYPASS | I2C_DRIVE | ASP_DRIVE | SRC_<br>BYPASS_DAC | SRC_<br>BYPASS_ADC | | p. 133 | | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | 0x08 | MCLK Status<br>(Read Only) | | | - | | | | INTERNAL_<br>FS_STAT | _ | | p. 133 | | 0 | 0 | 0 | 0 | 0 | 0 | x | 0 | | 0x09 | MCLK Control | | | - | _ | | | INTERNAL_FS | _ | | p. 134 | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | 0x0A | Soft Ramp Rate | | ASR_I | RATE | | | DSR_ | RATE | | | p. 134 | | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | | 0x0B | Slow Start Enable | _ | S | LOW_START_E | N | | - | _ | | | p. 134 | | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | 0x0C-0x0D | Reserved | | | | - | _ | | | | | | | х | X | X | Х | Х | Х | Х | X | | 0x0E | I <sup>2</sup> C Debounce | 120 | C_SDA_DBNC_C | NT | I2C_SDA<br>DBNC_EN | 120 | C_SCL_DBNC_C | CNT | I2C_SCL_<br>DBNC_EN | | p. 135 | | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | | 0x0F | I <sup>2</sup> C Stretch | | | | _ | RETCH | | | | | p. 135 | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | 0x10 | I <sup>2</sup> C Timeout | MAS_I2C_<br>NACK | MAS_TO_DIS | MAS_1 | TO_SEL | ACC_TO_DIS | | ACC_TO_SEL | | | p. 135 | | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | | 0x11-0x7F | Reserved | x | x | х | x | x | x | х | х | | | 1 | 1 | | | | | | | | # 6.5 Power-Down and Headset-Detect Registers | | 12C Addres | SS: 10010(AD1)( | <i>'</i> | • • • | Headset-Detec | Vrite); 10010(AD | 1)(ADU)1 = 0x95 | (Read) | | |---------------------|---------------------------------------------------------|---------------------|---------------------------|---------------------------------------|---------------------|------------------------|-------------------|---------------------------------------|------------------| | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | ' | | J | _ | GE | | | • | | OXOO | Control of the ago | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | | 0x01 | Power Down Control 1 | ASP_DAO_<br>PDN | ASP_DAI_<br>PDN | MIXER_PDN | EQ_PDN | HP_PDN | ADC_PDN | _ | PDN_ALL | | p. 135 | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 0x02 | Power Down Control 2 | | _ | | DISCHARGE_<br>FILT+ | SRC_PDN_<br>OVERRIDE | ASP_DAI1_<br>PDN | DAC_SRC_<br>PDNB | ADC_SRC_<br>PDNB | | p. 136 | | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | 0x03 | Power Down Control 3 | _ | SW_CLK_ST | P_STAT_SEL | - | _ | VPMON_<br>PDNB | RING_<br>SENSE_PDNB | | | p. 137 | | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | 0x04 | Ring Sense Control 1 | _ | RING_<br>SENSE_PU_<br>HIZ | _ | _ | HSBIAS_FILT_<br>REF_RS | HP_REF_RS | RS_TRIM_T | RS_TRIM_R | | p. 137 | | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x05 | Ring Sense Control 2 | TS_RS_GATE | | | | _ | | • | | | p. 138 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x06 | Reserved | <u> </u> | ~ | | - | | | | 7. | | 0x07 | Oscillator Switch | X | Х | Х | X | Х | Х | Х | X<br>SCLK | | | Control | | • | | _ | • | | • | PRESEÑT | | p. 138 | December | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 80x0 | Reserved | x | х | х | x | _<br>x | х | х | х | | 0x09 | Oscillator Switch<br>Status (Read Only) | | | | | ^ | OSC_PDNB_<br>STAT | OSC_SW_ | | | p. 138 | ,, | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | | 0x0A-0x11 | Reserved | x | х | x | -<br>X | x | X | × | х | | 0x12 | Ring Sense Control 3 | RS_INV | RS_PU_EN | | FALL DBNCE | | | RISE_DBNCE_T | | | p. 138 | | 0 | 0 | 0 - | 1 | 1 | 0 - | 1 | 1 | | 0x13 | Tip Sense Control 1 | TS_INV | _ | TS_ | FALL_DBNCE_1 | ГІМЕ | TS_ | RISE_DBNCE_T | IME | | p. 139 | | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | | 0x 14 | Reserved | | | | _ | _ | | | | | 0.45 | T: 0 (D) | Х | Х | Х | X | X | X | X | X | | 0x15 | Tip Sense/Ring Sense<br>Indicator Status (Read<br>Only) | | _ | _ | | TS_UNPLUG_<br>DBNC | TS_PLUG_<br>DBNC | RS_UNPLUG_<br>DBNC | RS_PLUG_<br>DBNC | | p. 139 | ** | 0 | 0 | 0 | 0 | X | х | X | х | | 0x16–0x1E | Reserved | x | х | х | x | x | х | х | х | | 0x1F | Headset Detect | | HSDET_C | | | | | OMP1_LVL | | | p. 139 | Control 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | | 0x20 | Headset Detect | HSDET | _CTRL | HSDE | T_SET | HSBIAS_REF | _ | HSDET_A | JTO_TIME | | p. 140 | Control 2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 0x21 | Headset Switch<br>Control | SW_REF_HS3 | | SW_HSB_<br>FILT_HS3 | SW_HSB_<br>FILT_HS4 | | SW_HSB_HS4 | HS3 | SW_GNDHS_<br>HS4 | | p. 140 | | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | | 0x 22–0x23 | Reserved | x | x | x | x | x | x | x | x | | 0x24 | Headset Detect Status<br>(Read Only) | HSDET_<br>COMP2_OUT | HSDET_<br>COMP1_OUT | | - | _ | | HSDET | _TYPE | | p. 141 | , , , , | x | x | 0 | 0 | 0 | x | × | x | | 0x 25–0x28 | Reserved | | ~ | · · · · · · · · · · · · · · · · · · · | - | | · | · · · · · · · · · · · · · · · · · · · | · | | 0x29 | HS Clamp Disable | Х | Х | Х | x | Х | Х | Х | X<br>HS_CLAMP_ | | | , | | 0 | 6 | ^ | ^ | 6 | | DISABLE | | p. 141<br>0x2A-0x7F | Reserved | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | x | X | х | х | х | х | х | х | # 6.6 Clocking Registers | | I-O Address | 3. 10010(AD1)( | ADO)[IVVI] till | Page 0x12—Cloc | AD0)0 = 0x94 (V<br>king Registers | VIII.E), 10010(AD | 1)(AD0)1 - 0x33 | (Iteau) | | |-----------|-------------------------------|----------------|-----------------|-----------------|-----------------------------------|----------------------|------------------------|---------------------|------------------| | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | | | | PA | .GE | | | | | | | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | | 0x01 | MCLK Source Select | | | - | _ | | | MCLKDIV | MCLK_SRC_<br>SEL | | p. 141 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x02 | S/PDIF Clock<br>Configuration | - | _ | | SPDIF_CLK_DI\ | / | SPDIF_LRCK_<br>SRC_SEL | SPDIF_LRCK_<br>CPOL | _ | | p. 141 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x03 | FSYNC Pulse Width | | | | FSYNC_PULS | SE_WIDTH_LB | • | • | | | p. 142 | Lower Byte | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x04 | FSYNC Pulse Width | | | _ | | | FSYN | C_PULSE_WIDT | H_UB | | p. 142 | Upper Byte | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x05 | FSYNC Period Lower | | | | FSYNC_P | ERIOD_LB | • | | | | p. 142 | Byte | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | | 0x06 | FSYNC Period Upper | r — FSYNC_P | | | | | ERIOD_UB | | | | p. 142 | Byte | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x07 | ASP Clock<br>Configuration 1 | - | _ | ASP_SCLK_<br>EN | ASP_<br>HYBRID_<br>MODE | ASP_SCPOL_<br>IN_ADC | ASP_SCPOL_<br>IN_DAC | ASP_LCPOL_<br>OUT | ASP_LCPOL_<br>IN | | p. 143 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x08 | ASP Frame | | _ | 1 | ASP_STP | ASP_5050 | | ASP_FSD | | | p. 143 | Configuration | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | 0x09 | Fs Rate Enable | | | _ | 1 | | FS_ | _EN | | | p. 143 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x09 | Fs Rate Enable | | | _ | _ | 1 | | FS | _EN | | p. 143 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0A | Input ASRC Clock | | | - | _ | | | CLK_IAS | RC_SEL | | p. 144 | Select | 0 | 0 | 0 | 0 | 0 | 0 | 0 | _ 0 | | 0x0B | Output ASRC Clock | | | _ | _ | | | CLK_OA | SRC_SEL | | p. 144 | Select | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0C | PLL Divide | | | - | _ | | | SCLK_I | PREDIV | | p. 144 | Configuration 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0D-0x7F | Reserved | | | | _ | _ | | 1 | | | | | x | х | x | x | x | x | x | x | # 6.7 Interrupt Registers | | I <sup>2</sup> C Addres | ss: 10010(AD1)( | AD0)[R/W] throu | igh 10010(AD1) | (AD0)0 = 0x94 (V | Vrite); 10010(AD | 1)(AD0)1 = 0x95 | (Read) | | |-----------|----------------------------------------|-----------------------|-----------------------|----------------------|------------------|--------------------|-----------------|---------------------|--------------------| | | | | Р | age 0x13—Inter | rrupt Registers | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | | | | PA | GE | | | | | | | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | | 0x01 | ADC Overflow | | | | _ | | | | ADC_OVFL | | p. 144 | Interrupt Status (Read Only) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | x | | 0x02 | Mixer Interrupt Status (Read Only) | | = | - | | EQ_BIQUAD_<br>OVFL | EQ_OVFL | MIX_CHA_<br>OVFL | MIX_CHB_<br>OVFL | | p. 144 | | 0 | 0 | 0 | 0 | x | x | x | x | | 0x03 | SRC Interrupt Status | | _ | _ | | SRC_OUNLK | SRC_IUNLK | SRC_OLK | SRC_ILK | | p. 145 | (Read Only) | 0 | 0 | 0 | 0 | x | x | x | x | | 0x04 | ASP RX Interrupt<br>Status (Read Only) | | _ | | ASPRX_OVLD | ASPRX_<br>ERROR | ASPRX_LATE | ASPRX_<br>EARLY | ASPRX_<br>NOLRCK | | p. 145 | | 0 | 0 | 0 | х | x | x | x | х | | 0x05 | ASP TX Interrupt<br>Status (Read Only) | | _ | _ | | ASPTX_<br>SMERRŌR | ASPTX_LATE | ASPTX_<br>EARLY | ASPTX_<br>NOLRCK | | p. 146 | | 0 | 0 | 0 | 0 | x | x | x | x | | 0x06-0x07 | Reserved | | | | _ | _ | | | | | | | x | X | x | x | X | X | X | x | | 0x08 | Codec Interrupt<br>Status (Read Only) | | | - | _ | | | HSDET_<br>AUTO_DONE | PDN_DONE | | p. 146 | | 0 | 0 | 0 | 0 | 0 | 0 | x | x | | 0x09 | Detect Status 1 (Read Only) | HSBIAS_<br>SENSE | TIP_SENSE_<br>PLUG | TIP_SENSE_<br>UNPLUG | | | _ | • | | | p. 146 | | x | x | x | x | x | x | x | x | | 0x0A | Detect Status 2 (Read Only) | DETECT_<br>TRUE_FALSE | DETECT_<br>FALSE_TRUE | | _ | | HSBIAS_HIZ | SHORT_<br>RELEASE | SHORT_<br>DETECTED | | p. 147 | | x | х | x | х | X | x | x | х | | I <sup>2</sup> C Address: 10010(AD1)(AD0)[R/W] through 10010(AD1)(AD0)0 = 0x94 (Write); 10010(AD1)(AD0)1 = 0x95 (Read) Page 0x13—Interrupt Registers | | | | | | | | | | | | | |-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|---|----------|------------|------------------|-------------------------|------------------|-----------------------|--------------------|--|--|--| | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 0x0B | SRC Partial Lock | _ | DAC_UNLK | ADC_UNLK | - | | DAC_LK | _ | ADC_LK | | | | | p. 147 | Interrupt Status (Read Only) | х | x | Х | Х | х | х | х | х | | | | | 0x0C | Reserved | x | X | X | x | _ x | X | X | x | | | | | 0x0D | VPMON Interrupt | | | | | | | | VPMON_TRIP | | | | | p. 148 | (Read Only) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | x | | | | | 0x0E | PLL Lock (Read Only) | | | | _ | | | | PLL_LOCK | | | | | p. 148 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | х | | | | | 0x0F<br>p. 148 | Tip/Ring Sense Plug/<br>Unplug Interrupt Status<br>(Read Only) | x | x | x | x | TS_UNPLUG<br>x | TS_PLUG<br>x | RS_UNPLUG<br>x | RS_PLUG<br>x | | | | | 0x10-0x15 | Reserved | | | | | | | | | | | | | | | Х | x | x | x | x | x | x | x | | | | | 0x16 | ADC Overflow | | | | _ | | | | M_ADC_OVFL | | | | | p. 148 | Interrupt Mask | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | | | 0x17 | Mixer Interrupt Mask | | - | _ | | M_EQ<br>BIQUAD_<br>OVFL | M_EQ_OVFL | M_MIX_CHA_<br>OVFL | M_MIX_CHB_<br>OVFL | | | | | p. 149 | | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | | | | 0x18 | SRC Interrupt Mask | | _ | _ | | M_SRC_<br>OUNLK | M_SRC_<br>IUNLK | M_SRC_OLK | M_SRC_ILK | | | | | p. 149 | | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | | | | 0x19 | ASP RX Interrupt Mask | | _ | | M_ASPRX_<br>OVLD | M_ASPRX_<br>ERROR | M_ASPRX_<br>LATE | M_ASPRX_<br>EARLY | M_ASPRX_<br>NOLRCK | | | | | p. 149 | | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | | | | | 0x1A | ASP TX Interrupt Mask | | - | _ | | M ASPTX<br>SMERROR | M_ASPTX_<br>LATE | M_ASPTX_<br>EARLY | M_ASPTX_<br>NOLRCK | | | | | p. 150 | | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | | | | 0x1B | Codec Interrupt Mask | | | - | _ | | | M_HSDET_<br>AUTO_DONE | M_PDN_<br>DONE | | | | | p. 150 | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | | | | | SRC Partial Lock<br>Interrupt Mask | • | | M_ADC_UNLK | - | _ | M_DAC_LK | _ | M_ADC_LK | | | | | p. 150 | · | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | 0x1D | Reserved | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 0x1E | VPMON Interrupt<br>Mask | | | | _ | | | | M_VPMON_<br>TRIP | | | | | p. 151 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | | | 0x1F | PLL Lock Mask | | | | | | | | M_PLL_LOCK | | | | | p. 151 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | | | 0x20 | Tip/Ring Sense Plug/<br>Unplug Interrupt Mask | _ | - | _ | _ | M_TS_<br>UNPLUG | M_TS_PLUG | M_RS_<br>UNPLUG | M_RS_PLUG | | | | | p. 151 | | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | | | | 0x21–0x7F | Reserved | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | # 6.8 Fractional-N PLL Registers | | I <sup>2</sup> C Addres | s: 10010(AD1) | (AD0)[R/W] throu | gh 10010(AD1)( | AD0)0 = 0x94 (V | Write); 10010(AD1 | )(AD0)1 = 0x95 | (Read) | | | | | | |-----------|-------------------------|---------------|-------------------|----------------|-----------------|-------------------|----------------|--------|---|--|--|--|--| | | | | Page | 0x15—Fractiona | II-N PLL Regist | ers | | | | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | 0x00 | Control Port Page | | | | PA | \GE | | • | • | | | | | | | | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | | | | | | 0x01 | PLL Control 1 | | — PLL_START | | | | | | | | | | | | p. 151 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 0x02 | PLL Division Fractional | | PLL_DIV_FRAC[7:0] | | | | | | | | | | | | p. 152 | Byte 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 0x03 | PLL Division Fractional | | | | PLL_DIV_ | FRAC[15:8] | | | | | | | | | p. 152 | Byte 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 0x04 | PLL Division Fractional | | | | PLL_DIV_F | FRAC[23:16] | | | | | | | | | p. 152 | Byte 2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 0x05 | Division Integer | | | | PLL_DIV | /_INT[7:0] | | | | | | | | | p. 152 | | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 0x06-0x07 | Reserved | | - | | | | | | | | | | | | | | x | x | x | x | x | x | x | X | | | | | | 0x08 | PLL Control 3 | | PLL_DIVOUT | | | | | | | | | | | | p. 152 | | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | | | | | | I <sup>2</sup> C Addres | s: 10010(AD1) | (AD0)[R/W] throu | gh 10010(AD1)( | AD0)0 = 0x94 (V | Vrite); 10010(AD | 1)(AD0)1 = 0x95 | (Read) | | | | | | |-----------|----------------------------------------|---------------|------------------|----------------|-----------------|------------------|-----------------|--------|------|--|--|--|--| | | Page 0x15—Fractional-N PLL Registers | | | | | | | | | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | 0x09 | Reserved | | • | | - | | • | • | | | | | | | | | x | X | X | x | X | x | x | x | | | | | | 0x0A | 0A PLL Calibration Ratio PLL_CAL_RATIO | | | | | | | | | | | | | | p. 152 | | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 0x0B-0x1A | Reserved | | | | - | _ | | | | | | | | | | | X | X | X | x | x | X | X | x | | | | | | 0x1B | PLL Control 4 | | | _ | _ | | | PLL_I | MODE | | | | | | p. 152 | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | | | | | 0x1C-0x7F | 0x1C-0x7F Reserved — | | | | | | | | | | | | | | | | X | X | X | x | x | X | X | x | | | | | # 6.9 HP Load Detect Registers | | I <sup>2</sup> C Address: 10010(AD1)(AD0)[R/W] through 10010(AD1)(AD0)0 = 0x94 (Write); 10010(AD1)(AD0)1 = 0x95 (Read) | | | | | | | | | | | | | |-----------|------------------------------------------------------------------------------------------------------------------------|---|-----------------|---|----------|----|---|-----|---------------------|--|--|--|--| | | Page 0x19—HP Load Detect Registers | | | | | | | | | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | 0x00 | Control Port Page | | | | PA | GE | • | • | • | | | | | | | | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | | | | | | 0x01-0x24 | Reserved | | | | _ | _ | | | | | | | | | | | x | X | x | X | x | X | X | x | | | | | | 0x25 | Load Detect R/C | | _ | | CLA_STAT | - | _ | RLA | _STAT | | | | | | p. 153 | Status (Read Only) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 0x26 | HP Load Detect Done (Read Only) | | | | _ | | | | HPLOAD_<br>DET_DONE | | | | | | p. 153 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 0x27 | HP Load Detect | | | | _ | | | | HP_LD_EN | | | | | | p. 153 | Enable | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 0x28-0x7F | Reserved | | | | _ | _ | | | • | | | | | | | | x | x x x x x x x x | | | | | | | | | | | # 6.10 Headset Interface Registers | | I <sup>2</sup> C Addre | ss: 10010(AD1)( | | | | | 1)(AD0)1 = 0x95 | (Read) | | |-----------|------------------------------------|-----------------------------|----------------------|-------------------|------------------|---------|-----------------|--------------|------------------------| | | | | Page ( | 0x1B—Headset | Interface Regist | ters | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | | | | PA | ,GE | | • | | | | | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | | 0x01-0x6F | Reserved | | | | - | _ | | | | | | | x | x | X | x | x | X | x | x | | 0x70 | HSBIAS Sense and Clamp Autocontrol | HSBIAS_<br>SENSE_EN | AUTO_<br>HSBIAS_HIZ | TIP_SENSE_<br>EN | - | _ | HS | BIAS_SENSE_T | RIP | | p. 153 | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | 0x71 | Wake Control | M_MIC_WAKE | M_HP_W<br>AKE | WAKEB_<br>MODE | | - | _ | | WAKEB_<br>CLEAR | | p. 154 | | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x72 | ADC Disable Mute | ADC_<br>DISABLE_S0_<br>MUTE | | | | _ | | | | | p. 154 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x73 | Tip Sense Control | TIP_SEN | SE_CTRL | TIP_SENSE_<br>INV | | _ | | TIP_SENSE | DEBOUNCE | | p. 154 | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | 0x74 | Miscellaneous Detect<br>Control | | _ | | DETEC | T_MODE | HSBIAS | S_CTRL | PDN_MIC_<br>LVL_DETECT | | p. 155 | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | 0x75 | Mic Detect Control 1 | LATCH_TO_<br>VP | EVENT_<br>STATUS_SEL | | | HS_DETE | CT_LEVEL | | | | p. 155 | | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | | 0x76 | Mic Detect Control 2 | D | EBOUNCE_TIM | E | | | _ | | | | p. 156 | | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | 0x77 | Detect Status 1 (Read Only) | TIP_SENSE | HSBIAS_<br>CLAMPHĪZ | | | - | _ | | | | p. 156 | | x | x | 0 | х | x | X | x | X | | 0x78 | Detect Status 2 (Read | | | _ | _ | | | HS_TRUE | SHORT_TRUE | | p. 156 | Only) | x | x | X | x | 0 | X | x | x | | | I <sup>2</sup> C Addr | ess: 10010(AD1)( | AD0)[R/W] throu | gh 10010(AD1) | (AD0)0 = 0x94 (V) | Vrite); 10010(AD | 1)(AD0)1 = 0x95 | (Read) | | |-----------|----------------------------|-------------------------|-------------------------|----------------------------|-------------------|------------------|------------------|---------------------|---------------------| | | | | Page 0 | x1B—Headset | Interface Regist | ers | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x79 | Detect Interrupt<br>Mask 1 | M_HSBIAS_<br>SENSE | M_TIP_<br>SENSE_PLUG | M_TIP_<br>SENSE_<br>UNPLUG | | | _ | | | | p. 157 | | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | 0x7A | Detect Interrupt<br>Mask 2 | M_DETECT_<br>TRUE_FALSE | M_DETECT_<br>FALSE_TRUE | | _ | | M_HSBIAS_<br>HIZ | M_SHORT_<br>RELEASE | M_SHORT<br>DETECTED | | p. 157 | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 0x7B-0x7F | Reserved | | | | _ | _ | • | | | | | | x | x | x | X | x | X | X | x | # **6.11 Headset Bias Registers** | | I <sup>2</sup> C Addres | ss: 10010(AD1)(A | AD0)[R/W] throu | igh 10010(AD1 | (AD0)0 = 0x94 (W | /rite); 10010(AD | 1)(AD0)1 = 0x95 | (Read) | | |-----------|-------------------------|-----------------------|-----------------|---------------|--------------------|------------------|-----------------|--------|--------| | | | | Pag | e 0x1C—Heads | set Bias Registers | 3 | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | | | | PA | GE | • | • | • | | | | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | | 0x01-0x02 | Reserved | | | | _ | _ | | | | | | | x | х | x | х | x | х | х | x | | 0x03 | Headset Bias Control | HSBIAS_<br>CAPLESS_EN | - | _ | HSBIAS_PD | - | _ | HSBIAS | S_RAMP | | p. 157 | | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | | 0x04-0x7F | Reserved | | | | | _ | | • | | | | | x | x | X | x | X | x | x | X | # 6.12 ADC Registers | | I <sup>2</sup> C Addres | ss: 10010(AD1)( | AD0)[R/W] thr | ough 10010(AD1) | (AD0)0 = 0x94 (V) | Vrite); 10010(AD | 1)(AD0)1 = 0x95 | (Read) | | |-----------|---------------------------------------|-----------------|---------------|-------------------|------------------------|------------------|-------------------------|--------|-------------------| | | | | | Page 0x1D—A | OC Registers | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | | • | • | PA | GE | • | • | • | | | | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | | 0x01 | ADC Control 1 | - | _ | ADC_NOTCH_<br>DIS | ADC_FORCE_<br>WEAK_VCM | _ | ADC_INV | _ | ADC_DIG_<br>BOOST | | p. 158 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x02 | ADC Soft-Ramp<br>Enable | | | _ | | | ADC_<br>SOFTRAMP_<br>EN | - | <u>-</u> | | p. 158 | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | 0x03 | ADC Volume | | | | ADC | _VOL | • | • | | | p. 158 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x04 | ADC Wind-Noise Filter and HPF Control | _ | | ADC_WNF_CF | | ADC_WNF_<br>EN | ADC_F | IPF_CF | ADC_HPF_EN | | p. 159 | | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | | 0x05-0x7F | Reserved | | - | | _ | _ | | | | | | | x | x | X | X | x | x | x | X | # **6.13 DAC Registers** | | I <sup>2</sup> C Addre | ss: 10010(AD1) | (AD0)[R/W] thro | ugh 10010(AD1)( | AD0)0 = 0x94 | (Write); 10010(AD1 | )(AD0)1 = 0x9 | (Read) | | |-----------|------------------------|----------------|-----------------|-----------------|--------------|--------------------|-----------------|------------|----------| | | | | | Page 0x1F—DA | C Registers | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | | • | • | ı | PAGE | | | | | | | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | | 0x01 | DAC Control 1 | | | _ | _ | | | DACB_INV | DACA_INV | | p. 159 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x02-0x05 | Reserved | | | | | _ | | | | | | | x | x | X | x | x | x | X | x | | 0x06 | DAC Control 2 | | HPOUT_P | PULLDOWN | | HPOUT_LOAD | HPOUT_<br>CLAMP | DAC_HPF_EN | _ | | p. 159 | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | 0x07-0x7F | Reserved | | | | | | | | | | | | x | x | X | x | X | x | х | X | ## **6.14 HP Control Registers** | | I <sup>2</sup> C Addre | ess: 10010(AD1) | AD0)[R/W] throu | igh 10010(AD1)( | AD0)0 = 0x94 (V | Vrite); 10010(AD | 1)(AD0)1 = 0x95 | (Read) | | |-----------|------------------------|-----------------|-----------------|-----------------|-----------------|------------------|-----------------|--------------------|---| | | | | Pa | ge 0x20—HP Co | ntrol Registers | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | | • | | PA | GE | | ' | | | | | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | 0x01 | HP Control | | = | _ | | ANA_MUTE_B | ANA_MUTE_A | FULL_SCALE_<br>VOL | _ | | p. 160 | | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | | 0x02-0x7F | Reserved | | | | - | _ | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## 6.15 Class H Registers | | I <sup>2</sup> C Addre | ess: 10010(AD1)( | AD0)[R/W] throu | igh 10010(AD1)( | AD0)0 = 0x94 (V | Vrite); 10010(AD1 | I)(AD0)1 = 0x9 | 5 (Read) | | |-----------|------------------------|------------------|-----------------|-----------------|-----------------|-------------------|----------------|----------|---| | | | | F | age 0x21—Clas | s H Registers | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | | • | • | PA | GE | | | | | | | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | | 0x01 | Class H Control | | | _ | | | | ADPTPWR | | | p. 160 | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | 0x02-0x7F | Reserved | | | | - | | | | | | | | x | x | x | x | X | x | X | X | # **6.16 Mixer Volume Registers** | | | | Pag | e 0x23—Mixer \ | /olume Register | s | | | | |----------|-----------------------|---|-----|----------------|-----------------|---------|---------|---|---| | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | | • | | PA | GE | | | | | | | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | | 0x01 | Mixer Channel A Input | - | _ | | | MIXER_0 | CHA_VOL | | | | p. 160 | Volume | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | 0x02 | Mixer ADC Input | - | _ | MIXER_ADC_VOL | | | | | | | p. 161 | Volume | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | 0x03 | Mixer Channel B Input | - | _ | | | MIXER_0 | CHB_VOL | | | | p. 161 | Volume | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | k04–0x7F | Reserved | | | | - | _ | | | | | | | x | x | х | x | х | X | x | х | # **6.17 Equalizer Registers** | | I <sup>2</sup> C Addres | s: 10010(AD1) | (AD0)[R/W] throu | igh 10010(AD1 | (AD0)0 = 0x94 (V) | Write); 10010(AD1 | )(AD0)1 = 0x | 95 (Read) | | | |---------|-------------------------------------|---------------|--------------------|---------------|-------------------|-------------------|--------------|-----------|---------|--| | | | | Pa | age 0x24—Equ | alizer Registers | | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 0x00 | Control Port Page | | • | | P/ | ÄGE | | • | | | | | | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | | | 0x01 | Equalizer Filter | | | | EQ_CO | EF_IN[7:0] | | | | | | p. 161 | Coefficient Input 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 0x02 | Equalizer Filter | | | | EQ_COE | F_IN[15:8] | | | | | | p. 161 | Coefficient Input 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 0x03 | Equalizer Filter | | | | EQ_COE | F_IN[23:16] | | | | | | p. 161 | Coefficient Input 2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 0x04 | Equalizer Filter | | EQ_COEF_IN[31:24] | | | | | | | | | p. 161 | Coefficient Input 3 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 0x05 | Reserved | | | | | _ | | | | | | | | х | x | x | х | x | x | х | x | | | 0x06 | Equalizer Filter | | | | _ | | | EQ_WRITE | EQ_READ | | | p. 161 | Coefficient Read/Write | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 0x07 | Equalizer Filter | | | | EQ_COE | F_OUT[7:0] | | • | | | | p. 161 | Coefficient Output 0(Read Only) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 0x08 | Equalizer Filter | | | | EQ_COEF | _OUT[15:8] | | | | | | p. 162 | Coefficient Output 1<br>(Read Only) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 0x09 | Equalizer Filter | | EQ_COEF_OUT[23:16] | | | | | | | | | p. 162 | Coefficient Output 2<br>(Read Only) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | I <sup>2</sup> C Addres | ss: 10010(AD1) | (AD0)[R/W] throu | igh 10010(AD1) | (AD0)0 = 0x94 (W | Vrite); 10010(AD1 | )(AD0)1 = 0x9 | 5 (Read) | | |-----------|---------------------------------------------|----------------|------------------|----------------|------------------|-------------------|---------------|----------|---------------------| | | | | P | age 0x24—Equa | alizer Registers | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x0A | Equalizer Filter | | • | • | EQ_COEF_ | OUT[31:24] | | • | • | | p. 162 | Coefficient Output 3 (Read Only) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0B | Equalizer Initialization Status (Read Only) | | | | _ | | | | EQ_INIT_<br>DONE | | p. 162 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0C | Equalizer Start Filter<br>Control | | | | _ | | | | EQ_START_<br>FILTER | | p. 162 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0D | Reserved | | | | _ | _ | | | • | | | | x | x | x | X | x | x | x | х | | 0x0E | Equalizer Input Mute | | | | _ | | | | EQ_MUTE | | p. 162 | Control | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0F-0x7F | Reserved | | | | _ | _ | | | • | | | | х | X | х | 0 | X | x | X | х | # **6.18 AudioPort Interface Registers** | | | | Page 0x | 25—AudioPo | rt Interface Registe | ers | | | | |----------|---------------------------------------------|---|-----------------|------------|----------------------|-------|--------------------|----------|----------| | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | | ' | | PAG | SE . | ' | | ' | | | | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | | 0x01 | Serial Port Receive | | _ | | | SP_RX | CHB_SEL | SP_RX_ | CHA_SEL | | p. 163 | Channel Select | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | 0x02 | Serial Port Receive<br>Isochronous Control | _ | SP_RX_<br>RSYNC | | SP_RX_NSB_POS | 1 | SP_RX_NFS_<br>NSBB | SP_RX_IS | SOC_MODE | | p. 163 | | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | 0x03 | Serial Port Receive | | | | | | SP_RX_FS | | | | p. 163 | Sample Rate | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | 0x04 | S/PDIF Channel Select | | | | | SPDIF | _CHB_SEL | SPDIF_ | CHA_SEL | | p. 164 | | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | | 0x05 | Serial Port Transmit<br>Isochronous Control | | SP_TX_<br>RSYNC | | SP_TX_NSB_POS | | SP_TX_NFS_<br>NSBB | SP_TX_IS | SOC_MODE | | p. 164 | | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | 0x06 | Serial Port Transmit | | | | | | SP_TX_FS | | ' | | p. 164 | Sample Rate | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | | 0x07 | S/PDIF/SoundWire | | _ | SPD | IF_RES | SW_R | ES_INPUT | SW_RES | _OUTPUT | | p. 165 | Control 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | x08–0x7F | Reserved | | | | <u>-</u> | | ' | | | | | | x | X | x | х | x | X | x | х | # **6.19 SRC Registers** | | 2C Address: 10010(AD1)(AD0)[R/W] through 10010(AD1)(AD0)0 = 0x94 (Write); 10010(AD1)(AD0)1 = 0x95 (Read) Page 0x26—SRC Registers Address Function 7 6 5 4 3 2 1 0 | | | | | | | | | | | | | |-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|-------------|----|--------------|---|---|--|--|--|--| | Address | | | | | | | | | | | | | | | 0x00 | Control Port Page | | 1 | | PA | GE | 1 | | | | | | | | | _ | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | | | | | | 0x01 | SRC Input Sample | | _ | | SRC_SDIN_FS | | | | | | | | | | p. 165 | Rate | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | 0x02-0x08 | Reserved | | | | - | _ | | | | | | | | | | | x | х | x | X | x | X | X | х | | | | | | 0x09 | SRC Output Sample | | _ | | | | SRC_SDOUT_FS | 3 | | | | | | | p. 165 | Rate | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | x0A-0x7F | Reserved | | | | - | _ | | | | | | | | | | | X | Х | X | X | X | Х | X | х | | | | | # 6.20 DMA Registers | | I <sup>2</sup> C Address: 10010(AD1)(AD0)[R/W] through 10010(AD1)(AD0)0 = 0x94 (Write); 10010(AD1)(AD0)1 = 0x95 (Read) | | | | | | | | | | |---------|------------------------------------------------------------------------------------------------------------------------|------------------------|------|---|---|---|---|---|---|--| | | Page 0x27—DMA Registers | | | | | | | | | | | Address | Function | nction 7 6 5 4 3 2 1 0 | | | | | | | | | | 0x00 | Control Port Page | | PAGE | | | | | | | | | | | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | | | | I <sup>2</sup> C Address: 10010(AD1)(AD0)[R/W] through 10010(AD1)(AD0)0 = 0x94 (Write); 10010(AD1)(AD0)1 = 0x95 (Read) | | | | | | | | | |-----------|------------------------------------------------------------------------------------------------------------------------|---|---|--------------|--------------|---|---|--------------------|---| | | | | | Page 0x27—DN | IA Registers | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x01 | Soft Reset Reboot | | | _ | _ | | | SFT_RST_<br>REBOOT | _ | | p. 165 | | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | | 0x02-0x7F | Reserved | | | | _ | _ | | | | | | | х | x | X | x | X | x | X | x | # 6.21 S/PDIF Registers | | | | | Page 0x28—S/F | DIF Registers | | | | | |-----------|-------------------|------------|------------------|---------------------|---------------|------------------|-------------------|------------------|--------------------| | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | | | PAGE | | | | ! | | | | | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | | 0x01 | S/PDIF Control 1 | | | _ | | | SPDIF_TX_<br>RAW | SPDIF_TX_<br>KAE | SPDIF_TX_<br>PDN | | p. 166 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | 0x02 | S/PDIF Control 2 | SPDIF_TX_L | SPDIF_TX_<br>PRO | SPDIF_TX_<br>AUDIOB | SPDIF_TX_CP | SPDIF_TX_<br>PRE | SPDIF_TX_<br>VCFG | SPDIF_TX_V | SPDIF_TX_<br>DIGEN | | p. 166 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x03 | S/PDIF Control 3 | _ | | | | SPDIF_TX_CC | • | | | | p. 167 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x04 | S/PDIF Control 4 | | — SPDIF_TX_STAT | | | | | | | | p. 167 | | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | | 0x05–0x7F | Reserved | | | | _ | - | | | | | | | x | X | X | X | x | X | X | X | # **6.22 Serial Port Transmit Registers** | | I <sup>2</sup> C Addres | S: 10010(AD1)( | | | | Write); 10010(AD | 1)(AD0)1 = 0x | 95 (Read) | | |-----------|----------------------------------------------|-------------------|-------------------|-------|------------------|------------------|----------------|-------------------|-------------------------------| | | | | | | rt Transmit Regi | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | | | | PA | AGE | | | | | | | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | | 0x01 | ASP Transmit Size and | | | | _ | | | ASP_TX_2FS | ASP_TX_EN | | p. 168 | Enable | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x02 | ASP Transmit Channel Enable | | | | _ | | | ASP_TX_<br>CH2_EN | ASP_TX_<br>CH1_EN | | p. 168 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x03 | ASP Transmit Channel<br>Phase and Resolution | ASP_TX_<br>CH1_AP | ASP_TX_<br>CH2_AP | | _ | ASP_TX_ | ASP_TX_CH2_RES | | CH1_RES | | p. 168 | | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | 0x04 | ASP Channel 1<br>Transmit Bit Start MSB | | | | _ | • | | | ASP_TX_<br>CH1_BIT_ST_<br>MSB | | p. 168 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x05 | ASP Channel 1 | | | | ASP_TX_CH | 1_BIT_ST_LSB | | | | | p. 168 | Transmit Bit Start LSB | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x06 | ASP Transmit Hi-Z and | _ | _ | ASP T | X_DRV_Z | ASP TX | HIZ_DLY | _ | _ | | p. 169 | Delay Configuration | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x07-0x09 | Reserved | | | | - | _ | | | | | | | x | x | x | x | x | x | x | x | | 0x0A | ASP Channel 2<br>Transmit Bit Start MSB | | | | _ | | | | ASP_TX_<br>CH2_BIT_ST_<br>MSB | | p. 169 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0B | ASP Channel 2 | | | | ASP_TX_CH2 | 2_BIT_ST_LSB | | | | | p. 169 | Transmit Bit Start LSB | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0C-0x7F | Reserved | | | | - | _ | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # **6.23 Serial Port Receive Registers** | | | | | | rt Receive Regis | Vrite); 10010(AD<br>ters | ,. == -, | ·/ | | |----------------|-------------------------------------------------------|--------------------|-------------------------|--------------------|--------------------|--------------------------|--------------------|-----------------|-------------------------------| | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | Control Port Page | 0 | 0 | 1 | PA<br>0 | GE<br>1 | 0 | 1 | 0 | | 0x01 | ASP Receive DAI0<br>Enable | ASP_RX1_<br>CH2_EN | ASP_RX1_<br>CH1_EN | ASP_RX0_<br>CH4_EN | ASP_RX0_<br>CH3_EN | ASP_RX0_<br>CH2_EN | ASP_RX0_<br>CH1_EN | ASP_RX1_<br>2FS | ASP_RX0_<br>2FS | | p. 169 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x02 | ASP Receive DAI0<br>Channel 1 Phase and | _ | ASP_RX0_<br>CH1_AP | | _ | _ | | ASP_RX0 | _CH1_RES | | p. 170 | Resolution | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | 0x03 | ASP Receive DAI0<br>Channel 1 Bit Start<br>MSB | | | | _ | | | | ASP_RX0_<br>CH1_BIT_S<br>MSB | | p. 170 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x04 | ASP Receive DAI0 | | | | ASP_RX0_CH | 1_BIT_ST_LSB | | | | | p. 170 | Channel 1 Bit Start<br>LSB | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x05 | ASP Receive DAI0<br>Channel 2 Phase and | _ | ASP_RX0_<br>CH2_AP | | - | _ | | ASP_RX0 | _CH2_RES | | p. 170 | Resolution | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | 0x06 | ASP Receive DAI0<br>Channel 2 Bit Start<br>MSB | | | | _ | | | | ASP_RX0_<br>CH2_BIT_ST<br>MSB | | p. 170 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x07 | ASP Receive DAI0 | | | | | 2_BIT_ST_LSB | | | 1 | | p. 171 | Channel 2 Bit Start<br>LSB<br>ASP Receive DAI0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x08<br>p. 171 | Channel 3 Phase and Resolution | 0 | ASP_RX0_<br>CH3_AP<br>0 | 0 | 0 | 0 | 0 | 1 1 | _CH3_RES | | 0x09 | ASP Receive DAI0 | 0 | 0 | 0 | | 0 | 0 | ' | ASP RX0 | | | Channel 3 Bit Start<br>MSB | 0 | 0 | 0 | _ | 0 | 0 | 0 | CH3_BIT_S | | p. 171<br>0x0A | ASP Receive DAI0 | 0 | 0 | 0 | 0 | 0<br>3_BIT_ST_LSB | 0 | 0 | 0 | | p. 171 | Channel 3 Bit Start<br>LSB | 0 | 0 | 0 | 0<br>0 | 0 | 0 | 0 | 0 | | 0x0B | ASP Receive DAI0<br>Channel 4 Phase and | _ | ASP_RX0_<br>CH4_AP | | - | _ | | ASP_RX0 | _CH4_RES | | p. 171 | Resolution | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | 0x0C | ASP Receive DAI0<br>Channel 4 Bit Start<br>MSB | | | | _ | | | | ASP_RX0<br>CH4_BIT_S<br>MSB | | p. 172 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0D | ASP Receive DAIO | | | | | 4_BIT_ST_LSB | | | • | | p. 172 | Channel 4 Bit Start<br>LSB | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x0E | ASP Receive DAI1<br>Channel 1 Phase and | _ | ASP_RX1_<br>CH1_AP | | - | _ | | ASP_RX1 | _CH1_RES | | p. 172 | Resolution | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | 0x0F | ASP Receive DAI1<br>Channel 1 Bit Start<br>MSB | | | | _ | | | | ASP_RX1<br>CH1_BIT_S<br>MSB | | p. 172 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x10 | ASP Receive DAI1 | | | | | 1_BIT_ST_LSB | | | • | | p. 172 | Channel 1 Bit Start<br>LSB | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x11 | ASP Receive DAI1<br>Channel 2 Phase and<br>Resolution | _ | ASP_RX1_<br>CH2_AP | | - | _ | | _ | _CH2_RES | | p. 173 | ASP Receive DAI1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 ASP RX1 | | 0x12 | Channel 2 Bit Start<br>MSB | | | | _ | | | | CH2_BIT_S | | p. 173 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x13<br>p. 173 | ASP Receive DAI1<br>Channel 2 Bit Start<br>LSB | 0 | 0 | 0 | ASP_RX1_CH<br>0 | 2_BIT_ST_LSB<br>0 | 0 | 0 | 0 | | )x14–0x7F | | | | | | _ | | | | | WIT OVII | 1.0501704 | x | х | х | x | x | х | х | х | | | | | | | | | | | | ## 6.24 ID Registers | | I <sup>2</sup> C Address: 10010(AD1)(AD0)[R/W] through 10010(AD1)(AD0)0 = 0x94(Write); 10010(AD1)(AD0)1 = 0x95 (Read) | | | | | | | | | |-----------|-----------------------------------------------------------------------------------------------------------------------|---|---|---|-------|--------|---|---|---| | | Page 0x30—ID Registers | | | | | | | | | | Address | Function | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x00 | 0x00 Control Port Page PAGE | | | | | | | | | | | | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | | 0x01-0x13 | 01–0x13 Reserved — | | | | | | | | | | | | x | x | x | x | x | x | x | x | | 0x14 | Subrevision | | | | SUBRE | VISION | | | | | p. 173 | | x | X | X | X | X | X | X | x | | 0x15-0x7F | x15–0x7F Reserved — | | | | | | | | | | | | x | x | x | x | x | x | x | x | ## 7 Register Descriptions The tables in this section give bit assignments, definitions, and default states after power-up or reset. Reserved register fields must maintain default states. Section 6 describes the red, turquoise, and orange indicators. # 7.1 SoundWire Control Port 0 Registers ### 7.1.1 SCP Interrupt Status 1 Address Base + 0x40 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|-------------------|-------------------|-------------------|---|---------------------|--------------------|-------------| | | _ | PORT3_<br>CASCADE | PORT2_<br>CASCADE | PORT1_<br>CASCADE | _ | GEN_INT_<br>CASCADE | STAT_BUS_<br>CLASH | STAT_PARITY | | | | | R/ | O | | | R/W1C | R/W1C | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | _ | Reserved | | 6:4 | | Port x cascade. Indicates whether at least one unmasked interrupt condition is set in the corresponding DP <i>n</i> interrupt status register. The interrupt must be cleared at its source in the DP <i>n</i> interrupt status register. | | | | 0 (Default) No unmasked interrupt conditions in the DP <i>n</i> interrupt status register<br>1 At least one unmasked interrupt condition in DP <i>n</i> interrupt status register | | 3 | _ | Reserved | | 2 | GEN_INT_<br>CASCADE | General interrupt cascade. Indicates whether at least one unmasked interrupt condition is set in the general interrupt status registers 1 and 2. The interrupt must be cleared at its source in the general interrupt status registers. | | 1 | BUS_ | Bus clash status. Indicates whether an interrupt is pending due to detection of a bus clash on the SoundWire bus. If the corresponding mask bit is set, this event can generate an interrupt. Writing a 1 to the bit clears it and its associated interrupt. A sync loss reset does not clear the bit. | | | | (Default) No bus collision detected. Bus collision detected. | | 0 | STAT_<br>PARITY | Parity status. Indicates whether a parity error is detected on the SoundWire bus. If the corresponding mask bit is set, the event can generate an interrupt. Writing a 1 to the bit clears it and its associated interrupt. A sync loss reset does not clear the bit. | | | | 0 (Default) No parity error detected.<br>1 Parity error detected | ## 7.1.2 SCP Interrupt Mask 1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|----------------|-------------| | | | | _ | - | | | MASK_BUS_CLASH | MASK_PARITY | | | | | _ | - | | | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|---------------|-------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1 | MASK_ | Bus clash mask. Determines whether a bus collision event generates an interrupt | | | BUS_<br>CLASH | 0 (Default) A bus collision does not generate an interrupt. 1 A bus collision generates an interrupt. | | 0 | MASK_ | Bus parity error mask. Determines whether a parity error event generates an interrupt | | | PARITY | 0 (Default) A parity error does not generate an interrupt. 1 A parity error generates an interrupt. | ## 7.1.3 SCP Control Address Base + 0x44 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-------------|--------------|---|---|-----|---|----------------|-------------------------| | | FORCE_RESET | CURRENT_BANK | | - | _ | | CLOCK_STOP_NOW | CLOCK_STOP_NOT_FINISHED | | | W/O | R/O | | R | :/O | | W/O | R/O | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Bits | Name | Description | |------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | FORCE_ | Force reset (write only). Used to trigger an internal reset. See Section 4.17 for details. | | | RESET | 0 (Default) No action<br>1 Force internal reset. | | 6 | CURRENT_ | Current bank. Identifies the current register bank. | | | BANK | 0 (Default) current register bank is Bank 0<br>1 Current register bank is Bank 1 | | 5:2 | _ | Reserved | | 1 | CLOCK_<br>STOP_ | Clock stop now (write only). Informs the slave whether the master is shutting down the SoundWire clock at the end of the next frame. | | | NOW | O (Default) Normal operation Clock stops after one more frame. The master is shutting down the SoundWire clock at the end of the next SoundWire frame. The master sends one more frame, which contains a Ping command where the master owns all payload data bit slots. The clock is stopped after the falling edge of the clock for that frame. The asynchronous wake event is allowed to propagate to the data pin only while the clock is stopped. To enter clock stop, the SoundWire master must first set CLOCK_STOP_PREPARE and wait for CLOCK_STOP_NOT_FINISHED to be cleared before setting this bit. | | 0 | CLOCK_<br>STOP_<br>NOT_ | Clock stop not finished. Indicates whether the chip completed any necessary shutdown sequence and is ready for the SoundWire master to set CLOCK_STOP_NOW and shut down the SoundWire clock. The encoding allows a SoundWire group read to identify when all SoundWire slaves are ready to enter Clock Stop State. | | | FINISHED | Ready for clock stop. (Default) Not finished with state transition requested by the current value of CLOCK_STOP_PREPARE. | # 7.1.4 SCP System Control | | 7 6 5 4 | | 3 | 2 | 1 | 0 | | | |---------|---------|---|---|---|----------------|-----------------|---|--------------------| | | | _ | - | | WAKE_UP_ENABLE | CLOCK_STOP_MODE | _ | CLOCK_STOP_PREPARE | | | | _ | _ | | R/W | R/W | _ | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:4 | | Reserved | | 3 | WAKE_<br>UP_<br>ENABLE | Clock Stop Mode wake-up enable. Used to enable asynchronous wake from Clock Stop Mode when an S0 button press, headphone plug, or headphone unplug occurs. | | | ENABLE | 0 (Default) Asynchronous wake disabled.<br>1 Asynchronous wake enabled. | | 2 | CLOCK_ | Clock Stop Mode. Allow the SoundWire slave to lose context coming out of Clock Stop Mode. | | | STOP_<br>MODE | (Default) Slave must not lose context in Clock Stop Mode Slave loses context and triggers a SoundWire hard reset on exit from Clock Stop Mode | | 1 | _ | Reserved | | 0 | CLOCK_<br>STOP_<br>PREPARE | Clock stop prepare. Indicates whether the SoundWire master intends to stop the SoundWire clock. See Section 4.8.13. 0 (Default) Clock stop not requested. 1 The CS42L42 is notified to prepare for clock stop. | #### 7.1.5 SCP Device Number Address Base + 0x46 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|------|-------|---|---------|--------|---| | | _ | - | GROL | JP_ID | | DEVICE_ | NUMBER | | | | _ | - | | | R | /W | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Note: This register can be written only if SoundWire slave has enumeration on. See note in Section 7.1.8. | Bits | Name | Description | |------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:6 | _ | Reserved | | 5:4 | GROUP_<br>ID | Group ID. Indicates whether this SoundWire slave device is addressed by a shared group alias in addition to commands targeted to its own device number. | | | | 00 (Default) Normal, not in a shared group. 01 Group 12: The device reacts to any command directed to the DevAddr = 12 alias. 10 Group 13: The device reacts to any command directed to the DevAddr = 13 alias. 11 Reserved | | 3:0 | | Device number. This value is compared with the DevAddr field in the control word to determine whether the command is directed to this device. Attempts to write to this bit are ignored if the SoundWire slave is not in the Enumeration ON State. See note in Section 7.1.8. | | | | 0000–1011 Valid device numbers (0–11 decimal).<br>1100–1111 Reserved | #### 7.1.6 SCP Device ID 0 Address Base + 0x50 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|----|--------------|-------------------|-------|-----|-------------|----------------|---| | | SO | JNDWIRE_VERS | ION (DeviceID[47: | :44]) | | INSTANCE (D | eviceID[43:40] | | | | | | | F | R/O | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | Х | Х | **Note:** A read of this register puts the SoundWire Slave in the Enumeration ON State. If enumeration is ON, reads of the SCP device ID registers return the Device ID values and writes to the SCP device number register are allowed. If enumeration is OFF, reads of the device ID registers return a zero and writes to the SCP device number register do not complete. If a bus clash is detected while the device ID read data is placed on the SoundWire bus, the SoundWire slave drops out of enumeration (enumeration turns OFF) and remaining bits of the read operation return zero. | Bits | Name | Description | |------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:4 | VERSION - | SoundWire version. Indicates the version of the MIPI SoundWire Specification supported by the device. A value is returned only if enumeration is ON. A zero is returned if enumeration is OFF. If enumeration goes OFF due to a SoundWire bus clash in the middle of a read, a partial value may be returned. | | | | 0000 Pre–MIPI SoundWire Specification, v 1.0 0001 Compliant to MIPI SoundWire Specification, v 1.0. | | 3:0 | | Instance. Used to indicate the instance of the device if there are multiple copies of the same device on the SoundWire bus. A value is returned only if enumeration is ON; a zero is returned if it is OFF. If enumeration goes OFF due to a SoundWire bus clash in the middle of a read, a partial value may be returned. | | | | INSTANCE[3:2] default = 00 INSTANCE[1:0] indicate the AD1/AD0 pin values latched on reset, which are idle when SoundWire is selected. | #### 7.1.7 SCP Device ID 1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---------|-------------|-------------------|-----------|---|---| | | | | MIPI_MA | NUFACTURER_ | ID[15:8] (Devicel | D[39:32]) | | | | | | | | R | /O | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Bits | Name | Description | |------|------|---------------------------------------------------------------------------------------------------------| | 7:0 | | MIPI manufacturer's device ID upper byte. (Cirrus Logic is 0x01FA). The value is returned only if | | | | enumeration is ON. A zero is returned if enumeration is OFF. If enumeration goes OFF due to a SoundWire | | | | bus clash in the middle of a read, a partial value may be returned. | ### 7.1.8 SCP Device ID 2 | Address | Base | + | 0x52 | |---------|------|---|------| | Audicoo | Dase | • | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---------|--------------|--------------------|-----------|---|---| | | | | MIPI_MA | ANUFACTURER_ | _ID[7:0] (DeviceID | )[31:24]) | | | | | | | | R/ | <b>′</b> O | | | | | Default | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | | Bits | Name | Description | |------|---------------------------|----------------------------------------------------------------------------------------------------------------| | 7:0 | MIPI_ | This is a read only field reporting the lower byte of the unique MIPI Manufacturer's device ID value. The MIPI | | | MANUFACTURER_ | Manufacturer ID for Cirrus Logic is 0x01FA. | | | ID[7:0] (DeviceID[31:24]) | A value is returned only when enumeration is ON. A zero is returned if enumeration is OFF. If enumeration | | | | goes OFF due to a SoundWire bus clash in the middle of a read, a partial value may be returned. | ### 7.1.9 SCP Device ID 3 Address Base + 0x53 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|-------------------|-----------------|---|---|---| | | | | | PART_ID [15:8] (I | DEVICEID[23:16] | ) | | | | | | | | R | /O | | | | | Default | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | | Bits | Name | Description | |------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:0 | (DEVICĒID[23:16]) | Part ID upper byte. Unique ID for each device. The value can be read only while the SoundWire Slave is in Enumeration ON State. A zero is returned if enumeration is OFF. If enumeration goes OFF due to a SoundWire bus clash in the middle of a read, a partial value may be returned. Part ID = 4242 | ### 7.1.10 SCP Device ID 4 Address Base + 0x54 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|--------------------------------|---|---|----|------------|---|---|---|--| | | PART_ID [7:0] (DeviceID[15:8]) | | | | | | | | | | | | | | R/ | <b>'</b> O | | | | | | Default | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | | Bits | Name | Description | |------|------------------|------------------------------------------------------------------------------------------------------------------| | 7:0 | PART_ID[7:0] | Part ID lower byte. Unique ID for each device. The value can be read only while the SoundWire Slave is in the | | | (DeviceID[15:8]) | Enumeration ON state. A zero value is returned if enumeration is OFF. If enumeration goes OFF due to a SoundWire | | | | bus clash in the middle of a read, a partial value may be returned. | | | | Part ID = 4242 | ## 7.1.11 SCP Device ID 5 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|----------------------------|---|---|----|---|---|---|---| | | CLASS[7:0] (DeviceID[7:0]) | | | | | | | | | | | | | R/ | 0 | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|------------|--------------------------------------------------------------------------------------------------------------------------------| | 7:0 | CLASS[7:0] | Class. Reserved to indicate the device class. A value is returned only if enumeration is ON. A zero is returned if enumeration | | | | is OFF. If enumeration goes OFF due to a SoundWire bus clash in the middle of a read, a partial value may be returned. | #### 7.1.12 SCP Frame Control Address Base + 0x60 Address Base + 0x70 (Banked) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|-------------|---|--------------|----|---|---| | | | | ROW_CONTROL | C | OLUMN_CONTRO | DL | | | | | | | | V | I/O | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | **Note:** A write to this register in the inactive bank triggers bank switch at the end of the current frame. A write to the Bank 0 register can trigger a bank switch to Bank 0. A write to the Bank 1 register can trigger a bank switch to Bank 1. | Bits | Name | | Description | | | | | | | | | | |------|---------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------|----------------------|----------------------|---------------------|--|--|--|--|--| | 7:3 | | | ows per frame. Selects the number of rows in the frame. This field automatically updates with frame size detected at | | | | | | | | | | | | CONTROL | | mpletion of the frame synchronization search. Writes to this register change the frame shape at the end of the next frame. | | | | | | | | | | | | | | rites to the inactive banked version of this register trigger a bank switch at the end of the next frame, regardless of whether | | | | | | | | | | | | | the register contents I | nave changed. | | | | | | | | | | | | | ROW_CONTROL | Number of Rows | ROW_CONTROL | Number of Rows | ROW_CONTROL | Number of Rows | | | | | | | | | 0x00 | 48 | 0x08 | 96 | 0x10 | 192 | | | | | | | | | 0x01 | 50 | 0x09 | 100 | 0x11 | 200 | | | | | | | | | 0x02 | 60 | 0x0A | 120 | 0x12 | 240 | | | | | | | | | 0x03 | 64 | 0x0B | 128 | 0x13 | 256 | | | | | | | | | 0x04 | 75 | 0x0C | 150 | 0x14 | 72 | | | | | | | | | 0x05 | 80 | 0x0D | 160 | 0x15 | 144 | | | | | | | | | 0x06 | 125 | 0x0E | 250 | 0x16 | 90 | | | | | | | | | 0x07 | 147 | 0x0F | Reserved | 0x17 | 180 | | | | | | | 2:0 | COLUMN_ | Columns per frame. A<br>Writes to this register | utomatically update | es with frame size de | etected at completio | n of the frame synch | nronization search. | | | | | | | | CONTROL | register trigger a bank | | | | | | | | | | | | | | 000 (Default) 2 Colu | | 001 4 Columns | | 111 16 Columns | | | | | | | ## 7.1.13 General Interrupt Status 1 Address Base + 0xC0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-----------------------|---|---|---|---|---|---|--------------| | | GEN_INT_STAT2_CASCADE | | | - | _ | | | SCP_IMP_DEF1 | | | R/O | | | _ | _ | | | R/W1C | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|-------------------|-------------------------------------------------------------------------------------------------------------------------| | 7 | GEN_INT_ | General interrupt status cascade. Reports any unmasked interrupt conditions in the general interrupt status 2 register. | | | STAT2_<br>CASCADE | (Default) No unmasked interrupted condition detected. Unmasked interrupt condition asserted | | 6:1 | _ | Reserved | | 0 | SCP_IMP_ | SCP implementation defined 1. The combined interrupt from the interrupt controller is connected to this bit. | | | DEF1 | (Default) Interrupt not asserted. Interrupt condition asserted | ## 7.1.14 General Interrupt Mask 1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|----------------| | | | | | _ | | | | M_SCP_IMP_DEF1 | | | | | | _ | | | | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | s Name | Description | |-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7: | · — | Reserved | | 0 | | Status bit interrupt enable 1. Enables corresponding status bit to generate an interrupt. This bit is cleared automatically on any internal reset or loss-of-frame synchronization. 0 (Default) Corresponding status bit cannot generate an interrupt. 1 Corresponding status bit may generate an interrupt. | ## 7.1.15 General Interrupt Status 2 #### Address Base + 0xC2 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|--------------------|----------------------|---| | | | _ | | | INT_STAT_LATE_RESP | INT_STAT_TIMEOUT_ERR | _ | | | | _ | | | R/W1C | R/W1C | _ | | | | | | | | | | | Bits | Name | Description | |------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:3 | _ | Reserved | | 2 | INT_STAT_<br>LATE_RESP | Late response. Reports whether any SoundWire read command did not complete in time for the response to be included in the read data response of the same command. See Section 4.8.12.1 for details. | | | | O (Default) Interrupt not asserted Interrupt condition detected. Set on an APB read that requires indirect-access procedures. The associated interrupt can be used as a warning if direct access was expected, but indirect access was required. If set, the bit is cleared by writing a 1 to the bit. It is not cleared by the sync loss reset. | | 1 | INT_STAT_<br>TIMEOUT_<br>ERR | Timeout error. Reports whether a timeout error occurs on the APB read or write access. Timeout error generation is controlled through the memory access timeout register. 0 (Default) Interrupt not asserted 1 Interrupt condition detected. If set, the bit is cleared by writing a 1 to the bit. It is not cleared by the sync loss reset. | | 0 | _ | Reserved | ## 7.1.16 General Interrupt Mask 2 #### Address Base + 0xC3 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|-------------|---------------|---| | | | | _ | | | M_LATE_RESP | M_TIMEOUT_ERR | _ | | | | | _ | | | R/W | R/W | _ | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:3 | _ | Reserved | | 2 | M_LATE_<br>RESP | Late response mask. Enables a late read data event to generate an generate an interrupt. This bit is automatically cleared on any internal reset or loss-of-frame synchronization. | | | | 0 (Default) Late read data does not generate an interrupt.<br>1 Late read data generates an interrupt. | | 1 | M_ | Timeout error mask. Enables an APB timeout error event to generate an interrupt | | | TIMEOUT_<br>ERR | (Default) Timeout error does not generate an interrupt. Timeout error generates an interrupt. | | 0 | _ | Reserved | # 7.1.17 Memory Access Status | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|-----------|-----------------|----------|-----------| | | | _ | _ | | LAST_LATE | CMD_IN_PROGRESS | CMD_DONE | RDATA_RDY | | | | _ | - | | | R/O | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | | | | | | | | |------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 7:4 | _ | Reserved | | | | | | | | | 3 | | Last command late. Indicates whether the previous read command completed in time for the response to be included in a single command for direct access. If not, indirect access procedures are required for registers. | | | | | | | | | | | his bit is cleared at the start of a new transaction through the APB interface. | | | | | | | | | | | O (Default) Previous APB read access was direct. Previous APB read access did not complete in time, and indirect access procedures are required. Note: This bit is also used to set INT_STAT_LATE_RESP. | | | | | | | | | 2 | CMD_IN_<br>PROGRESS | Command in progress. Indicates whether a read/write operation is in progress across the internal bus bridge, including register access initiated through the control word. | | | | | | | | | | | Note: Applies only to read access through the internal bus bridge (address 0x1000 and above). Does not apply to internal SoundWire registers (0x0000–0x0FFF). 0 (Default) No transfer is in progress across the bridge. 1 A read or write access is in progress across the bridge. | | | | | | | | | Bits | Name | Description | |------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | CMD_DONE | Transfer done. Indicates whether the previous read/write access initiated by a control word command through the internal memory bridge completed. It is cleared at the beginning of the next access attempt to the bridge (address above 0x1000). CMD_DONE is cleared by any control word–initiated read/write to any address accessed through the internal memory bridge. CMD_DONE is cleared on a read command that returns previously fetched data. | | | | (Default) Previous access through the bridge not completed or no access requested yet. Previous access through the bridge completed. | | 0 | RDATA_<br>RDY | Read data ready. Indicates whether the previous control word–initiated read access is complete and the read data would be returned on the next control word initiated read of the same address, which is preserved in MEM_READ_LAST_ADDR. | | | | Note: Applies only to read access through the internal bus bridge (address 0x1000 and above) and not to internal SoundWire registers (0x0000–0x0FFF). This bit is cleared by any control word–initiated read access to any address accessed through the internal memory bridge. 0 (Default) Bridge does not contain previous read data or new read data fetch is in progress. 1 Bridge contains read data that can be read from the memory read data register (see Section 7.1.21) | ## 7.1.18 Memory Access Control Address Base + 0xD1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|---|---|---|---|---|---|---|-----------|--| | | _ | | | | | | | LATE_RESP | | | | _ | | | | | | | /W | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | Bits | Name | Description | |------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1:0 | | Late response. Selects the command response supplied in the control word NAK/ACK bits for read instructions when read data is not available in time to be returned in the same command. | | | | 00 Respond with COMMAND_IGNORED 01 (Default) Respond with COMMAND_OK, which allows for indirect access. If indirect access procedures are required to access the read data at a later time in the MEM_READ_DATA, this selection allows the COMMAND_OK to acknowledge that the internal access was accepted and initiated. 10 Respond with COMMAND_FAIL 11 Reserved | | | | If operating conditions require direct access to always be allowed, the response can be programmed as either COMMAND_IGNORED or COMMAND_FAIL to provide an immediate indication of the delay. | | | | <b>Note</b> : A COMMAND FAIL response can also be returned on APB access if the previous access did not complete. | # 7.1.19 Memory Access Timeout | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|-----------------|-----|--------------|---| | | | _ | _ | | TIMEOUT_DISABLE | | TIMEOUT_CTRL | - | | | | _ | _ | | | R/W | 1 | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | | Description | | | | | | | | |------|----------|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|---------------------------------------------|--|--|--|--|--| | 7:4 | _ | Reserved | | | | | | | | | | 3 | TIMEOUT_ | Timeout disable. Disables time | meout disable. Disables timeout control. See Section 4.8.12 for details and examples. | | | | | | | | | | DISABLE | O (Default) Timeout enabled Timeout disabled on intern | 0 (Default) Timeout enabled on internal memory access through the APB memory bridge. 1 Timeout disabled on internal memory access through the APB memory bridge. | | | | | | | | | 2:0 | TIMEOUT_ | | | | through the APB memory bridge | | | | | | | | CTRL | 10 | enerates a timeout error and aborts the memory access. | | | | | | | | | | | 000 (Default) 8 bus cycles<br>001 16 bus cycles | 010 32 bus cycles<br>011 64 bus cycles | 100 128 bus cycles<br>101 256 bus cycles | 110 512 bus cycles<br>111 65,535 bus cycles | | | | | | ### 7.1.20 Memory Read Last Address 0 and 1 Address Base + 0xD4 Address Base + 0xD5 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|--------------------------|---|---|-------------|---------------|---|---|---|--| | | | | | MEM_READ_LA | AST_ADDR[7:0] | | | | | | | MEM_READ_LAST_ADDR[15:8] | | | | | | | | | | | R/O | | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits | Name | Description | ] | |------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---| | | | Memory read last address. Address of the last completed read access via a control word command. Valid only if RDATA_RDY is set. See Section 4.8.12 for details. | Ī | | | LAST_<br>ADDR | Applies only to the last access through the memory access bridge to the internal APB (which requires indirect access via a SoundWire command). Not applicable to internal SoundWire registers (addresses 0x0000–0x0FFF), which are accessed directly via a SoundWire command. | | ### 7.1.21 Memory Read Data Address Base + 0xD8 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|--------------------|---|---|---|---|---|---|---|--| | | MEM_READ_DATA[7:0] | | | | | | | | | | | R/O | | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bit | Name | Description | |-----|-----------|------------------------------------------------------------------------------------------------------------------| | 7:0 | MEM_ | Memory read data. Contains the data previously read from the address stored in MEM_READ_LAST_ADDR. Data is valid | | | READ_DATA | if the RDATA_RDY status bit of in the memory access status register is set. See Section 4.8.12 for details. | ## 7.2 SoundWire Data Port (1-3) Descriptions The registers in this section are replicated for each enabled data port enabled via the SW\_NUM\_PORTS RTL parameter. The "n" in "DPn" represents the appropriate port number (1–3; see Table 4-10 for port mappings). ### 7.2.1 DP*n* Interrupt Status | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|------------------|----------------| | | | | _ | - | | | STAT_P'ORT_READY | STAT_TEST_FAIL | | | _ | | | | | | R/W1 | C | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1 | STAT_<br>PORT_<br>READY | Port ready status. Indicates whether the port is ready for data transfer after a prepare request. This event generates an interrupt if the corresponding mask register bit is set. It is cleared only by writing 1 to it. It is not cleared by a sync loss reset. See Section 4.8.8 for programming details. 0 (Default) Port is not ready. 1 Port is ready. | | 0 | STAT_<br>TEST_<br>FAIL | Status test/fail. Indicates whether an error was detected during PRBS, Static0, or Static1 test modes when a sink data port (Data Ports 2 and 3) does not receive the expected value from the SoundWire bus. This bit is never set in source data ports (Data Port 1). The bit is cleared only by writing 1 to it. It is not cleared by the sync loss reset. 0 (Default) No Test Mode error detected. 1 Test Mode error detected. | ## 7.2.2 DPn Interrupt Mask #### Address Base + 0x01 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|--------------|-------------| | | | | _ | _ | | | PORT_READY_M | TEST_FAIL_M | | | _ | | | | | | R/V | / | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1 | PORT_<br>READY_ | Port ready mask. Enables corresponding status bit to generate an interrupt. This bit is automatically cleared on any internal reset or loss-of-frame synchronization. | | | M | O (Default) Corresponding status bit cannot generate an interrupt. Corresponding status bit may generate an interrupt. | | 0 | TEST_<br>FAIL_M | Test/fail mask. Enables the corresponding status bit to generate an interrupt. This bit is automatically cleared on any internal reset or loss-of-frame synchronization. | | | | 0 (Default) Corresponding status bit cannot generate an interrupt. 1 Corresponding status bit may generate an interrupt. | ### 7.2.3 DP*n* Port Control #### Address Base + 0x02 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|-------------|---------|----------|---|---| | | | _ | | INVERT_BANK | PORT_DA | ATA_MODE | _ | _ | | | | _ | | | | R/W | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | | | | | | | | | | |------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 7:5 | _ | Reserved | | | | | | | | | | | 4 | | nvert bank. Applies to DP <i>n</i> -prefixed registers for this port, but not to SCP-prefixed banked registers. This bit is cleared on a sync loss reset. The selected value is applied at the end of the SoundWire frame with the command writing to NVERT_BANK. | | | | | | | | | | | | | Note: This function for this bit was defined before the publication of MIPI SoundWire Specification, v. 1.0, in which this bit is replaced with NEXT_INVERT_BANK. 0 (Default) Use bank as directed in the control word. 1 Use the opposite bank than what is directed in the control word. Setting is applied on the next frame boundary | | | | | | | | | | | 3:2 | PORT_ | Port data mode. Determines whether the port is in Normal Mode or Test Mode of data transfer. | | | | | | | | | | | | DATA_MODE | 00 (Default) Normal 01 Test Mode test data 10 Static 0 test data 11 Static 1 test data | | | | | | | | | | | 1:0 | _ | Reserved | | | | | | | | | | ### 7.2.4 DPn Block Control 1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------------|---|---|---|---|----|---|---| | | — WORD_LENGTH | | | | | | | | | | _ | | | | R | /W | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|--------|-------------------------------------------------------------------------------------------------------------| | 7:6 | | Reserved | | 5:0 | WORD_ | Word length. Specifies the payload length in bits. Configure this bit before enabling channels on the port. | | | LENGTH | 00 0000 (Default) 1 bit 00 0001 2 bits | ### 7.2.5 DPn Prepare Status Address Base + 0x04 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|-----|-----------------------|-----------------------| | | | | - | _ | | | NOT_FINISHED_CHANNEL2 | NOT_FINISHED_CHANNEL1 | | | | | | | | R/O | • | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1:0 | FINISHED_ | Not finished channel. Indicates whether each channel completed its state transition after the corresponding PREPARE_CHANNELx bit is written to prepare or deprepare the channel. | | | CHANNELx | 0 (Default) Channel not finished moving to the preparedness state indicated by the CHANNEL_PREPAREx bit. 1 After PREPARE_CHANNELx is set, if NOT_FINISHED_CHANNELx = 1, the channel has not finished the transition to readiness. A 0 indicates that the channel is ready. Fig. 4-27 shows how to interpret channel status. After PREPARE_CHANNELx is cleared, if NOT_FINISHED_CHANNELx = 1, the channel is not finished with the transition to deprepared state. A 0 indicates that the channel has finished any internal process to be deprepared. | ## 7.2.6 DPn Prepare Control Address Base + 0x05 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|-----|---|------------------|------------------| | | | | _ | _ | | | PREPARE_CHANNEL2 | PREPARE_CHANNEL1 | | | | | | | R/W | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|----------|---------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1:0 | PREPARE_ | Prepare channel. Prepares each channel so it can begin immediately when enabled. Data Ports 2 and 3 are stereo and | | | CHANNELx | therefore support Channels 1 and 2. Data Port 1 supports only Channel 1. Fig. 4-27 shows how to interpret channel status. | | | | O (Default) Channel deactivated Channel commanded to prepare for activity. | ### 7.2.7 DPn Channel Enable Address Base + 0x20 Address Base + 0x30 (Banked) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|----|---|---|-------------|-------------| | | | | _ | _ | | | CHANNEL_EN2 | CHANNEL_EN1 | | | | | | R/ | W | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | 1 | |------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---| | 7:2 | _ | Reserved | 1 | | 1:0 | ENx - | Channel enable 2 and 1. Automatically cleared on internal resets and loss-of-frame synchronization. Do not set these bits unless the channel has been prepared using the DP <i>n</i> prepare control register and confirmed by reading the DP <i>n</i> prepare status register. Data Ports 2 and 3 are stereo and therefore support Channels 1 and 2. Data Port 1 supports Channel 1 only. | | | | | 0 (Default) Channel disabled 1 Channel enabled | | ## 7.2.8 DPn Sample Control 1 Address Base + 0x22 Address Base + 0x32 (Banked) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |---------|---------------------|---|---|---|---|---|---|---|--|--|--| | | SAMPLE_INTERVAL_LOW | | | | | | | | | | | | | R/W | | | | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | | | Bits | Name | Description | |------|--------------|-------------------------------------------------------------------------------------------------------------------------| | 7:0 | SAMPLE_ | Sample interval lower byte. The sample interval is calculated in units of bit slots according to the following formula: | | | INTERVAL_LOW | Sample Interval = 256*SAMPLE_INTERVAL_HIGH + SAMPLE_INTERVAL_LOW + 1 | ## 7.2.9 DPn Sample Control 2 Address Base + 0x23 Address Base + 0x33 (Banked) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---------|----------------------|---|---|---|---|---|---|---|--|--| | | SAMPLE_INTERVAL_HIGH | | | | | | | | | | | | R/W | | | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits | ts Name Description | | | | | | | |------|---------------------|------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 7:0 | SAMPLE_ | Sample interval upper byte. The interval is calculated in units of bit slots according to the following formula: | | | | | | | | INTERVAL_HIGH | Sample Interval = 256*SAMPLE_INTERVAL_HIGH + SAMPLE_INTERVAL_LOW + 1 | | | | | | #### 7.2.10 DPn Offset Control 1 Address Base + 0x24 Address Base + 0x34 (Banked) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---------|---------|---|---|----|----|---|---|---|--|--| | | OFFSET1 | | | | | | | | | | | | | | | R/ | /W | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits | Name | Description | | | | | | | | |------|---------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 7:0 | OFFSET1 | Block offset control 1. Determines the number of bit slots from the start of the sample interval to the start of the port's payload | | | | | | | | | | | ta block within the SoundWire frame. | | | | | | | | | | | <ul> <li>In Block-per-Channel mode, the block offset is calculated as follows: Block Offset = OFFSET1</li> </ul> | | | | | | | | | | | In Block-per-Port Mode, the block offset is calculated as follows: Block Offset = OFFSET1 + (256 * OFFSET2) | | | | | | | | ### 7.2.11 DPn Offset Control 2 Address Base + 0x25 Address Base + 0x35 (Banked) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---------|---------|---|---|---|---|---|---|---|--|--| | | OFFSET2 | | | | | | | | | | | | R/W | | | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits | Name | Description | |------|------|------------------------------------------------------------------------------------------------------------------------------------| | 7:0' | | Block offset control 2. Determines either the block offset (number of bit slots from the start of the sample interval to the start | | | | of the port's payload data block) or the subblock offset (number of bit slots between individual channels), which is the number | | | | of bit slots from the start of the sample interval to the start of the port's payload data block within the SoundWire frame. | | | | In Block-per-Channel Mode, the subblock offset is calculated as follows: Subblock offset = OFFSET2 | | | | In Block-per-Port Mode, the block offset is calculated as follows: Block Offset = OFFSET1 + (256 * OFFSET2) | #### 7.2.12 DP*n* Horizontal Control Address Base + 0x26 Address Base + 0x36 (Banked) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|-----|-----|----|---|-----|----|---| | | | HST | ART | | | HST | OP | | | | | | | R/ | W | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|--------|---------------------------------------------------------------------------------------------------------------------------------| | 7:4 | HSTART | Horizontal control start. Defines the column number within a row that is the start of the port's transport subframe. The port's | | | | payload data is bounded by the columns defined by HSTART and HSTOP. The HSTART value must not exceed HSTOP. | | | | 0x0 (Default) Subframe begins in Column 0 0x1 Subframe begins in Column 1 0xF Subframe begins in Column 15 | | 3:0 | HSTOP | Horizontal control stop. Defines the column number within a row that is the end of the port's transport subframe. The port's | | | | payload data is bounded by the columns defined by HSTART and HSTOP. The HSTART value must not exceed HSTOP. | | | | 0x0 (Default) Subframe ends in Column 0 0x1 Subframe ends in Column 1 0xF Subframe ends in Column 15 | ### 7.2.13 DPn Block Control 3 Address Base + 0x27 Address Base + 0x37 (Banked) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|--------------------| | | | | | _ | | | | BLOCK_PACKING_MODE | | | | | | _ | | | | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | | Block packing mode. Determines how the port's channel data is positioned within the SoundWire frame. | | | PACKING_<br>MODE | 0 (Default) Block-per-Port Mode. Each channel's payload is adjacent (no space between channels) within the port's payload transport window. | | | | 1 Block-per-Channel Mode. Spacing is added between individual channels within the payload transport window. | ## 7.3 Global Registers ## 7.3.1 Device ID A and B Address 0x1001 | 2 | 1 | 0 | |-----|-------|------------| | DEV | /IDB | | | 0 | 1 | 0 | | _ | 0 DEV | DEVIDB 0 1 | ### 7.3.2 Device ID C and D Address 0x1002 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|-----|------|---|---|-----|------|---| | | | DEV | 'IDC | | | DE\ | /IDD | | | Default | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | ### 7.3.3 Device ID E and F Address 0x1003 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|-----|------|---|---|---|---|---| | | | DEV | /IDE | | | _ | _ | | | Default | 0 | 0 | 1 | 0 | х | х | х | х | | Bits | Name | Description | |------|------------------|-----------------------------------------------------------------| | 7:4 | DEVIDA | Device ID code. Identifies the CS42L42. | | | DEVIDC<br>DEVIDE | DEVIDA 0x4<br>DEVIDB 0x2 | | 3:0 | DEVIDB<br>DEVIDD | DEVIDC 0xA Represents the L in CS42L42. DEVIDD 0x4 DEVIDE 0x2 | ### 7.3.4 Revision ID | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|-----|------|---|---|------|------|---| | | | ARE | :VID | | | MTLR | EVID | | | Default | x | x | х | х | х | х | х | х | | Bits | Name | Description | |------|----------|-------------------------------------------------------------------------------------------------------------------------| | 7:4 | AREVID | Alpha revision. CS42L42 alpha revision level. AREVID and MTLREVID form the complete device revision ID (e.g.,: A0, B2). | | | | 0x00 0xFF | | 3:0 | MTLREVID | Metal revision. CS42L42 metal revision level. AREVID and MTLREVID form the complete device revision ID (e.g.,: A0, B2). | | | | 0x00 0xFF | | 7 2 E | Freeze Control | |-------|----------------| | / | rreeze Comiroi | | | Address 0x1006 | |---|----------------| | 1 | 0 | | | FREEZE | | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|--------| | | | | | _ | | | | FREEZE | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | | Freeze registers. Configures a hold on all volume-control and power-down register settings except PDN_MIC_LVL_DETECT (p. 155). Use this bit only during normal operation after all circuit blocks in use have powered up. Using the bit when an affected circuit block is powering up could cause the change to occur immediately when power up completes (i.e., not gated by the FREEZE bit). Bits affected by FREEZE are shown in orange throughout Section 6 and Section 7. 0 (Default) Volume-control and power-down register changes take effect immediately. 1 Modifications made to volume-control and power-down registers take effect only after this bit is cleared. | ### 7.3.6 Serial Port SRC Control #### Address 0x1007 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|-----------|-----------|-----------|----------------|----------------| | | | _ | | EQ_BYPASS | I2C_DRIVE | ASP_DRIVE | SRC_BYPASS_DAC | SRC_BYPASS_ADC | | Default | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|----------------|--------------------------------------------------------------------------------------------------------------------------| | 7:5 | _ | Reserved | | 4 | EQ_<br>BYPASS | Bypass equalizer. Configures whether the EQ block is bypassed. See Section 4.1 for details | | | DIPASS | 0 No bypass<br>1 (Default) Bypass | | 3 | _ | I <sup>2</sup> C output drive strength. Selects drive strength used for the SDA output | | | DRIVE | 0 (Default) Normal<br>1 Decreased | | 2 | | ASP output drive strength. Selects drive strength used for the ASP port SDOUT output. See Table 3-25 for specifications. | | | DRIVE | 0 (Default) Normal<br>1 Decreased | | 1 | | Bypass SRC (DAC path). Determines the bypass of the input SRCs. See Section 4.11 for details. | | | BYPASS_<br>DAC | 0 (Default) No bypass<br>1 Bypass. SRC SDIN_FS (see p. 165) must be set equal to Fs <sub>INT</sub> . | | 0 | SRC | Bypass SRC (ADC path). Determines the bypass of the output SRCs. See Section 4.11 for details. | | | BYPASS | 0 (Default) No bypass | | | ADC _ | 1 Bypass. SRC_SDIN_FS must be set equal to Fs <sub>INT</sub> . | ## 7.3.7 MCLK Status | Address | 0x1008 | |---------|--------| | Auuless | 0.000 | | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|------------------|---| | | | | _ | _ | | | INTERNAL_FS_STAT | _ | | Default | 0 | 0 | 0 | 0 | 0 | 0 | X | 0 | | Bits | Name | Description | |------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1 | | Internal sample rate status. Indicates the divide ratio from MCLK <sub>INT</sub> (set in INTERNAL_FS, see Section 7.3.8) to produce the internal sample rate for all converters. | | | | 0 Fs <sub>INT</sub> = MCLK <sub>INT</sub> /250. Indicates that the internal MCLK is 12 or 24 MHz.<br>1 Fs <sub>INT</sub> = MCLK <sub>INT</sub> /256. Indicates that the internal MCLK is 11.2896, 12.288, 22.5792, or 24.576 MHz. | | 0 | _ | Reserved | Address 0x1009 | 720 | MCLK Control | | |-------|--------------|--| | 7.3.0 | MCLK COULTOI | | | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|---| | | _ | | | | | | | _ | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | Bits | Name | Description | |------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1 | INTERNAL_<br>FS | Internal sample rate (Fs <sub>INT</sub> ). Selects the divide ratio from MCLK <sub>INT</sub> to produce the internal sample rate for all converters. See Table 4-6 for programming details. This bit always returns zero when read. Reports status in INTERNAL_FS_STAT. 0 Fs <sub>INT</sub> = MCLK <sub>INT</sub> /250. Set if internal MCLK is 12 or 24 MHz. 1 (Default) Fs <sub>INT</sub> = MCLK <sub>INT</sub> /256. Set if internal MCLK is 11.2896, 12.288, 22.5792, or 24.576 MHz. If MCLK <sub>INT</sub> 11.2896, 12, or 12.288 MHz, MCLKDIV must be 0. If it is 22.5792, 24, or 24.576 MHz, MCLKDIV must be 1. | | 0 | _ | Reserved | ## 7.3.9 Soft Ramp Rate Address 0x100A | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|----------|---|---|---|----------|---|---|---| | | ASR_RATE | | | | DSR_RATE | | | | | Default | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | | Bits | Name | Description | | | | | | | | | |------|------|-----------------|---------------|-----------------------|------------------|------------------|----------------------------|----------------|-----------------|--| | 7:4 | ASR_ | Analog soft-r | amp rate (num | ber of Fs periods be | etween steps). | Selects the sof | ft ramp rate for all analo | og volumes. S | tep size = 1 dB | | | | RATE | or 2 dB for H | POUTx. See | Section 4.4.4 for det | ails. | | | | | | | | | 0000 1 | 0010 4 | 0100 8 | 0110 12 | 1000 22 | 1010 (Default) 33 | 1100 44 | 1110 66 | | | | | 0001 2 | 0011 6 | 0101 11 | 0111 16 | 1001 24 | 1011 36 | 1101 48 | 1111 72 | | | 3:0 | | Digital soft-ra | mp rate (numb | er of Fs periods betw | een steps). Sele | ects soft ramp r | ate for all digital volume | s. Step size = | 0.125 dB. | | | | RATE | 0000 1 | 0010 4 | 0100 (Default) 8 | 0110 12 | 1000 22 | 1010 33 | 1100 44 | 1110 66 | | | | | 0001 2 | 0011 6 | 0101 1 | 0111 16 | 1001 24 | 1011 36 | 1101 48 | 1111 72 | | ### 7.3.10 Slow Start Enable Address 0x100B | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---------------|---|---|---|---|---| | | _ | S | SLOW_START_EN | | | _ | _ | | | Default | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|----------|--------------------------------------------------------------------------------------------------------------------------------------| | 7 | _ | Reserved | | 6:4 | | Slow startup enable. Selects between fast and slow start-up times. See Section 4.4.5 for details. | | | START_EN | 000 Disabled. Shortens start-up time of the mixer, DAC, and HP. Useful for high-definition audio applications. 111 (Default) Enabled | | 3:0 | _ | Reserved | ## 7.3.11 I<sup>2</sup>C Debounce Address 0x100E | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|-----------------|----|-----------------|---|-----------------|----|-----------------| | | | I2C_SDA_DBNC_CN | IT | I2C_SDA_DBNC_EN | | I2C_SCL_DBNC_CN | IT | I2C_SCL_DBNC_EN | | Default | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | | Bits | Name | Description | | | | | | | | |------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 7:5 | I2C_SDA_ | I <sup>2</sup> C debounce count. Number of MCLKs to debounce SDA input | | | | | | | | | | DBNC_CNT | Note: The I2C_SDA_DBNC_CNT and I2C_SCL_DBNC_CNT settings must be identical. 000 0 MCLKs 010 2 MCLKs 100 (Default) 4 MCLKs 110 6 MCLKs 001 1 MCLK 011 3 MCLKs 101 5 MCLKs 111 7 MCLKs | | | | | | | | | 4 | I2C_SDA_ | I2C SDA debounce enable. SDA debounce enable | | | | | | | | | | DBNC_EN | Note: The I2C_SDA_DBNC_EN and I2C_SCL_DBNC_EN settings must be identical. 0 (Default) Disabled. Must be 0 for Fast Mode or Fast-Mode Plus. 1 Enabled | | | | | | | | | 3:1 | | I <sup>2</sup> C SCL debounce count. Number of MCLKs to debounce SCL input | | | | | | | | | | DBNC_CNT | Note: The I2C_SDA_DBNC_CNT and I2C_SCL_DBNC_CNT settings must be identical. 000 0 MCLKs 010 2 MCLKs 100 (Default) 4 MCLKs 110 6 MCLKs 001 1 MCLK 011 3 MCLKs 101 5 MCLKs 111 7 MCLKs | | | | | | | | | Bits | Name | Description | |------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | I2C_SCL_ | I <sup>2</sup> C SCL debounce count enable. | | | DBNC_EN | Note: The settings of I2C_SDA_DBNC_EN and I2C_SCL_DBNC_EN must be identical. 0 (Default) Disabled. Must be 0 for Fast Mode or Fast-Plus Mode. 1 Enabled | | 7 3 12 | I <sup>2</sup> C Stretch | Add | ress 0x100F | |--------|--------------------------|------|-------------| | 1.3.1Z | 12C Suelli | Audi | COO OX IOOI | | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|--------|-------|---|---|---| | | | | | I2C_ST | RETCH | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | Bits | Name | Description | |------|---------|------------------------------------------------------------------------------------------------| | 7:0 | _ | I <sup>2</sup> C stretch. Number of additional MCLKs to clock stretch after the slave is ready | | | STRETCH | 0000 0011 (Default) 3 MCLKs | 7.3.13 I<sup>2</sup>C Timeout Address 0x1010 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|--------------|------------|--------|-------|------------|---|------------|---| | | MAS_I2C_NACK | MAS_TO_DIS | MAS_TO | )_SEL | ACC_TO_DIS | | ACC_TO_SEL | | | Default | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | | Bits | Name | | | Description | | | | | | | | |------|--------------|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|------------------------------------------|----------------------------|--|--|--|--|--|--| | 7 | 100 - | | PB master I2C NACK. Determines whether clock stretching or a NACK occurs if an APB access is attempted and I2C is not APB | | | | | | | | | | | I2C_<br>NACK | master. | | | | | | | | | | | | INACK | 0 I <sup>2</sup> C clock stretches if an | APB access is attempted w | hile I <sup>2</sup> C is not APB master. | | | | | | | | | | | 1 (Default) I <sup>2</sup> C NACKs if A | PB access is attempted whi | le I <sup>2</sup> C is not APB master. | | | | | | | | | 6 | | APB master access timeout | | | | | | | | | | | | TO_DĪS | 0 (Default) Enabled | 1 Disabled | | | | | | | | | | 5:4 | | APB master access timeout | select. Determines the time | out duration. | | | | | | | | | | TO_SĒL | 00 64 ms | 01 128 ms | 10 256 ms | 11 (Default) 512 ms | | | | | | | | 3 | | APB access timeout disable | • | | | | | | | | | | | TO_DĪS | 0 (Default) Enabled | 1 Disabled | | | | | | | | | | 2:0 | | APB access timeout select. Determines the timeout duration in MCLKs. | | | | | | | | | | | | TO_SĒL | 000 7 MCLKs | 010 31 MCLKs | 100 127 MCLKs | 110 511 MCLKs | | | | | | | | | | 001 15 MCLKs | 011 63 MCLKs | 101 255 MCLKs | 111 (Default) 65,535 MCLKs | | | | | | | ## 7.4 Power Down and Headset Detects ### 7.4.1 Power Down Control 1 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-------------|-------------|-----------|--------|--------|---------|---|---------| | | ASP_DAO_PDN | ASP_DAI_PDN | MIXER_PDN | EQ_PDN | HP_PDN | ADC_PDN | _ | PDN_ALL | | Default | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Bits | Name | Description | | | | | | | | |------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 7 | | ASP output path power down. Configures ASP SDOUT path power state. | | | | | | | | | | DAO_<br>PDN | 0 Powered up 1 (Default) Powered down, SDOUT is Hi-Z; ASP_DAO1 is powered down. The setting does not tristate the serial port clock. | | | | | | | | | 6 | | ASP DAI0 input path power down. Configures ASP DAI0 SDIN path power state. | | | | | | | | | | DAI_ | 0 Powered up | | | | | | | | | | PDN | 1 (Default) Powered down. Setting this bit does not tristate the serial port clock. | | | | | | | | | 5 | | Mixer power down. Configures the mixer power state. | | | | | | | | | | PDN | 0 The mixer is powered up. | | | | | | | | | | | 1 (Default) The mixer is powered down. | | | | | | | | | 4 | EQ_ | Equalizer power down. Configures the equalizer power state. See the restrictions described in Section 4.3. | | | | | | | | | | PDN | 0 Powered up | | | | | | | | | | | 1 (Default) Powered down. All filter state data is reset to pass-through coefficients. | | | | | | | | | 3 | | HPOUTx power down | | | | | | | | | | PDN | 0 The HP driver and DACx are powered up. | | | | | | | | | | | 1 (Default) The HP driver and DACx are powered down. | | | | | | | | | Bits | Name | Description | |------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | ADC_ | ADC power down | | | PDN | Powered up. The ADC is powered up. (Default) The ADC is powered down. | | 1 | _ | Reserved | | 0 | ALL | Codec power down. Configures the entire codec's power state except for PLL_START and SPDIF_TX_PDN (which is not affected in order to support Keep-Alive Mode). After power up (PDN_ALL: $1 \rightarrow 0$ ), individual subblocks are powered according to power-control programming. This bit is affected by LATCH_TO_VP (see p. 155). | | | | Note: The SRC power-down state depends on the SRC_PDN_OVERRIDE setting (see p. 136). 0 Powered up, per the individual x_PDN controls 1 (Default) Powered down. PDN_ALL must not be set without first enabling LATCH_TO_VP. After PDN_ALL is set and the entire codec is powered down, PDN_DONE is set, indicating that SCLK can be removed. | ## 7.4.2 Power Down Control 2 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---------------------|----------------------|--------------|------------------|------------------| | | | _ | | DISCHARGE_<br>FILT+ | SRC_PDN_<br>OVERRIDE | ASP_DAI1_PDN | DAC_SRC_<br>PDNB | ADC_SRC_<br>PDNB | | Default | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | Bits | Name | Description | |------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:5 | _ | Reserved | | 4 | DISCHARGE_<br>FILT+ | Discharge FILT+ capacitor. Configures the state of the FILT+ pin internal clamp. Before setting this bit, ensure that the VD_FILT device input is connected to a supply, as shown in Table 3-2. | | | | 0 (Default) FILT+ is not clamped to ground.<br>1 FILT+ is clamped to ground. This must be set only if PDN_ALL = 1. Discharge time with an external 2.2-μF<br>capacitor on FILT+ is ∼46 ms. | | 3 | | SRC power down override. Configures the SRCs' power states. | | | OVERRIDE | <ul> <li>0 (Default) Power state control for the DAC and ADC SRCs, which are controlled by the following smart logic:</li> <li>DAC SRCs are off if SRC BYPASS DAC = 1.</li> <li>ADC SRC is off if SRC_BYPASS_ADC = 1.</li> <li>If PDN_ALL = 1, all SRCs are off.</li> </ul> | | | | <ul> <li>If PDN ALL = 0 and the respective ADC or DAC bypass bits = 0, the following controls each SRC's power state: —If SWIRE SEL pin = VL, all SRCs are ON —If SWIRE SEL pin = GNDL the following applies: —If DAI0 is enabled, the DAC SRCs are powered up. </li> </ul> | | | | <ul> <li>If DAO is enabled, the ADC SRC is powered up.</li> <li>DAC SRCs are controlled by DAC_SRC_PDNB and the ADC SRC is controlled by ADC_SRC_PDNB.</li> </ul> | | 2 | ASP_DAI1_<br>PDN | ASP DAI1 power down. This applies only to the S/PDIF port.lf ASP_DAI_PDN is set, DAI1 is also powered down regardless of this register setting. | | | | 0 ASP power up<br>1 (Default) ASP power down | | 1 | DAC_SRC_ | DAC SRC power down. Configures the DAC ASP power state if SRC_PDN_OVERRIDE = 1. | | | PDNB | 0 (Default) Power down<br>1 Power up audio DAC SRC only | | 0 | | ADC SRC power down. Configures the ADC SRC power state if SRC_PDN_OVERRIDE = 1. | | | PDNB | 0 (Default) Power down<br>1 Power up audio ADC SRC only | ## 7.4.3 Power Down Control 3 Address 0x1103 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---------------------|---|---|------------|-----------------|---|---| | | _ | SW_CLK_STP_STAT_SEL | | _ | VPMON_PDNB | RING_SENSE_PDNB | _ | | | Default | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | | Reserved | | 6:5 | SW_<br>CLK_ | SoundWire clock-stop status selection. Sets which functional blocks report as powered down before clearing CLOCK_STOP_NOT_FINISHED (see p. 122). Section 4.8.13 describes SoundWire Clock-Stop Mode and wake events. | | | STP_<br>STAT_ | <b>Note:</b> This field does not perform power-down commands for each functional block; the user must set those commands manually through SoundWire control. | | | SEL | 00 The device does not perform any functions before clearing CLOCK_STOP_NOT_FINISHED. 01 (Default) Complete power-down (i.e., DAC, ADC, S/PDIF_TX, HS, and MICBIAS). Follow Ex. 5-2, Steps 1–7. After completing these steps, if the PLL is in use, to ensure that no commands are missed when exiting Clock Stop Mode, clear MCLK_SRC_SEL to use the SWIRE_CLK source, then power down the PLL by clearing PLL_START. Additionally, the headset-detection sequence must be completed (HSDET_CTRL = 00 or 10) before CLOCK_STOP_NOT_FINISHED is cleared. 10 Only ADC_PDN, HP_PDN, and SPDIF_TX_PDN must be asserted. 11 Reserved | | 4:3 | | Reserved | | 2 | VPMON_ | VPMON power down. VP monitor is described in Section 4.15.1. | | | PDNB | 0 (Default) Power down VPMON.<br>1 Power up VPMON. | | 1 | RING_ | Ring sense power down | | | SENSE_<br>PDNB | 0 (Default) Power down ring sense.<br>1 Power up ring sense. | | 0 | _ | Reserved | ## 7.4.4 Ring Sense Control 1 | R/W | 7 | 6 | 5 4 | | 3 | 2 | 1 | 0 | |---------|---|-------------------|-----|---|--------------------|----------|-----------|-----------| | | _ | RING_SENSE_PU_HIZ | | _ | HSBIAS_FILT_REF_RS | HPREF_RS | RS_TRIM_T | RS_TRIM_R | | Default | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | _ | Reserved | | 6 | RING_<br>SENSE_<br>PU_HIZ | Ring-sense pull-up to Hi-Z. Used to decrease the value of the pull-up resistor to allow detection of impedances above or below ~1 kΩ (e.g., Mid-Z Detection Mode). See Section 4.14.3 for programming details. 0 Mid-Z Detection Mode 1 (Default) Hi-Z Detection Mode. | | 5:4 | _ | Reserved | | 3 | HSBIAS_<br>FILT_<br>REF RS | Headset bias filter reference. Sets the state of the HSBIAS_FILT_REF_RS switch. See Section 4.13, Section 4.14.3, and SW_REF_HSx on p. 140. | | | INEI _INO | (Default) Ring sense is not used as the ground reference. Ring sense is used as the ground reference. | | 2 | HP_<br>REF_RS | Headphone amp reference. Determines whether ring sense is used as a ground reference. See Section 4.13, Section 4.14.3, and SW_REF_HSx on p. 140. | | | | (Default) Ring sense is not used as the headphone amplifier ground reference. Ring sense is used as the headphone amplifier ground reference. | | 1 | RS_<br>TRIM_T | Ring-sense trim threshold. See Section 4.14.3 for programming details. 0 (Default) V <sub>IH</sub> = 0.1 * VP; V <sub>IL</sub> = 0.05 * VP. 1 V <sub>IH</sub> = 0.35 * VP; V <sub>IL</sub> = 0.3 * VP | | 0 | RS_<br>TRIM_R | Ring-sense trim resistance. See Section 4.14.3 for programming details. 0 (Default) Pull-up resistance = 2.25 M $\Omega$ . 1 Pull-up resistance = 1.125 M $\Omega$ . | ## 7.4.5 Ring Sense Control 2 | Address | 0x110 | |---------|-------| |---------|-------| | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|------------|---|---|---|---|---|---|---| | | TS_RS_GATE | | | | _ | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bi | ts Name | Description | |----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | TS_RS_ | Tip/ring sense gating, Configures whether tip and ring sense are interdependent. Section 4.14.4 gives programming details. | | | GATE | (Default) Individual jacks. TIP_SENSE and RING_SENSE are independent of each other. Combo plug. TIP_SENSE and RING_SENSE mutually gate each other. | | 6 | 0 — | Reserved | ### 7.4.6 Oscillator Switch Control #### Address 0x1107 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|---|---|---|---|---|---|---|--------------|--| | | | | | _ | | | | SCLK_PRESENT | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits | Name | Description | |------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | | SCLK present. Used to select the internal MCLK source. See Section 4.7 for programming details. | | | PRESENT | 0→1 transition starts switch from RCO to selected internal MCLK (SCLK must be running first). 1→0 transition starts switch from selected internal MCLK to RCO (SCLK must keep running during transition). | | | | O (Default) SCLK may be present, but the internal MCLK is sourced from the RCO. 1 SCLK is present and the internal MCLK is sourced from the SCLK pin. | ### 7.4.7 Oscillator Switch Status #### Address 0x1109 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---------------|---|-----------| | | | | _ | | | OSC_PDNB_STAT | | _SEL_STAT | | Default | 0 | 0 | 0 | 0 | 0 | 1 | X | х | | Bits | Name | Description | | | | | | |------|-----------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 7:3 | _ | Reserved | | | | | | | 2 | | RCO power-down status. Indicates the RCO power state. See Section 4.7 for programming details. | | | | | | | | PDNB_STAT | RCO powered down | | | | | | | | | 1 (Default) RCO powered up | | | | | | | 1:0 | | RCO switch status. Indicates the RCO oscillator switch status. The default is determined by the state of the SWIRE_SEL | | | | | | | | SEL_STAT | pin; see Section 1.See Section 4.7 for programming details. | | | | | | | | | 00 In transition 10 (Default, if SWIRE_SEL is asserted) SCLK/PLL selected for | | | | | | | | | 01 (Default, if SWIRE_SEL is deasserted) RCO internal MCLK selected for internal MCLK 11 Reserved | | | | | | | | | Selected for internal Mich | | | | | | # 7.4.8 Ring Sense Control 3 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|--------|----------|--------------------|---|---|---|----------------|-----| | | RS_INV | RS_PU_EN | RS_FALL_DBNCE_TIME | | | R | S_RISE_DBNCE_T | IME | | Default | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | | Bits | Name | | Description | | | | | | | |------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-------------------------|-------------------------|--|--|--|--| | 7 | RS_INV | Ring-sense invert. Used to invert the signal from the ring-sense circuit. Reverses the meaning of RS_UNPLUG_DBNC and RS_PLUG_DBNC (see p. 139). | | | | | | | | | | | 0 (Default) Not inverted<br>1 Inverted | | | | | | | | | 6 | RS_PU_EN | Ring-sense pull-up enable. Cor | ing-sense pull-up enable. Configures whether the ring-sense pull-up is connected. | | | | | | | | | | O (Default) Pull-up disconnec Pull-up connected | 0 (Default) Pull-up disconnected 1 Pull-up connected | | | | | | | | 5:3 | RS_FALL_ | Ring sense falling debounce tir | ne. Section 4.14.4 gives progra | amming details. | | | | | | | | DBNCE_TIME | 001 125 ms | 010 250 ms<br>011 (Default) 500 ms | 100 750 ms<br>101 1.0 s | 110 1.25 s<br>111 1.5 s | | | | | | 2:0 | RS_RISE_ | Ring sense rising debounce tim | ne. Section 4.14.4 gives progra | | | | | | | | | DBNCE_TIME | 000 0 ms<br>001 125 ms | 010 250 ms | 100 750 ms | 110 1.25 s<br>111 1.5 s | | | | | | | | 001 125 1118 | 011 (Default) 500 ms | 101 1.0 s | 111 1.5 8 | | | | | ## 7.4.9 Tip Sense Control 1 #### Address 0x1113 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|--------|---|-----|--------------|-----------------------|---|---|---| | | TS_INV | _ | TS_ | FALL_DBNCE_T | ME TS_RISE_DBNCE_TIME | | | | | Default | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | | Bits | Name | | Description | | | | | | | | |------|------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------------------|--|--|--|--|--| | 7 | TS_INV | | ip sense raw signal invert. Used to invert the raw signal from the tip-sense circuit. Reverses the meaning of TS_INPLUG_DBNC and TS_PLUG_DBNC (see p. 139). | | | | | | | | | | | 0 (Default) Not inverted<br>1 Inverted | | | | | | | | | | 6 | _ | Reserved | Reserved | | | | | | | | | 5:3 | TS_FALL_ | Tip sense falling debounce tin | ne. Section 4.14.4 gives pro | gramming details. | | | | | | | | | DBNCE_TIME | 000 0 ms | 010 250 ms | 100 750 ms | 110 1.25 s | | | | | | | | _ | 001 125 ms | 011 (Default) 500 ms | 101 1.0 s | 111 1.5 s | | | | | | | 2:0 | TS_RISE_ | Tip sense rising debounce tim | ne. Section 4.14.4 gives pro | gramming details. | | | | | | | | | DBNCE_TIME | 000 0 ms<br>001 125 ms | 010 250 ms<br>011 (Default) 500 ms | 100 750 ms<br>101 1.0 s | 110 1.25 s<br>111 1.5 s | | | | | | ## 7.4.10 Tip Sense/Ring Sense Indicator Status #### Address 0x1115 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|--------------------|------------------|--------------------|------------------| | | | _ | _ | | TS_UNPLUG_<br>DBNC | TS_PLUG_<br>DBNC | RS_UNPLUG_<br>DBNC | RS_PLUG_<br>DBNC | | Default | 0 | 0 | 0 | 0 | Х | х | Х | х | | Bits | Name | Description | |------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:4 | _ | Reserved | | 3 | TS_<br>UNPLUG_<br>DBNC | Tip sense unplug debounce status. See Section 4.14.4 for details. Setting TS_INV reverses the meaning of this bit. 0 Condition is not present. 1 Condition is present. | | 2 | TS_PLUG_<br>DBNC | Tip sense plug debounce status. See Section 4.14.4 for details. Setting TS_INV reverses the meaning of this bit. 0 Condition is not present. 1 Condition is present. | | 1 | RS_<br>UNPLUG_<br>DBNC | Ring sense unplug debounce status. See Section 4.14.4 for details. Setting RS_INV reverses the meaning of this bit. 0 Condition is not present. 1 Condition is present. | | 0 | RS_PLUG_<br>DBNC | Ring sense plug debounce status. See Section 4.14.4 for details. Setting RS_INV reverses the meaning of this bit. 0 Condition is not present. 1 Condition is present. | ### 7.4.11 Headset Detect Control 1 #### Address 0x111F | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---------|----------|---|---|----------|----------|---| | | | HSDET_C | OMP2_LVL | | | HSDET_CO | OMP1_LVL | | | Default | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | | Bits | Name | | Description | | | | | | | | |------|-----------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--|--|--|--|--|--| | 7:4 | HSDET_ | Headset Detect Comparator | eadset Detect Comparator 2 level. Sets the reference level used by the HSDET Comparator 2. Table 3-16 lists | | | | | | | | | | COMP2_LVL | tolerances for these values. | erances for these values. See Section 4.13 for details. | | | | | | | | | | | 0000 1.65 V | 0111 (Default) 2.0 V | 1111 2.4 V | | | | | | | | 3:0 | | | leadset Detect Comparator 1 level. Sets the reference level used by the HSDET Comparator 1. Table 3-16 lists olerances for these values. See Section 4.13 for details. | | | | | | | | | | | 0000 0.65 V | 0111 (Default) 1.0 V | 1111 1.4 V | | | | | | | ## 7.4.12 Headset Detect Control 2 #### Address 0x1120 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|------------|---|-----------|---|------------|---|---------|----------| | | HSDET_CTRL | | HSDET_SET | | HSBIAS_REF | _ | HSDET_A | UTO_TIME | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | | | | | | | |------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 7:6 | HSDET_ | Headset type detect mode. Sets the headset type detect mode. For details, see Section 4.13.1. | | | | | | | | | CTRL | <ul> <li>00 (Default) Manual, disabled. Headset-type-detect comparator and reference voltage are powered down. Internal switch controls in Section 7.4.13 are active; the system can configure them as needed. HSDET_SET must be set appropriately.</li> <li>01 Manual, active. The headset-type-detect comparators and reference voltage are enabled. Comparator outputs are reported to their HSDET_COMPx_OUT status bits. The internal switch controls in Section 7.4.13 are active and the system can configure them as needed. HSDET_SET must also be set appropriately.</li> <li>10 Automatic, disabled. The headset-type-detect comparator, reference voltage, and logic are powered down. Internal switch controls in Section 7.4.13 are ignored and remain in their previous state (i.e., not set to the values in Section 7.4.13).</li> <li>11 Automatic, active. Headset-type-detect comparator, reference voltage, and logic are enabled. When set to this value from another state, logic starts a sequence that detects headset type; internal switches are configured into the correct state, as reported by HSDET_TYPE. Internal switch controls in Section 7.4.13 are ignored. When detection finishes, HSDET_AUTO_DONE is set and can be configured to cause an interrupt. HSDET_CTRL must then be set to 10.</li> </ul> | | | | | | | | 5:4 | HSDET_ | leadset detect manual mode setting. Used for setting the MIC bias switches on the headset. In manual mode (HSDET_CTRL | | | | | | | | | SET | = 00 or 01), the setting indicates to the codec which headset pin is configured for HSBIAS and which is configured for ground. See Section 4.13 for details | | | | | | | | | | HS3 Pin Configuration HS4 Pin Configuration | | | | | | | | | | 00 (Default) GND HSBIAS | | | | | | | | | | 01 HSBIAS GND | | | | | | | | | | 10 GND GND 11 Reserved Reserved | | | | | | | | 3 | ПСВІЛС | Selects the pin used for the internal headset microphone bias LDO reference. | | | | | | | | 3 | HSBIAS_<br>REF | · · | | | | | | | | | IXEI | 0 (Default) HSx_REF selected as the ground reference 1 Closed HSx selected as the ground | | | | | | | | 3:2 | | Reserved | | | | | | | | 1:0 | HSDET_ | Automatic headset detect cycle time. Sets the time that the HSDET logic waits in each detection phase. | | | | | | | | | AUTO_ | 00 (Default) 10 μs 10 50 μs | | | | | | | | | TIME | 01 20 μs 11 100 μs | | | | | | | ## 7.4.13 Headset Switch Control | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|------------|------------|---------------------|---------------------|------------|------------|------------------|------------------| | | SW_REF_HS3 | SW_REF_HS4 | SW_HSB_FILT_<br>HS3 | SW_HSB_FILT_<br>HS4 | SW_HSB_HS3 | SW_HSB_HS4 | SW_GNDHS_<br>HS3 | SW_GNDHS_<br>HS4 | | Default | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | | Bits | Name | Description | |------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:6 | SW_ | Ref-to-HSx switch. Sets the Ref-to-HSx switch state. See Section 4.13. This bit is affected by LATCH_TO_VP (see p. 155). | | | REF_HSx | 0 Open<br>1 (Default) Closed | | 5:4 | SW_<br>HSB_ | HSBIAS_FILT_REF-to-HSx or HSx_REF switch. Sets the state of the HSBIAS_FILT_REF-to-HSx or HSx_REF switch, depending on the HSBIAS_REF setting. See Section 4.13. This bit is affected by LATCH_TO_VP. | | | FILT_HSx | o open | | | | 1 (Default) Closed | | 3:2 | SW_ | HSBIAS-to-HSx switch. Sets the HSBIAS-to-HSx switch state. See Section 4.13. This bit is affected by LATCH_TO_VP. | | | HSB_<br>HSx | 0 (Default) Open<br>1 Closed | | 1:0 | SW_ | GNDHS-to-HSx switch. Sets the GNDHS-to-HSx switch state. See Section 4.13. This bit is affected by LATCH_TO_VP. | | | GNDHS_<br>HSx | 0 Open | | | пох | 1 (Default) Closed | ### 7.4.14 Headset Detect Status #### Address 0x1124 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-----------------|-----------------|---|---|---|---|-------|-------| | | HSDET_COMP2_OUT | HSDET_COMP1_OUT | | _ | _ | | HSDET | _TYPE | | Default | X | Х | 0 | 0 | 0 | х | х | х | | Bits | Name | Description | | | | | | | |------|--------|---------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 7:6 | HSDET_ | adset detect comparator output state. Based on the HSDET_COMPx_LVL setting. See HSDET_CTRL (p. 140), HSDET_ | | | | | | | | | COMPx_ | AUTO_DONE (p. 146), and Section 4.13 for details. | | | | | | | | | OUT | 0 Low 1 High | | | | | | | | 5:2 | _ | Reserved | | | | | | | | 1:0 | HSDET_ | eadset detect type. Indicates the headset type determined by automatic headset detect logic (see Section 4.13.1). Ex. 5-5 | | | | | | | | | TYPE _ | provides a sample sequence. | | | | | | | | | | 00 1 01 2 10 3 11 4 | | | | | | | ## 7.4.15 Headset Clamp Disable #### Address 0x1129 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|------------------| | | | | | _ | | | | HS_CLAMP_DISABLE | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|---------|------------------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | HS_ | Headset clamp disable. Clamping devices suppress ground-noise when connecting to an external amplifier and the CS42L42 | | | CLAMP_ | is powered down. Section 5.6 gives a programming example. This bit is affected by LATCH_TO_VP (see p. 155). | | | DISABLE | o (Delault) no diampo are connected and provide ground-noise suppression | | | | 1 HS clamps are disconnected and no ground-noise suppression available | # 7.5 Clocking Registers ### 7.5.1 MCLK Source Select #### Address 0x1201 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---------|--------------| | | | | - | _ | | | MCLKDIV | MCLK_SRC_SEL | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1 | | Master clock divide ratio. Selects the divide ratio between the selected MCLK source and the MCLK <sub>INT</sub> . Section 4.7.2 lists supported MCLK rates and their associated programming settings. 0 (Default) Divide by 1 (source MCLK <sub>INT</sub> = ~12 MHz). 1 Divide by 2 (source MCLK <sub>INT</sub> = ~24 MHz) Note: Change this field only if PDN_ALL = 1. | | 0 | MCLK_<br>SRC_<br>SEL | Master clock source select. Selects the internal master clock source. For programming details and examples, see Section 4.7. 0 (Default) SCLK pin 1 PLL clock | ## 7.5.2 S/PDIF Clock Configuration | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|--------------|---|--------------------|-----------------|---| | | - | _ | | SPDIF_CLK_DI | V | SPDIF_LRCK_SRC_SEL | SPDIF_LRCK_CPOL | _ | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | | | | | | | |------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 7:6 | _ | Reserved | | | | | | | | 5:3 | SPDIF_<br>CLK_DIV | /PDIF clock divide factor. For proper S/PDIF timing, use the following formula to choose the divide value: Divide factor = MCLK <sub>INT</sub> /(128 x Fs). For details, see Section 4.10.2. For example, if Fs of the S/PDIF output should be 92 kHz, 128 x 192 kHz = 24.576 MHz. If ASP_SCLK is 24.576 MHz, the divide factor must be 1 (SPIF_CLK_DIV = 000). 000 (Default) 1 010 3 100 8 001 2 011 4 101–111Reserved | | | | | | | | 2 | | S/PDIF LRCK source select. S/PDIF LRCK requires a 50% duty cycle. If the externally provided duty cycle is not 50%, an internally generated LRCK is required. See Section 4.10.1. 0 (Default) Use internally generated LRCK. Typically used for Hybrid-Master Mode or with SoundWire. 1 Use LRCK from the ASP_LRCK pin. Typically used for Slave Mode. | | | | | | | | Bits | Name | Description | |------|--------|------------------------------------------------------------------| | 1 | SPDIF_ | S/PDIF LRCK polarity. Selects LRCK polarity. See Section 4.10.1. | | | LRCK_ | 0 (Default) Normal | | | CPOL | 1 Înverted | | 0 | _ | Reserved | ## 7.5.3 FSYNC Pulse Width, Lower Byte | Address | 0x1 | 20 | |---------|-----|----| |---------|-----|----| | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |---------|----------------------|---|---|---|---|---|---|---|--|--|--|--| | | FSYNC_PULSE_WIDTH_LB | | | | | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | Bits | Name | Description | |------|--------|----------------------------------------------------------------------------------------------------------------------------| | 7:0 | FSYNC_ | FSYNC pulse width LB. FSYNC_PULSE_WIDTH_UB FSYNC_PULSE_WIDTH_LB provides an 11-bit field to set the duty | | | | cycle of LRCK in Hybrid-Master Mode. These combined value forms an integer number of SCLK periods within an LRCK | | | | frame that governs the LRCK high time. See Section 4.9.2 for usage details and Section 5 for a programming example. The | | | LB | value must be 1 less than the desired width of the LRCK pulse, measured in SCLK counts, as illustrated by the value below. | | | | FSYNC_PULSE_WIDTH_UB FSYNC_PULSE_WIDTH_LB yield the following setting value: | | | | 000 0000 0000 (Default) LRCK is one SCLK wide. | ## 7.5.4 FSYNC Pulse Width, Upper Byte Address 0x1204 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|------------------------|---|---|---|---|---|---|---| | | — FSYNC_PULSE_WIDTH_UE | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name Description | | | | | | |------|------------------|----------------------------------------------------------------------------------|--|--|--|--| | 7:3 | _ | Reserved | | | | | | 2:0 | | FSYNC pulse width UB. See description for FSYNC_PULSE_WIDTH_LB in Section 7.5.3. | | | | | | | WIDTH_UB | 000 (Default) | | | | | ## 7.5.5 FSYNC Period, Lower Byte Address 0x1205 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |---------|-----------------|---|---|---|---|---|---|---|--|--|--|--| | | FSYNC_PERIOD_LB | | | | | | | | | | | | | Default | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | | | | | | Bits | Name | Description | | | | | | | | | |------|---------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 7:0 | FSYNC_ | SYNC period LB. FSYNC PERIOD UB FSYNC PERIOD LB controls frequency (number of SCLKs per LRCK) of LRCK | | | | | | | | | | | PERIOD_ | or ASP. Section 4.9.2 for details on how this register is used and Section 5 for a programming example. The final SCLKs per | | | | | | | | | | | LB | LRCK count is +1 of the value set in the UB LB register field | | | | | | | | | | | | FSYNC PERIOD UB FSYNC PERIOD LB yield the following setting values: | | | | | | | | | | | | 0x000 1 SCLK/LRCK 0x0F9 (Default) 250 SCLKs/ LRCK 0xFFF 4096 SCLKs/ LRCK | | | | | | | | | ## 7.5.6 FSYNC Period, Upper Byte | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|---|---|---|---|-----------------|---|---|---|--| | | | _ | _ | | FSYNC_PERIOD_UB | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits | Name | Description | |------|-----------|------------------------------------------------------------------------| | 7:4 | _ | Reserved | | 3:0 | FSYNC_ | FSYNC period UB. See description for FSYNC_PERIOD_LB in Section 7.5.5. | | | PERIOD_UB | 0000 (Default) | # 7.5.7 ASP Clock Configuration 1 Address 0x1207 | R/W | W 7 6 | | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-------|---|-------------|-----------------|------------------|------------------|---------------|--------------| | | _ | | ASP_SCLK_EN | ASP_HYBRID_MODE | ASP_SCPOL_IN_ADC | ASP_SCPOL_IN_DAC | ASP_LCPOL_OUT | ASP_LCPOL_IN | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:6 | _ | Reserved | | 5 | | ASP SCLK enable. Must be set if DAO/DAI functionality is used. | | | EN | 0 (Default) Disabled<br>1 Enabled | | 4 | ASP_ | ASP Hybrid-Master Mode. Allows the internal LRCK to be generated from SCLK. See Fig. 4-31 for details. | | | HYBRID_<br>MODE | O (Default) LRCK is input from external source which is synchronous to SCLK (Slave Mode). LRCK is an output generated from SCLK (Hybrid Master Mode). | | 3 | | ASP SCLK input polarity. Determines the drive polarity for ADC path. See Fig. 4-30 for details. | | | IN_ADC | 0 (Default) SDOUT launched on rising edge<br>1 SDOUT launched on falling edge | | 2 | | ASP SCLK input polarity. Determines the polarity for the DAC path. See Fig. 4-31 for details. | | | IN_DAC | 0 (Default) SDIN latched on falling edge<br>1 SDIN latched on rising edge | | 1 | | ASP LRCK output drive polarity. Determines the polarity for the ASP LRCK output drive. See Fig. 4-31 for details. | | | OUT | 0 (Default) Normal<br>1 Inverted | | 0 | ASP_LCPOL_<br>IN | ASP LRCK input polarity. Determines ASP LRCK input polarity (pad to logic). See Fig. 4-31 for details. 0 (Default) Normal 1 Inverted | ## 7.5.8 ASP Frame Configuration Address 0x1208 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---------|----------|---|---------|---| | | | _ | | ASP_STP | ASP_5050 | | ASP_FSD | | | Default | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:5 | _ | Reserved | | 4 | | ASP start phase. Controls which LRCK/FSYNC phase starts a frame. See Section 4.9.5 for details. | | | STP | 0 The frame begins when LRCK/FSYNC transitions from high to low<br>1 (Default) The frame begins when LRCK/FSYNC transitions from low to high | | 3 | ASP_ | ASP LRCK fixed 50/50 duty cycle. Determines whether the duty cycle is fixed or programmable. See Section 4.9.5 for details. | | | 5050 | 0 (Default) Programmable duty cycle. Determined by FSYNC_PULSE_WIDTH_LB (see p. 142), FSYNC_PULSE_WIDTH_UB, and FSYNC_PERIOD_xSB (see p. 142). 1 50/50 Mode. Fixed 50% duty cycle | | 2:0 | ASP_ | ASP frame-start delay. Determines the delay before the start of an ASP frame in ASP_SCLK periods. See Section 4.9.2. | | | FSD | 000 (Default) 0 delay 001 0.5 delay 010 1.0 delay 101 2.5 delay 110–111 Reserved | ## 7.5.9 FS Rate Enable | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|-----|----|---| | | | _ | | | | FS_ | EN | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:4 | _ | Reserved | | 3:0 | FS_EN | Fs rate enable. Provides enables for all internally generated Fs rates. 0 = disabled; 1 = enabled. Section 4.11 gives details. | | | | FS_EN[0] Enable IASRC 96K and lower rates. FS_EN[1] Enable OASRC96K and lower rates. FS_EN[2] Enable IASRC 192, 176.4, and 176.471 K rates FS_EN[3] Enable OASRC 192, 176.4, and 176.471 K rates 0000 (Default) All disabled | ## 7.5.10 Input ASRC Clock Select #### Address 0x120A | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|---|---|---|-----------------|---|---|---|---|--| | | | | _ | — CLK_IASRC_SEL | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits | Name | Description | |------|------------|----------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1:0 | CLK_IASRC_ | Input ASRC clock select. Selects input ASRC MCLK <sub>INT</sub> frequency. See Section 4.11 for programming details. | | | SEL | 00 (Default) 6 MHz | ## 7.5.11 Output ASRC Clock Select #### Address 0x120B | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---------|---------|---|---|---|---| | | | | CLK_OAS | SRC_SEL | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|-----------|------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1:0 | CLK_ | Output ASRC clock select. Selects output ASRC MCLK <sub>INT</sub> frequency. See Section 4.11 for programming details. | | | OASRC_SEL | 00 (Default) 6 MHz | ## 7.5.12 PLL Divide Configuration 1 #### Address 0x120C | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|-------------|--------|--------| | | | | _ | | | PLL_REF_INV | SCLK_I | PREDIV | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|----------|--------------------------------------------------------------------------| | 7:3 | _ | Reserved | | 2 | PLL_REF_ | Invert PLL reference clock. See Table 4.7.3 for programming guidelines. | | | INV | 0 (Default) Normal<br>1 Inverted | | 1:0 | SCLK_ | PLL reference divide select. See Table 4.7.3 for programming guidelines. | | | PREDIV | 00 (Default) Divide by 1 01 Divide by 2 10 Divide by 4 11 Divide by 8 | ## 7.6 Interrupt Registers ## 7.6.1 ADC Overflow Interrupt Status #### Address 0x1301 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|----------| | | | | | _ | | | | ADC_OVFL | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Х | | Bits | Name | Description | |------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | | ADC overflow. Indicates the overrange status in the corresponding signal path. Rising-edge state transitions may cause an interrupt, depending on the programming of the associated interrupt mask bit. 0 No digital clipping has occurred in the data path of the respective signal source. 1 Digital clipping has occurred in the data path of the respective signal source. | ## 7.6.2 Mixer Interrupt Status | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|----------------|---------|--------------|--------------| | | | _ | _ | | EQ_BIQUAD_OVFL | EQ_OVFL | MIX_CHA_OVFL | MIX_CHB_OVFL | | Default | 0 | 0 | 0 | 0 | х | х | Х | х | | Bits | Name | Description | |------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:4 | _ | Reserved | | 3 | EQ_<br>BIQUAD_<br>OVFL | Digital equalizer biquad overflow. Indicates the overrange status in the individual biquads in the equalizer data path. Rising-edge state transitions may cause an interrupt, depending on the programming of the associated interrupt mask bit. No digital clipping occurred in one of the individual biquads in the equalizer data path Digital clipping occurred in one of the individual biquads in the equalizer data path | | Bits | Name | Description | |------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | EQ_OVFL | Digital equalizer data path overflow. Indicates the overrange status of the equalizer data path. Rising-edge state transitions may cause an interrupt, depending on the programming of the associated interrupt mask bit. | | | | No digital clipping occurred in the equalizer data path. Digital clipping occurred in the equalizer data path. Note: If EQ overflow conditions occur regularly, it is recommended that the EQ coefficients be modified. | | 1 | MIX_CHA_<br>OVFL | Channel overflow. Indicates the overrange status in the corresponding signal path. Rising-edge state transitions may cause an interrupt, depending on the programming of the associated interrupt mask bit. | | 0 | MIX_CHB_<br>OVFL | No digital clipping has occurred in the data path of the respective signal source. Digital clipping has occurred in the data path of the respective signal source. | # 7.6.3 SRC Interrupt Status Address 0x1303 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|-----------|-----------|---------|---------| | | | _ | - | | SRC_OUNLK | SRC_IUNLK | SRC_OLK | SRC_ILK | | Default | 0 | 0 | 0 | 0 | х | Х | х | х | | Bits | Name | Description | |------|-----------|---------------------------------------------------------------------------------------------------------------------------| | 7:4 | _ | Reserved | | 3 | SRC_OUNLK | SRC unlock status. Indicates SRC unlock status for the output path. Status is valid only if serial-port LRCK is toggling. | | | | 0 Locked<br>1 Unlocked | | 2 | SRC_IUNLK | SRC unlock status. Indicates SRC unlock status for the input path. Status is valid only if serial-port LRCK is toggling. | | | | 0 Locked<br>1 Unlocked | | 1 | SRC_OLK | SRC lock status. Indicates SRC lock status for the ASP output path. Status is valid only if serial-port LRCK is toggling. | | | | 0 Unlocked<br>1 Locked | | 0 | SRC_ILK | SRC lock status. Indicates SRC lock status for the ASP input path. Status is valid only if serial-port LRCK is toggling. | | | | 0 Unlocked<br>1 Locked | # 7.6.4 ASP RX Interrupt Status | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|------------|-------------|------------|-------------|--------------| | | | _ | | ASPRX_OVLD | ASPRX_ERROR | ASPRX_LATE | ASPRX_EARLY | ASPRX_NOLRCK | | Default | 0 | 0 | 0 | Х | х | Х | Х | Х | | Bits | Name | Description | |------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:5 | _ | Reserved | | 4 | ASPRX_<br>OVLD | ASP RX request overload. Set when too many input buffers request processing at once. 0No interrupt 1 Interrupt detected. ASP RX cannot retrieve data from the internal input buffers because at least one of the following violations has occurred: —The ASP RX core clock frequency is less than SCLK/8. | | | | —The LRCK frame (non-50/50 Mode) or LRCK subframe (50/50 Mode) period is less than 16 SCLK periods (assuming the ASP RX core clock frequency is equal to SCLK/8). | | 3 | | ASP RX LRCK error. Logical OR of ASPRX_LATE and ASPRX_EARLY, described below. | | | ERROR | 0 No interrupt 1 Interrupt detected | | 2 | ASPRX_<br>LATE | ASP RX LRCK late. Determines whether the number of SCLK periods per LRCK phase (high or low) is greater than the expected count, as determined by the FSYNC_PERIOD_xSB and FSYNC_PULSE_WIDTH_x fields. | | | | 0 No interrupt 1 Interrupt detected | | 1 | ASPRX_<br>EARLY | ASP RX LRCK early. Determines whether the number of SCLK periods per LRCK phase (high or low) is less than the expected count, as determined by FSYNC_PERIOD_xSB (see p. 142) and FSYNC_PULSE_WIDTH_x (see p. 142). | | | | 0 No interrupt 1 Interrupt detected | | 0 | | ASP RX no LRCK. Determines whether the SCLK periods counted exceeds twice the value of LRCK period (FSYNC_PERIOD_xSB) without an LRCK edge. | | | | 0 No interrupt 1 Interrupt detected | ### 7.6.5 ASP TX Interrupt Status #### Address 0x1305 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---------------|------------|-------------|--------------| | | | _ | - | | ASPTX_SMERROR | ASPTX_LATE | ASPTX_EARLY | ASPTX_NOLRCK | | Default | 0 | 0 | 0 | 0 | х | Х | Х | х | | Bits | Name | Description | |------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:4 | _ | Reserved | | 3 | ASPTX_<br>SMERROR | ASP TX SM error. Determines whether the transmit state machine cannot retrieve data from output buffers; it is analogous to ASP Rx request overload. If all channel size and location registers are properly configured to nonoverlapping values, this error status should never be set. | | | | 0 No interrupt 1 Interrupt detected | | 2 | ASPTX_<br>LATE | ASP TX LRCK late. Determines whether the number of SCLK periods per LRCK phase (high or low) is greater than the expected count as determined by the FSYNC_PERIOD_xSB and FSYNC_PULSE_WIDTH_x fields. | | | | 0 No interrupt 1 Interrupt detected | | 1 | ASPTX_<br>EARLY | ASP TX LRCK early. Determines whether the number of SCLK periods per LRCK phase (high or low) is less than the expected count indicated by FSYNC_PERIOD_xSB (see p. 142) and FSYNC_PULSE_WIDTH_x (see p. 142). | | | | 0 No interrupt 1 Interrupt detected | | 0 | ASPTX_<br>NOLRCK | ASP TX no LRCK. Determines whether the number of SCLK periods counted exceeds twice the value of LRCK period (FSYNC_PERIOD_xSB) without an LRCK edge. | | | | 0 No interrupt 1 Interrupt detected | ## 7.6.6 Codec Interrupt Status ### Address 0x1308 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|-----------------|----------| | | | | _ | _ | | | HSDET_AUTO_DONE | PDN_DONE | | Default | 0 | 0 | 0 | 0 | 0 | 0 | Х | х | | Bits | Name | Description | |------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1 | _ | Automatic headset detect done. Indicates when HSDET logic has finished its detection cycle and the headset can be read from HSDET_COMPx_OUT. 0 HSDET is disabled or has not completed its detection cycle. 1 The HSDET logic has completed its detection cycle. | | 0 | _ | Power-down done. Indicates when the codec has powered down and MCLK can be stopped, as determined by various power-control and headset-interface register settings. 0 Not completely powered down 1 Powered down as a result of PDN_ALL having been set. | # 7.6.7 Detect Interrupt Status 1 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|--------------|----------------|------------------|---|---|---|---|---| | | HSBIAS_SENSE | TIP_SENSE_PLUG | TIP_SENSE_UNPLUG | | | _ | | | | Default | х | Х | Х | х | х | Х | х | х | | Bits | Name | Description | |------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | HSBIAS_SENSE | HSBIAS sense. Indicates whether the HSBIAS output current falls below the HSBIAS_SENSE_TRIP value. | | | | Output current has not gone below the specified threshold. Output current has gone below the specified threshold. | | 6 | TIP_SENSE_PLUG | Tip sense plug event. Indicates the undebounced status of a plug event on the TIP_SENSE pin.1 | | | | 0 No HP plug event 1 HP plug event | | 5 | TIP_SENSE_UNPLUG | Tip sense unplug event. Indicates the undebounced status of an unplug event on the TIP_SENSE pin. <sup>1</sup> 0 (Default) No HP unplug event 1 HP unplug event | | 4:0 | _ | Reserved | <sup>1.</sup> This bit is affected by EVENT\_STATUS\_SEL (see p. 156). It is active only if TIP\_SENSE\_CTRL (p. 154) is configured so the tip-sense circuit is powered up. If the system is configured for standby operation, the sticky version of this bit (that also accounts for events that occurred during standby) can be read back after a wake event. Use EVENT\_STATUS\_SEL to retrieve this bit's information under that scenario. ### 7.6.8 Detect Interrupt Status 2 Address 0x130A | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-----------------------|-----------------------|---|---|---|------------|-------------------|--------------------| | | DETECT_TRUE_<br>FALSE | DETECT_FALSE_<br>TRUE | | _ | | HSBIAS_HIZ | SHORT_<br>RELEASE | SHORT_<br>DETECTED | | Default | х | Х | х | х | х | Х | х | х | | Bits | Name | Description | |------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | DETECT_TRUE_FALSE | Mic detect True-to-False. Indicates whether the mic level detector transitions from True to False. | | | | No transition detected Transition from True to False detected | | 6 | DETECT_FALSE_TRUE | Mic detect False-to-True. Indicates whether the mic level detector transitions from False to True. | | | | No transition detected Transition from False to True detected | | 5:3 | _ | Reserved | | 2 | HSBIAS_HIZ | HSBIAS Hi-Z engaged. | | | | 0 Not engaged<br>1 Engaged | | 1 | SHORT_RELEASE | Short release. Indicates whether the S0 button-detect block output a low-to-high edge on the version of the short condition indicator that is sent to the control port. This status is debounced as per DEBOUNCE_TIME in Normal Mode. | | | | If M_SHORT_RELEASE = 0, a shadow register captures up to two button-press events. Reading the register once transfers shadow register contents into this register, therefore, the register can be read twice per interrupt event. Shadow bits are not available in Wake Mode (only VP present). This bit is affected by EVENT_STATUS_SEL (see p. 156). | | | | 0 HSBIAS_IN has not transitioned above the short detect threshold. 1 HSBIAS_IN transitioned above the short detect threshold. | | 0 | SHORT_DETECTED | Short detected. Indicates whether a high-to-low edge occurred on the version of the short condition indicator, sourced by the S0 button-detect block output, that is sent to the control port. Status is debounced per DEBOUNCE_TIME in Normal Mode. This bit is affected by EVENT_STATUS_SEL (see p. 156). | | | | HSBIAS_IN has not transitioned below the short-detect threshold. HSBIAS_IN transitioned below the short-detect threshold. | <sup>1.</sup> This bit is active only if DETECT\_MODE (see p. 155) is set so the short-detection circuit is active. If the system is configured for standby operation, the sticky version of this bit (which accounts for events that occurred during standby) can be read back after a wake event. Use EVENT\_STATUS\_ SEL to retrieve this bit's information under that scenario. # 7.6.9 SRC Partial Lock Interrupt Status Address 0x130B | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|----------|----------|---|---|--------|---|--------| | | _ | DAC_UNLK | ADC_UNLK | _ | _ | DAC_LK | _ | ADC_LK | | Default | Х | Х | Х | х | х | Х | Х | х | | Bits | Name | Description | |------|----------|-------------------------------------| | 7 | _ | Reserved | | 6 | DAC_UNLK | ASP input SRC unlock status. | | | | 0 Locked<br>1 Unlocked | | 5 | ADC_UNLK | ASP output SRC unlock status. | | | | 0 Locked<br>1 Unlocked | | 4:3 | _ | Reserved | | 2 | DAC_LK | ASP input partial SRC lock status. | | | | 0 Unlocked<br>1 Locked | | 1 | _ | Reserved | | 0 | ADC_LK | ASP output partial SRC lock status. | | | | 0 Unlocked<br>1 Locked | # 7.6.10 VP Monitor Interrupt Status | ٨A | dress | Nv1 | 301 | |----|-------|-----|-----| | | | | | | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|------------| | | | | | _ | | | | VPMON_TRIP | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Х | | Bits | Name | Description | |------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------| | 7:1 | _ | Reserved | | 0 | VPMON_TRIP VP monitor interrupt. If the VP power supply falls below 2.6 V, this bit is set. See Section 4.15.1 for details. | | | | | 0 No interrupt 1 Interrupt detected | # 7.6.11 PLL Lock Interrupt Status #### Address 0x130E | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|----------| | | | | | _ | | | | PLL_LOCK | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | х | | Bits | Name | Description | |------|----------|------------------------------------------------| | 7:1 | _ | Reserved | | 0 | PLL_LOCK | PLL lock. Indicates the lock state of the PLL. | | | | 0 No interrupt<br>1 Interrupt detected | # 7.6.12 Tip/Ring Sense Plug/Unplug Interrupt Status #### Address 0x130F | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|-----------|---------|-----------|---------| | | | _ | _ | | TS_UNPLUG | TS_PLUG | RS_UNPLUG | RS_PLUG | | Default | 0 | 0 | 0 | 0 | х | Х | Х | Х | | Bits | Name | Description | |------|-----------|------------------------------------------------------------------------------------------------------------| | 7:4 | _ | Reserved | | 3 | TS_UNPLUG | Tip sense unplug status. See Section 4.14.4 for details. Setting TS_INV reverses the meaning of this bit. | | | | Condition is not present. Condition is present. | | 2 | TS_PLUG | Tip sense plug status. See Section 4.14.4 for details. Setting TS_INV reverses the meaning of this bit. | | | | Condition is not present. Condition is present. | | 1 | RS_UNPLUG | Ring sense unplug status. See Section 4.14.4 for details. Setting RS_INV reverses the meaning of this bit. | | | | Condition is not present. Condition is present. | | 0 | RS_PLUG | Ring sense plug status. See Section 4.14.4 for details. Setting RS_INV reverses the meaning of this bit. | | | | Condition is not present. Condition is present. | # 7.6.13 ADC Overflow Interrupt Mask | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|------------| | | | | | _ | | | | M_ADC_OVFL | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Bits | Name | Description | |------|----------------|---------------------------| | 7:1 | _ | Reserved | | 0 | M_ADC_<br>OVFL | ADC_OVFL mask. 0 Unmasked | | | | 1 (Default) Masked | # 7.6.14 Mixer Interrupt Mask #### Address 0x1317 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|----------------------|-----------|----------------|----------------| | | | _ | - | | M_EQ_<br>BIQUAD_OVFL | M_EQ_OVFL | M_MIX_CHA_OVFL | M_MIX_CHB_OVFL | | Default | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | Bits | Name | Description | |------|------------------|----------------------------------| | 7:4 | _ | Reserved | | 3 | M_EQ_BIQUAD_OVFL | EQ_BIQUAD_OVFL mask. | | | | 0 Unmasked<br>1 (Default) Masked | | 2 | M_EQ_OVFL | EQ_OVFL mask. | | | | 0 Unmasked<br>1 (Default) Masked | | 1 | M_MIX_CHA_OVFL | MIXER_CHx_OVFL mask. | | 0 | M_MIX_CHB_OVFL | 0 Unmasked<br>1 (Default) Masked | # 7.6.15 SRC Interrupt Mask #### Address 0x1318 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|-------------|-------------|-----------|-----------| | | | _ | _ | | M_SRC_OUNLK | M_SRC_IUNLK | M_SRC_OLK | M_SRC_ILK | | Default | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | Bits | Name | Description | |------|-----------|----------------------------------| | 7:4 | _ | Reserved | | 3 | M_SRC_ | SRC_OUNLK mask. | | | OUNLK | 0 Unmasked<br>1 (Default) Masked | | 2 | M_SRC_ | SRC_IUNLK mask. | | | IUNLK | 0 Unmasked<br>1 (Default) Masked | | 1 | M_SRC_OLK | SRC_OLK mask. | | | | 0 Unmasked<br>1 (Default) Masked | | 0 | M_SRC_ILK | SRC_ILK mask. | | | | 0 Unmasked<br>1 (Default) Masked | # 7.6.16 ASP RX Interrupt Mask | Add | Iress | 0x1 | 319 | ۱ | |-----|-------|-----|-----|---| |-----|-------|-----|-----|---| | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|--------------|---------------|--------------|---------------|----------------| | | | _ | | M_ASPRX_OVLD | M_ASPRX_ERROR | M_ASPRX_LATE | M_ASPRX_EARLY | M_ASPRX_NOLRCK | | Default | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | | Bits | Name | Description | |------|----------|----------------------------------| | 7:5 | | Reserved | | 4 | M_ASPRX_ | ASPRX_OVFL mask. | | | OVLD | 0 Unmasked<br>1 (Default) Masked | | 3 | M_ASPRX_ | ASPRX_ERROR mask. | | | ERROR | 0 Unmasked<br>1 (Default) Masked | | 2 | M_ASPRX_ | ASPRX_LATE mask. | | | LATE | 0 Unmasked<br>1 (Default) Masked | | 1 | M_ASPRX_ | ASPRX_EARLY mask. | | | EARLY | 0 Unmasked<br>1 (Default) Masked | | 0 | M_ASPRX_ | ASPRX_NOLRCK mask. | | | NOLRCK | 0 Unmasked<br>1 (Default) Masked | # 7.6.17 ASP TX Interrupt Mask #### Address 0x131A | R/W | V 7 6 5 4 | | 3 | 2 | 1 | 0 | | | |---------|-----------|---|---|---|-----------------|--------------|---------------|----------------| | | | _ | - | | M_ASPTX_SMERROR | M_ASPTX_LATE | M_ASPTX_EARLY | M_ASPTX_NOLRCK | | Default | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | Bits | Name | Description | |------|----------|----------------------------------| | 7:4 | _ | Reserved | | 3 | M_ASPTX_ | ASPTX_SMERROR mask. | | | SMERROR | 0 Unmasked<br>1 (Default) Masked | | 2 | M_ASPTX_ | ASPTX_LATE mask. | | | LATE | 0 Unmasked<br>1 (Default) Masked | | 1 | M_ASPTX_ | ASPTX_EARLY mask. | | | EARLY | 0 Unmasked<br>1 (Default) Masked | | 0 | M_ASPTX_ | ASPTX_NOLRCK mask. | | | NOLRCK | 0 Unmasked<br>1 (Default) Masked | # 7.6.18 Codec Interrupt Mask ### Address 0x131B | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|-------------------|------------| | | | | _ | _ | | | M_HSDET_AUTO_DONE | M_PDN_DONE | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | Bits | Name | Description | |------|-----------|----------------------------------| | 7:2 | _ | Reserved | | 1 | | HSDET_AUTO_DONE mask. | | | AUTO_DONE | 0 Unmasked<br>1 (Default) Masked | | 0 | | PDN_DONE mask. | | | DONE | 0 Unmasked<br>1 (Default) Masked | # 7.6.19 SRC Partial Lock Interrupt Mask #### Address 0x131C | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|------------|------------|---|---|----------|---|----------| | | _ | M_DAC_UNLK | M_ADC_UNLK | _ | _ | M_DAC_LK | _ | M_ADC_LK | | Default | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Bits | Name | Description | |------|----------------|----------------------------------| | 7 | _ | Reserved | | 6 | M_DAC_<br>UNLK | ASP input unlock mask. | | | | 0 Unmasked<br>1 (Default) Masked | | 5 | M_ADC_<br>UNLK | ASP output unlock mask. | | | UNLK | 0 Unmasked<br>1 (Default) Masked | | 4–3 | _ | Reserved | | 2 | M_DAC_LK | ASP input lock mask. | | | | 0 Unmasked<br>1 (Default) Masked | | 1 | _ | Reserved | | 0 | M_ADC_LK | ASP output lock mask. | | | | 0 Unmasked<br>1 (Default) Masked | # 7.6.20 VP Monitor Interrupt Mask #### Address 0x131E | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|--------------| | | | | | _ | | | | M_VPMON_TRIP | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Bits | Name | Description | |------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | M_<br>VPMON_<br>TRIP | <ul> <li>VP monitor mask.</li> <li>0 Unmasked. Unmask/enable this bit only when VP exceeds the detection voltage threshold; applicable to power-up conditions or if VP is not at its steady-state voltage.</li> <li>1 (Default) Masked</li> </ul> | ### 7.6.21 PLL Lock Mask #### Address 0x131F | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|------------| | | | | | _ | • | | | M_PLL_LOCK | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Name | Description | |------|----------------------------------| | _ | Reserved | | | PLL lock mask. | | LOCK | 0 Unmasked<br>1 (Default) Masked | | | _ | # 7.6.22 Tip/Ring Sense Plug/Unplug Interrupt Mask #### Address 0x1320 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|-------------|-----------|-------------|-----------| | | | _ | - | | M_TS_UNPLUG | M_TS_PLUG | M_RS_UNPLUG | M_RS_PLUG | | Default | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | Bits | Name | Description | |------|--------|----------------------------------| | 7:4 | _ | Reserved | | 3 | M_TS_ | Tip sense unplug mask. | | | UNPLUG | 0 Unmasked<br>1 (Default) Masked | | 2 | M_TS_ | Tip sense plug mask. | | | PLUG | 0 Unmasked<br>1 (Default) Masked | | 1:0 | _ | Reserved | | 1 | M_RS_ | Ring sense unplug mask. | | | UNPLUG | 0 Unmasked<br>1 (Default) Masked | | 0 | M_RS_ | Ring sense plug mask. | | | PLUG | 0 Unmasked<br>1 (Default) Masked | # 7.7 Fractional-N PLL Registers ### 7.7.1 PLL Control 1 | <b>Address</b> | 0x150° | |----------------|--------| |----------------|--------| | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|----------|---|---|---|-----------| | | | | | <u> </u> | | | | PLL_START | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits | Name | Description | |---|------|-------|-----------------------------------------------------------------------------------------------------------------------| | | 7:1 | _ | Reserved | | ſ | 0 | PLL_ | PLL start. If MCLK_SRC_SEL = 0, the PLL is bypassed and can be powered down by clearing PLL_START. See Section 4.7.3. | | | | START | 0 (Default) Powered off.<br>1 Powered on | | 1 | | | | | |--------------------|--|--|--|--| | | | | | | | | | | | | | PLL_DIV_FRAC[15:8] | | | | | | | | | | | | | | | | | | 0 | | | | | | Bits | Name | Description | |------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 7:0 | | PLL fractional portion of divide ratio LSB. See Section 4.7.3 for details. There are 3 bytes of PLL feedback divider fraction | | | FRAC[7:0] | portion: This is LSB byte; e.g., 0xFF means (2 <sup>-17</sup> + 2 <sup>-18</sup> ++2 <sup>-24</sup> ) | | | | 0000 0000 (Default) | | 7:0 | PLL_DIV_ | PLL fractional portion of divide ratio middle byte; e.g., $0xFF$ means $(2^{-9} + 2^{-10} + + 2^{-16})$ . See Section 4.7.3 for details. | | | FRAC[15:8] | 0000 0000 (Default) | | 7:0 | | PLL fractional portion of divide ratio MSB; e.g., 0xFF means (2 <sup>-1</sup> + 2 <sup>-2</sup> ++2 <sup>-8</sup> ). See Section 4.7.3 for details. | | | FRAC[23:16] | 0000 0000 (Default) | # 7.7.3 PLL Division Integer Address 0x1505 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|-------|--------|---|---|---| | | | | | PLL_D | IV_INT | | | | | Default | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | E | Bits | Name | | | | | | | |---|------|-------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 7 | 7:0 | PLL_DIV_INT | PLL integer portion of divide ratio. Integer portion of PLL feedback divider. See Section 4.7.3 for details. | | | | | | | | | | 0100 0000 (Default) | | | | | | # 7.7.4 PLL Control 3 Address 0x1508 | | _ | | | | | | | | |---------|---|---|---|-------|-------|---|---|---| | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | PLL_D | IVOUT | | | | | Default | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|--------|-----------------------------------------------------------------------------------| | 7:0 | PLL_ | Final PLL clock output divide value. See Section 4.7.3 for configuration details. | | | DIVOUT | 0001 0000 (Default) | ### 7.7.5 PLL Calibration Ratio Address 0x150A | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---------|---------|---|---|---| | | | | | PLL_CAI | L_RATIO | | | | | Default | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|----------|-----------------------------------------------------------------------------------------------------------| | 7:0 | PLL_CAL_ | PLL calibration ratio. See Section 4.7.3 for configuration details. Target value for PLL VCO calibration. | | | RATIO | 1000 0000 (Default) | ### 7.7.6 PLL Control 4 Address 0x151B | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|-------|------| | | | | _ | _ | | | PLL_N | MODE | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | Bits | Name | Description | | | | | | |------|------|-----------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 7:2 | _ | Reserved | | | | | | | 1:0 | PLL_ | PLL bypass mode. Configures 500/512 and 1029/1024 factor bypasses. See Section 4.7.3 for configuration details. | | | | | | | | MODE | 00 Unsupported 10 1029/1024 only (500/512 bypassed) | | | | | | | | | 01 500/512 only (1029/1024 bypassed) 11 (Default) Both bypassed | | | | | | # 7.8 HP Load-Detect Registers ### 7.8.1 Load-Detect R/C Status Address 0x1925 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|----------|---|---|------|------| | | | _ | | CLA_STAT | - | _ | RLA_ | STAT | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Name Description | | | | |------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 7:6 | _ | — Reserved | | | | | 4 | CLA_STAT Capacitor load-detection result for HPA. See Section 4.4.4 for details. Note: Low capacitance results were determined with $C_L = 1$ nF; high capacitance results were determined with $C_L = 10$ nF. 0 (Default) High capacitance ( $C_L \ge -2$ nF) 1 Low capacitance ( $C_L < -2$ nF) | | | | | | 1:0 | RLA_STAT | RLA_STAT Resistor load-detection result for HPA. See Section 4.4.4 for details. 00 (Default) 15 $\Omega$ 10 3 k $\Omega$ 11 Reserved | | | | ### 7.8.2 HP Load Detect Done Address 0x1926 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|-----------------| | | | | | _ | | | | HPLOAD_DET_DONE | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Γ | Bits | Name | Description | |---|------|----------|------------------------------------------------------------------------------------------------------| | Γ | 7:1 | _ | Reserved | | | 0 | _ | HP load detect done. Indicates whether HP load detection is finished. See Section 4.4.4 for details. | | | | DET_DONE | 0 (Default) HP load is not finished.<br>1 HP load is finished. | ### 7.8.3 HP Load Detect Enable Address 0x1927 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|----------| | | | | | _ | | | | HP_LD_EN | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|----------|---------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | HP_LD_EN | HP load detect enable. A 0-to-1 bit transition initiates load detection. See Section 4.4.4 for details. | | | | 0 (Default) Disabled 1 Enabled | # 7.9 Headset Interface Registers ### 7.9.1 HSBIAS Sense and Hi-Z Autocontrol | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-----------------|-----------------|--------------|---|---|---|-------------------|---| | | HSBIAS_SENSE_EN | AUTO_HSBIAS_HIZ | TIP_SENSE_EN | _ | _ | | HSBIAS_SENSE_TRIP | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | Bits | Name | Description | |------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | | HSBIAS current sense enable. Configures HSBIAS output current sense through the external 2.21-kΩ resistor. | | | SENSE_<br>EN | O (Default) Disabled. Must be disabled in Short Detect-Only Mode when the headset circuit disconnects the mic module. Due to the open circuit, HSBIAS_SENSE = 1 if the S0 button is not being pressed. The current sense trip point is set via HSBIAS_SENSE_TRIP. An interrupt can be configured to occur when the sensed current falls below the trip point. 1 Enabled | | 6 | AUTO_<br>HSBIAS_ | HSBIAS Hi-Z autocontrol. Sets how the Hi-Z Mode on the HSBIAS output is controlled. This bit is affected by LATCH_TO_ VP (see p. 155). | | | HIZ | 0 (Default) No change to HSBIAS output. The Hi-Z Mode is also cleared if it had been previously set. 1 Sets HSBIAS to Hi-Z Mode when the current sense goes below its trip point or a HP unplug event occurs, depending on which detector is enabled. To disengage Hi-Z Mode, clear this bit before resetting it to 1. | | Bits | Name | Description | | | | | | | | | |------|--------|---------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|--------------------------|----------------------------------------------|--|--|--|--|--| | 5 | TIP_ | Fip sense enable. Updatable only if LATCH_TO_VP is enabled. If AUTO_HSBIAS_HIZ = 1, a tip sense unplug event can be | | | | | | | | | | | SENSE_ | configured to affect its control. | | | | | | | | | | | EN | 0 (Default) TIP_SENSE unplug | 0 (Default) TIP SENSE unplug event does not affect the HSBIAS. | | | | | | | | | | | 1 TIP_SENSE unplug event affe | 1 TIP_SENSE unplug event affects the HSBIAS Hi-Z Mode if AUTO_HSBIAS_HIZ = 1. | | | | | | | | | 4:3 | | Reserved | | | | | | | | | | 2:0 | HSBIAS | HSBIAS current sense trip point. Set | s the HSBIAS current trip po | int sensed across the ex | xternal 2.21-kΩ bias resistor. Current sense | | | | | | | | SENSE | trip point in Table 3-15 lists tolerances for these values. | | | | | | | | | | | TRIP | 000 12 μA 0 | 10 41 μA | 100 64 µA | 110 93 µA | | | | | | | | | 001 23 µA 0 | 11 (Default) 52 μA | 101 75 μA | 111 104 μA | | | | | | ### 7.9.2 Wake Control Address 0x1B71 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|------------|-----------|------------|---|---|---|---|-------------| | | M_MIC_WAKE | M_HP_WAKE | WAKEB_MODE | | - | _ | | WAKEB_CLEAR | | Default | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | | Mask mic button detect wake. <sup>1,2</sup> Configures the mask for the mic-button detect wake status. | | | WAKE | 0 Unmasked. The occurrence of a wake interrupt affects WAKE. 1 (Default) Masked. The occurrence of a wake interrupt does not affect WAKE. | | 6 | M_HP_ | Mask tip sense wake. 1,2 Configures the mask for the tip-sense wake status. | | | WAKE | O Unmasked. The occurrence of a wake interrupt affects WAKE. 1 (Default) Masked. The occurrence of a wake interrupt does not affect WAKE. | | 5 | WAKEB_<br>MODE | WAKE output mode.¹ Configures the mode of operation for the WAKE output 0 (Default) Output is latched low after a trigger event until WAKEB_CLEAR is toggled. 1 Output follows the combination logic directly (nonlatched). | | 4:1 | _ | Reserved | | 0 | WAKEB_ | WAKE output clear. Applicable only if WAKEB_MODE = 0 and an event triggers the WAKE output to latch low. | | | CLEAR | 0 (Default) WAKE output normal operation. If WAKEB_MODE = 1, WAKEB_CLEAR does not deassert WAKE, but clears TIP_SENSE_PLUG, TIP_SENSE_UNPLUG, SHORT_DETECTED, SHORT_RELEASE in the VP domain. 1 WAKE output deasserted (the TIP_SENSE_PLUG, TIP_SENSE_UNPLUG, SHORT_DETECTED, SHORT_RELEASE bits in the VP domain are also cleared). | <sup>1.</sup> This bit can be changed only if LATCH\_TO\_VP is enabled (see p. 155). ### 7.9.3 ADC Disable Mute | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------------------|---|---|---|---|---|---|---| | | ADC_DISABLE_S0_MUTE | | | | _ | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | ADC_ | Disable ADC automute on S0 button press. For S0 automute to operate, DETECT_MODE must be set to 11. | | | DISABLE_S0_<br>MUTE | 0 (Default) Enabled. If HSBIAS_IN goes below the S0 threshold, ADC mutes. If DETECT_MODE = 11 and the HSBIAS_IN pin is floating, the ADC path could be muted due to the pin floating below the S0 trip threshold. 1 Disabled | | 6:0 | _ | Reserved | # 7.9.4 Tip Sense Control 2 | Address | 0x1 | <b>B73</b> | |---------|-----|------------| |---------|-----|------------| | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|----------------|---|---------------|--------------|---|---|--------------------|---| | | TIP_SENSE_CTRL | | TIP_SENSE_INV | <del>-</del> | | | TIP_SENSE_DEBOUNCE | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | Bits | Name | Description | |------|------|----------------------------------------------------------------------------------------------------------------| | 7:6 | | Tip sense control.Configures operation of the tip-sense circuit. | | | CTRL | Note: This bit can be updated only if LATCH_TO_VP (see p. 155) is enabled. | | | | 00 (Default) Disabled. The tip-sense circuit is powered down and does not report to the status registers (TIP_ | | | | SENSE_PLUG and TIP_SENSE_UNPLUG in the VP domain are also cleared). | | | | 01 Digital input. Internal weak current source pull-up is disabled. | | | | 10 Reserved | | | | 11 Short detect. Internal weak current source pull-up is enabled. | <sup>2.</sup> Before unmasking status, pending wake events must be cleared via WAKEB\_CLEAR. They are also cleared when deactivating and then reactivating the relevant mode using DETECT\_MODE (see p. 155). A powered-down device using the CS42L42 does not respond to the associated detect wake event. | Bits | Name | Description | | | | | | | |------|------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 5 | TIP_SENSE_ | o sense invert. Used to invert the signal from the tip-sense circuit. Updatable only if LATCH_TO_VP is enabled. | | | | | | | | | INV | 0 (Default) Not inverted 1 Inverted | | | | | | | | 4:2 | _ | Reserved | | | | | | | | 1:0 | TIP_SENSE_ | Tip sense debounce time. Sets tip sense unplug event (TIP_SENSE = 0) debounce time before status is reported. | | | | | | | | | DEBOUNCE | mings are approximate and vary with MCLK <sub>INT</sub> and Fs <sub>INT</sub> . | | | | | | | | | | 00 No debounce | | | | | | | ### 7.9.5 Miscellaneous Detect Control #### Address 0x1B74 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|--------|--------|--------|--------|------------------------| | | _ | | | DETECT | r_MODE | HSBIAS | S_CTRL | PDN_MIC_LVL_<br>DETECT | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | Bits | Name | Description | |------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:5 | | Reserved | | 4:3 | DETECT_<br>MODE | Detection mode setting. Sets the appropriate mode to be used for the mic button detection. This bit is affected by LATCH_TO_VP (see p. 155). | | | | 00 (Default) Inactive (SHORT_DETECTED and SHORT_RELEASE in the VP domain are also cleared) 01 Short detect only. Normal interrupts do not function; the INT pin follows the S0 comparator directly while the SHORT_DETECTED mask is cleared and remains high while the SHORT_DETECTED mask is set. 10 Reserved | | | | 11 Normal Mode. HSBIAS output uses a high-performance reference for 2.0- or 2.7-V Mode. See HSBIAS_CTRL. If LATCH_TO_VP = 1, PDN_ALL = 1 overrides DETECT_MODE setting and powers down the CS42L42. | | 2:1 | HSBIAS_ | HS bias output control. Sets the mode for the HSBIAS output pin. See the DETECT_MODE description, above. | | | CTRL | 00 Output is Hi-Z. The HSBIAS output uses a low-performance, low-power reference. If the HSBIAS-to-HS4 switch is closed (SW_HSB_HS4 = 1), the HS4 pin can float unless terminated with a load of at least 100 kΩ. 01 (Default) 0.0 V (weak ground, see Table 3-14, Footnote 1). 10 2.0 V. Wait for circuits to completely power up. A setting of 10 or 11 is required for headset interface functionality. 11 2.7 V. Wait for circuits to completely power up. A setting of 10 or 11 is required for headset interface functionality. Note: If DETECT_MODE = 11, the HSBIAS output uses a high-performance reference. If DETECT_MODE ≠ 11, the HSBIAS output uses a low-performance, low-power reference. • To avoid audible artifacts if the HS path is active, the path must be muted before changing the HSBIAS settings. • LATCH_TO_VP = 1, PDN_ALL = 1 overrides HSBIAS_CTRL settings and powers down the CS42L42. • Table 3-15 more precisely specifies voltages present on the HSBIAS output for each HSBIAS_CTRL setting, accounting for the effect of DETECT_MODE. It also documents HS bias power-up time. | | 0 | PDN_MIC_<br>LVL_<br>DETECT | Power-down mic DC level detect. Configures the power state of the mic-level detect circuit. 0 Powered up. See Table 3-14 for the level detect power-up time. 1 (Default) Powered down This feature can be used at any time (set in parallel with any other detection mode), but should not be continuously enabled | | | | if the HS input is enabled because the HS noise performance is degraded. | <sup>1.</sup> This bit can be updated only if LATCH\_TO\_VP is enabled. ### 7.9.6 Mic Detect Control 1 | _ | | | - | | | |----|-----|-----|-----|----|----| | Δ, | 4dr | ess | Nv1 | IR | 75 | | | | | | | | | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-------------|------------------|---|---|---------|----------|---|---| | L | LATCH_TO_VP | EVENT_STATUS_SEL | | | HS_DETE | CT_LEVEL | | | | Default | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | | Bits | Name | Description | | | | | | |------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 7 | LATCH_<br>TO_VP | atch to VP registers. Controls the transfer of writable control registers in the VD_FILT supply domain to duplicate registers in the VP supply domain. Can be used to enable setting sticky status bits in the VP domain. | | | | | | | | | O (Default) Inhibits the transfer of VD_FILT registers to VP registers (latched mode). Enables the setting of VP sticky status latches. Transfers VD_FILT fields to VP fields (transparent mode). Disables setting of VP sticky status latches. Affected registers: | | | | | | | | | <ul> <li>DETECT_MODE on p. 155</li> <li>TIP_SENSE_EN on p. 154</li> <li>M_HP_WAKE on p. 154</li> <li>M_SHORT_DETECTED on p. 157</li> <li>HSBIAS_CTRL on p. 155</li> <li>SW_REF_HSx on p. 140</li> <li>SW_HSB_FILT_HSx on p. 140</li> </ul> | | | | | | | | | Note: The description of PDN ALL on p. 136 describes the interdependency between LATCH TO VP and PDN ALL | | | | | | | Bits | Name | Description | | | | | | |------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 6 | EVENT_ | Event status selection. Selects the level of processing on readable status originating in the VP supply domain. | | | | | | | | STATUS_<br>SEL | (Default) Raw (unprocessed) status events are selected. Sticky processed status events are selected. Affected registers: | | | | | | | | | <ul> <li>TIP_SENSE_PLUG on p. 146</li> <li>SHORT_DETECTED on p. 147</li> <li>SHORT_RELEASE on p. 147</li> </ul> | | | | | | | 5:0 | HS_ | Mic 2 voltage level-detect setting (% of HSBIAS). Sets the level of the threshold to be used for detecting headset modules. | | | | | | | | DETECT_<br>LEVEL | 01 1111 (Default) The DC detector can be used at any time (set in parallel with any other detection mode), but should not be continuously enabled if the HS input is enabled because the HS noise performance is degraded. DC detector settling time is 11 ms. | | | | | | ### 7.9.7 Mic Detect Control 2 Address 0x1B76 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---------------|---|---|---|---|---|---| | | | DEBOUNCE_TIME | | | | _ | | | | Default | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | Bits | Name | Description | | | | | | |------|-----------|-------------------------|-----------------------------------------------------------------------------------------------------|-----------|-----------|--|--| | 7:5 | DEBOUNCE_ | Debounce time (ms). Set | ebounce time (ms). Sets the time to be used for S0 button detect (SHORT_DETECTED and SHORT_RELEASE) | | | | | | | TIME | debounce when in Norma | ebounce when in Normal Mode. Timings are approximate and vary with MCLK <sub>INT</sub> . | | | | | | | | 000 10 ms | 010 30 ms | 100 50 ms | 110 70 ms | | | | | | 001 (Default) 20 ms | 011 40 ms | 101 60 ms | 111 80 ms | | | | 4:0 | _ | Reserved | | | | | | # 7.9.8 Detect Status 1 Address 0x1B77 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-----------|------------|---|---|---|---|---|---| | | TIP_SENSE | HSBIAS_HIZ | | | _ | _ | | | | Default | Х | Х | 0 | Х | Х | х | х | х | | Bits | Name | Description | |------|------------|--------------------------------------------------------------------------------------------------------------------------------| | 7 | TIP_SENSE | TIP_SENSE circuit status. The plug-to-unplug edge is debounced for the set debounce time (see TIP_SENSE_<br>DEBOUNCE, p. 155). | | | | 0 HP not plugged in<br>1 HP plugged in | | 6 | HSBIAS_HIZ | HSBIAS Hi-Z Mode. Reports whether the HSBIAS Hi-Z Mode is enabled or disabled. | | | | 0 Hi-Z Mode is disabled.<br>1 Hi-Z Mode is enabled. | | 5:0 | | Reserved | ### 7.9.9 Detect Status 2 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---------|------------| | | | | | _ | | | HS_TRUE | SHORT_TRUE | | Default | Х | Х | Х | Х | 0 | Х | Х | Х | | Bits | Name | Description | |------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1 | HS_TRUE | HS true. Reports whether voltage detected on HSBIAS_IN drops below the HS_DETECT_LEVEL threshold. | | | | False. HSBIAS_IN is above the specified threshold. True. HSBIAS_IN is below the specified threshold. | | 0 | TRUE _ | Short true. Reports whether the voltage detected on HSBIAS_IN is below the S0 threshold. Valid only if DETECT_MODE = Normal Mode. Table 3-20 specified the threshold as "Short-Detect Threshold (S0 Button)." DEBOUNCE_TIME does not affect this bit, because its source is not debounced. 0 False. HSBIAS_IN is above the S0 threshold 1 True. HSBIAS_IN is below the S0 threshold | # 7.9.10 Detect Interrupt Mask 1 Address 0x1B79 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|----------------|------------------|--------------------|---|---|---|---|---|--| | | M_HSBIAS_SENSE | M_TIP_SENSE_PLUG | M_TIP_SENSE_UNPLUG | | | _ | | | | | Default | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | Interrupt mask register bits serve as a mask for the interrupt sources in the interrupt status registers. Interrupts are described in Section 4.18. | Bits | Name | Description | |------|--------|-----------------------| | 7 | | HSBIAS_SENSE mask | | | SENSE | 0 Unmasked | | | | 1 (Default) Masked | | 6 | | TIP_SENSE_PLUG mask | | | SENSE_ | 0 Unmasked | | | PLUG | 1 (Default) Masked | | 5 | | TIP_SENSE_UNPLUG mask | | | SENSE_ | 0 Unmasked | | | UNPLUG | 1 (Default) Masked | | 4:0 | _ | Reserved | # 7.9.11 Detect Interrupt Mask 2 Address 0x1B7A | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-------------------------|-------------------------|---|---|---|--------------|---------------------|----------------------| | | M_DETECT_<br>TRUE_FALSE | M_DETECT_<br>FALSE_TRUE | | _ | | M_HSBIAS_HIZ | M_SHORT_<br>RELEASE | M_SHORT_<br>DETECTED | | Default | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Interrupt mask register bits serve as a mask for the interrupt sources in the interrupt status registers. Interrupts are described in Section 4.18. | Bits | Name | Description | |------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | M_DETECT_ | DETECT_TRUE_FALSE mask | | | TRUE_ | 0 Unmasked | | | FALSE | 1 (Default) Masked | | 6 | | DETECT_FALSE_TRUE mask | | | FALSE_ | 0 Unmasked | | | TRUE | 1 (Default) Masked | | 5:2 | _ | Reserved | | 2 | M_HSBIAS_ | HSBIAS_HIZ mask | | | HIZ | 0 Unmasked | | | | 1 (Default) Masked | | 1 | | SHORT_RELEASE mask. A shadow register for this bit captures up to two button-press events. Reading the register once transfers the contents of the shadow register into this one; therefore, it can be read twice per interrupt event. Shadow bits are not available in Wake Mode (only VP present). | | | | 0 Unmasked<br>1 (Default) Masked | | 0 | | SHORT_DETECTED mask. This bit is affected by LATCH_TO_VP (see p. 155). | | | DETECTED | 0 Unmasked | | | | 1 (Default) Masked | # 7.10 Headset Bias Registers ### 7.10.1 Headset Bias Control | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-------------------|---|---|---|---|---|-------------|---| | | HSBIAS_CAPLESS_EN | - | _ | | _ | | HSBIAS_RAMP | | | Default | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | | Bits | Name | Description | |------|----------------|--------------------------------------------------------------------------------------------------------------------| | 7 | HSBIAS_ | HSBIAS capless enable. Indicates whether there is a capacitive load on HS bias output. | | | CAPLESS_<br>EN | External capacitor present (Default) No external capacitor (Default because there is no pin on HS bias output) | | 6:5 | _ | Reserved | | Bits | Name | Description | | | | | | |------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 4 | HSBIAS_ | HSBIAS pull down. Used to enable a $60$ -k $\Omega$ pulldown on HS bias. | | | | | | | | PD | 0 (Default) Pulldown resistor off<br>1 Pulldown resistor on | | | | | | | 3:2 | _ | Reserved | | | | | | | 1:0 | HSBIAS_ | HSBIAS ramp rate. Sets bidirectional output ramp rate between ground and set level. See Table 3-15 for specifications. | | | | | | | | RAMP | <b>Note:</b> After setting HSBIAS_RAMP and powering up the mic bias HSBIAS_CTRL (see p. 155), HSBIAS_RAMP cannot be changed until the ramp delay count is reached. Approximate ramp delay counts for HS_BIAS_RAMP = 00/01/10/11 are, respectively, 10/40/90/170 ms. After the ramp delay count, HS_TRUE and SHORT_TRUE (see p. 156) become valid. | | | | | | | | | 00 Fast rise time; slow, load-dependent fall time. 10 (Default) Slow 11 Slowest | | | | | | # 7.11 ADC Registers ## 7.11.1 ADC Control Address 0x1D01 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|-------------------|------------------------|---|---------|---|-------------------| | | | _ | ADC_NOTCH_<br>DIS | ADC_FORCE_<br>WEAK_VCM | _ | ADC_INV | _ | ADC_DIG_<br>BOOST | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|--------------------|--------------------------------------------------------------------------------------------------------| | 5 | ADC_ | ADC digital notch filter disable. Disables the digital notch filter on the ADC. | | | NOTCH_<br>DIS | 0 (Default) Enabled<br>1 Disabled | | 4 | ADC_ | ADC force analog input weak VCM. Controls the status of the weak VCM for the analog input. | | | FORCE_<br>WEAK_VCM | 0 (Default) Normal operation<br>1 Forced on | | 3 | _ | Reserved | | 2 | ADC_INV | ADC invert signal polarity. Configures the polarity of the ADC signal. See Section 4.13.1 for details. | | | | 0 (Default) Not inverted<br>1 Inverted | | 3 | _ | Reserved | | 0 | ADC_DIG_ | ADC digital boost. Configures a +20-dB digital boost on the ADC. See Section 4.1.3 for details. | | | BOOST | 0 (Default) No boost applied<br>1 +20-dB digital boost applied | # 7.11.2 ADC Soft-Ramp Enable Address 0x1D02 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---------------------|---|---| | | | | _ | | | ADC_<br>SOFTRAMP_EN | - | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | Bits | Name | Description | |------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------| | 7:3 | _ | Reserved | | 2 | ADC_<br>SOFTRAMP_<br>EN | ADC soft-ramp enable. Digital soft ramp enable bit for ADC. 0 (Default) Disabled 1 Enabled. The soft-ramp rate is set by DSR_RATE | | 1:0 | _ | Reserved | ## 7.11.3 ADC Volume | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---|---|---|---|---|---|---| | | ADC_VOL | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bi | s Name | Description | | | | | | | |----|---------------|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------|--|--------------------------|--|--|--| | 7: | O ADC_<br>VOL | ADC volume. ADC digital volume.<br>0111 1111–0000 1100 +12 dB<br>0000 1011 +11 dB | Sets the ADC signal volume<br>0000 0000 (Default) 0 dB<br>1111 1111 –1.0 dB | | 1001 1111–1000 0000 Mute | | | | # 7.11.4 ADC Wind-Noise Filter and HPF #### Address 0x1D04 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|------------|---|---|------------|--------|-------|------------| | | | ADC_WNF_CF | | | ADC_WNF_EN | ADC_HI | PF_CF | ADC_HPF_EN | | Default | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | | Bits | Name | Description | | | | |-----------------------------------------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 7 | _ | Reserved | | | | | 6:4 | _ | ADC wind-noise filter select. Sets the corner frequency for the wind-noise filter. See Section 4.1.2 for details. | | | | | | WNF_CF | 000–111 (Default = 111). See Table 3-11. | | | | | 3 | ADC_ | Enable ADC wind-noise filter. See Section 4.1.2 for details. | | | | | WNF_EN 0 (Default) Wind-noise filter disabled and bypassed. 1 Enabled | | | | | | | 2:1 | | HS ADC HPF corner frequency. Sets the corner frequency (–3 dB point) for the internal HPF. See Section 4.1 for details. Increasing the HPF corner frequency past the default setting can introduce up to ~0.3 dB of gain error in the passband. | | | | | | | 00 (Default) $3.88 \times 10^{-5}$ x Fs <sub>INT</sub> ( $1.86$ Hz at Fs <sub>INT</sub> = $48$ kHz) $10.4.9 \times 10^{-3}$ xFs <sub>INT</sub> ( $235$ Hz at Fs <sub>INT</sub> = $48$ kHz) | | | | | | | $01 \ 2.5 \text{x} 10^{-3} \text{x} \text{Fs}_{\text{INT}} (120 \ \text{Hz at Fs}_{\text{INT}} = 48 \ \text{kHz})$ $11 \ 9.7 \text{x} 10^{-3} \text{x} \text{Fs}_{\text{INT}} (466 \ \text{Hz at Fs}_{\text{INT}} = 48 \ \text{kHz})$ | | | | | 0 | ADC_<br>HPF_EN | HS ADC HPF enable. Configures the internal HPF after the HS ADC. Change only if the ADC is in a powered down state. See Section 4.1 for details. ADC_HPF_EN must remain asserted for proper functionality. Failure to do so may cause clipping of the ADC digital output. 0 Disabled. This must be cleared only for test purposes. 1 (Default) Enabled | | | | # 7.12 DAC Control Registers ### 7.12.1 DAC Control 1 | Address | 0x1F01 | |---------|--------| |---------|--------| | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|----------|----------| | | | | _ | _ | • | | DACB_INV | DACA_INV | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|----------|----------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1:0 | DACx_INV | DACx invert signal polarity. Configures the polarity of the DAC channel x signal. See Section 4.4 for details. | | | | 0 (Default) Not inverted | | | | 1 Inverted | ### 7.12.2 DAC Control 2 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---------|---------|---|------------|-------------|------------|---| | | | HPOUT_P | ULLDOWN | | HPOUT_LOAD | HPOUT_CLAMP | DAC_HPF_EN | _ | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | Bits | Name | Description | | | | | | | |------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 7:4 | | Although bits 2:0 are independent, the final resistance from the resistor string is dictated by the lowest resistance chosen; e.g., if HPOUT PULLDOWN = 1011, a nominal $6 \text{ k}\Omega$ pull-down resistance results even if $9.6 \text{ k}\Omega$ resistance is also selected. | | | | | | | | | | 0000 (Default) 0.9 kΩ 1000 No pulldown 1010 5.8 kΩ 1100 0.9 kΩ 0001–0111 0.9 kΩ 1001 9.3 kΩ 1011 Reserved 1101–1111 Reserved | | | | | | | | 3 | HPOUT_<br>LOAD | HP output load. Sets HP amplifier capacitive load capability. Table 3-13 gives output specifications. See Section 4.4 for details. | | | | | | | | | | 0 (Default) 1 nF Mode 1 10 nF Mode Note: The HP path must be powered down before reconfiguring this bit and repowered afterwards. See Section 4.4.4. | | | | | | | | 2 | HPOUT_ | HPOUT clamp. Configures an override of the HPOUT clamp to ground when the channels are powered down. | | | | | | | | | CLAMP | 0 (Default) Clamp to ground when channels are powered down. | | | | | | | | | | Clamp is disabled when the channels are powered down. The pulldown to GNDA depends on the HPOUT_ PULLDOWN setting. | | | | | | | | 1 | DAC_HPF_ | DAC high-pass filter enable. Configures the internal HPF before DAC. Changes to this bit must be made only if PDN_ | | | | | | | | | EN | ALL = 1. See Section 4.4 for details. | | | | | | | | | | 0 Disabled. This must be cleared only for test purposes. | | | | | | | | | | 1 (Default) Enabled. The corner frequency is set to 0.935 Hz when Fs <sub>INT</sub> = 48 kHz. | | | | | | | | 0 | _ | Reserved | | | | | | | # 7.13 HP Control Register # 7.13.1 HP Control Address 0x2001 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|------------|------------|----------------|---| | | | _ | _ | | ANA_MUTE_B | ANA_MUTE_A | FULL_SCALE_VOL | _ | | Default | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | | Bits | Name | Description | |------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:4 | _ | Reserved | | 3 | ANA_MUTE_ | Analog mute Channel B. See Section 4.4 for details. | | | В | 0 Unmuted<br>1 (Default) Muted | | 2 | ANA_MUTE_ | Analog mute Channel A. See Section 4.4 for details. | | | A | 0 Unmuted<br>1 (Default) Muted | | 1 | FULL_<br>SCALE_VOL | Full-scale volume. Determines the maximum volume for the headphone output. See Section 4.4 for details. 0 (Default) 0 dB 1 –6 dB. This setting is recommended if the load is approximately 15 Ω. | | 0 | _ | Reserved | # 7.14 Class H Register # 7.14.1 Class H Control | Address | 0x2101 | |---------|--------| |---------|--------| | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---------|---| | | | | _ | | | | ADPTPWR | | | Default | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | Bits | Name | Description | | | | | | |------|------|----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 7:3 | _ | Reserved | | | | | | | 2:0 | | Adaptive power adjustment. Configures how pow gives detailed descriptions of supported settings. | ver to HP output amplifiers adapts to the output signal level. Section 4.4 | | | | | | | | 000 Reserved 001 Fixed, Mode 0—VP_CP Mode (±2.5V) 010 Fixed, Mode 1—VCP Mode (±VCP) 011 Fixed, Mode 2 —VCP/2 Mode (±VCP/2) | <ul> <li>100 Fixed, Mode 3 —VCP/3 Mode (±VCP/3)</li> <li>101–110 Reserved</li> <li>111 (Default) Adapt to signal. The output signal dynamically determines the voltage level.</li> </ul> | | | | | # **7.15 Mixer** # 7.15.1 Mixer Channel A Input Volume | <b>Address</b> | 0x2301 | |----------------|--------| |----------------|--------| | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|---|---|---|---------------|---|---|---|---|--| | | | _ | | MIXER_CHA_VOL | | | | | | | Default | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | | E | Bits | Name | Description | | | | | | |---|------|--------|--------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | | 7:6 | _ | Reserved | | | | | | | 1 | 5:0 | MIXER_ | nput attenuation. Sets the attenuation level to be applied to various stereo digital inputs. See Section 4.2 for details. Each input | | | | | | | | | | can be muted or attenuated from –62 to 0 dB in 1-dB steps. | | | | | | | | | VOL | 00 0000 0 dB | | | | | | # 7.15.2 Mixer ADC Input Volume Address 0x2302 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---------|---------|---|---| | | | _ | | | MIXER_/ | ADC_VOL | | | | Default | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | Bits | Name | Description | |------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:6 | _ | Reserved | | 5:0 | | Mixer input attenuation. Sets the attenuation level to be applied to various stereo digital inputs. See Section 4.2 for details. Each mixer input can be muted or attenuated from –62 to 0 dB in 1-dB steps | | | VOL | 00 0000 0 dB 11 1110 –62.0 dB 00 0001 –1.0 dB 11 1111 (Default) Mute. If the SRC is enabled, the ASP outputs nonzero data until ASP_DAO_PDN is either toggled or set. | # 7.15.3 Mixer Channel B Input Volume Address 0x2303 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|---|---|---|---------------|---|---|---|---|--| | | | _ | | MIXER_CHB_VOL | | | | | | | Default | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | | Bits | Name | Description | |------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:6 | _ | Reserved | | 5:0 | | Input attenuation. Sets the attenuation level to be applied to various stereo digital inputs. See Section 4.2 for details. Each input can be muted or attenuated from –62 to 0 dB in 1-dB steps. | | | VOL | 00 0000 0 dB 11 1110 –62.0 dB 11 1111 (Default) Mute. If the SRC is enabled, the ASP outputs nonzero data until ASP_DAO_PDN is either toggled or set. | # 7.16 Equalizer # 7.16.1 Equalizer Filter Coefficient Input 0-3 Address 0x2401-0x2404 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-------------------|---|---|--------|-----------|---|---|---| | 0x2401 | | | | EQ_COE | F_IN[7:0] | | | | | 0x2402 | EQ_COEF_IN[15:8] | | | | | | | | | 0x2403 | EQ_COEF_IN[23:16] | | | | | | | | | 0x2404 | EQ_COEF_IN[31:24] | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:0 | _ | EQ coefficient input. Data to be written to the equalizer filter coefficient pointed to by the coefficient address pointer. See | | | _ | Section 4.3 for programming examples. | | | IN | Notes: | | | | With SoundWire, indirect-access procedures must be used for read/write of equalizer coefficients. | | | | EQ_COEF_IN[31:24] always returns zeros when read. | | | | • Filters are read by using EQ_COEF_OUT (see p. 162) and written by using EQ_COEF_IN. However, they must be accessed only as part of a full-filter access procedure; otherwise, the three-band filter may be corrupted and audio artifacts may occur. | | | | • Read/write access to EQ_COEF_IN[31:24] while the equalizer block is powered down may cause an APB timeout. | # 7.16.2 Equalizer Filter Coefficient Read/Write | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|----------|---------|---|---|---|---|---| | | | EQ_WRITE | EQ_READ | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1 | EQ_WRITE | EQ write. Enable write of the coefficients via EQ_COEF_IN. See Section 4.3 for programming examples. 0 (Default) Writes disabled. 1 Writes enabled. | | 0 | EQ_READ | EQ read. Enable read of the coefficients via EQ_COEF_OUT. See Section 4.3 for programming examples. 0 (Default) Reads disabled. 1 Reads enabled. | # 7.16.3 Equalizer Filter Coefficient Output 0–3 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|--------------------|---|---|----------|------------|---|---|---|--| | | EQ_COEF_OUT[7:0] | | | | | | | | | | | EQ_COEF_OUT[15:8] | | | | | | | | | | | EQ_COEF_OUT[23:16] | | | | | | | | | | | | | | EQ_COEF_ | OUT[31:24] | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits | Name | Description | | | | | | |------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 31:0 | COEF_ | EQ coefficient out. Coefficient read data from the equalizer. Data read from the equalizer filter coefficient pointed to by the coefficient address pointer. See Section 4.3 for programming examples. | | | | | | | | OUT | Filters are read by using EQ_COEF_OUT and written by using EQ_COEF_IN (see p. 161). However, they must be accessed only as part of a full-filter access procedure; otherwise, the three-band filter may be corrupted and audio artifacts may occur. | | | | | | | | | Notes: | | | | | | | | | With SoundWire, indirect procedures must be used for read/write of equalizer coefficients. | | | | | | | | | • Read/write access to EQ_COEF_OUT[7:0] while the equalizer block is powered down may cause an APB timeout. | | | | | | | | | • When reading this register via the I <sup>2</sup> C bus, EQ_PDN must be cleared and EQ_READ must be set. Otherwise, reading from this register may cause the SCL to be held low, hanging the I <sup>2</sup> C bus. See the notes after Ex. 4-1 in Section 4.3. | | | | | | # 7.16.4 Equalizer Initialization Status ### Address 0x240B | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|--------------| | | | | | _ | | | | EQ_INIT_DONE | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | В | its | Name | Description | |---|-----|---------------|----------------------------------------------------------------------------------------------------------------------------------| | 7 | :1 | _ | Reserved | | | ) | _ | Equalizer coefficient initialization done. Indicates whether initialization is complete. Section 4.3 gives programming examples. | | | | INIT_<br>DONE | (Default) Initialization is not complete. Initialization complete. Coefficients may be written to the equalizer. | # 7.16.5 Equalizer Start Filter Control ### Address 0x240C | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|-----------------| | | | | | _ | | | | EQ_START_FILTER | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | | Equalizer start filter. Signals whether read/write of the coefficients has completed and the equalizer can start operation. See Section 4.3 for programming examples. | | | | (Default) Coefficients are being read/written. The equalizer can start filtering based on current coefficients. | # 7.16.6 Equalizer Input Mute Control ### Address 0x240E | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|---------| | | | | | _ | | | | EQ_MUTE | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|---------|------------------------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | EQ_MUTE | Equalizer input mute. Sets the equalizer input to digital zeros with no soft ramp. See Section 4.3 for programming examples. | | | | 0 (Default) Not muted<br>1 Muted | # 7.17 AudioPort Interface Registers ### 7.17.1 Serial Port Receive Channel Select #### Address 0x2501 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---------------|---|---------------|---| | | | _ | _ | | SP_RX_CHB_SEL | | SP_RX_CHA_SEL | | | Default | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | Bits | Name | Description | | | | | | | | |------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 7:4 | _ | Reserved | | | | | | | | | 3:2 | | SP RX Channel B select for DAI0. Selects right input channel. Valid only if the SWIRE_SEL pin is deasserted. See Section 5 for programming examples. | | | | | | | | | | 02_522 | 00 Channel 0 01 (Default) Channel 1 10 Channel 2 11 Channel 3 | | | | | | | | | 1:0 | SP_RX_<br>CHA_SEL | SP RX Channel A select for DAI0. Selects right input channel. Valid only if the SWIRE_SEL pin is deasserted. 00 (Default) Channel 0 01 Channel 1 10 Channel 2 11 Channel 3 | | | | | | | | # 7.17.2 Serial Port Receive Isochronous Control #### Address 0x2502 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|-------------|---|--------------|---|----------------|----------|---------| | | _ | SP_RX_RSYNC | | SP_RX_NSB_PO | S | SP_RX_NFS_NSBB | SP_RX_IS | OC_MODE | | Default | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | Bits | Name | Description | |------|--------------|----------------------------------------------------------------------------------------------------------------------------------| | 7 | | Reserved | | 6 | SP_RX_ | Serial port receive synchronization. | | | RSYNC | O (Default) Normal state Recenter the FIFO. No read and writes when asserted | | 5:3 | SP_RX_ | Serial-port receive null-sample bit position. Selects the position of the null byte in the resultant 16-, 24-, or 32-bit sample. | | | NSB_ | For all samples, if SP_RX_ISOC_MODE ≠ 00, SP_RX_NFS_NSBB = 0, the following applies: | | | POS | For a 16-bit sample (8-bit audio + null byte), [23:16] is the null byte. | | | | • For a 24-bit sample (16-bit audio + null byte), [15:8] is the null byte. | | | | For a 32-bit sample (24-bit audio + null byte), [7:0] is the null byte. Note: NSB Mode does not support 32-bit audio samples. | | | | The ASP_RXn_CHn_RES fields in Section 7.22 set the output resolution of the ASP receive channel samples. | | | | Clearing SP_RX_NSB_POS indicates that Bit 0 must be zero for the sample to be classified as a null. | | | | 000 (Default) 0 111 7 | | 2 | SP_RX_ | Serial-port receive NSB/NFS Mode select. | | | NFS_<br>NSBB | 0 NSB Mode valid only if SP_RX_ISOC_MODE ≠ 00.<br>1 (Default) NFS Mode | | 1:0 | SP RX | Serial port receive isochronous mode. Selecting an isochronous mode allows for null removal. The ASP Rx rate bits (SP_RX_ | | | ISOC_ | FS, see p. 163) are used only to help the device determine when to insert nulls. | | | MODE | 00 (Default) Native mode 10 96k isochronous stream 01 48k isochronous stream 11 192k isochronous stream | | | | 01 48k isochronous stream 11 192k isochronous stream | # 7.17.3 Serial Port Receive Sample Rate | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|----------|---|---| | | | _ | | | | SP_RX_FS | | | | Default | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | Bits | Name | | Description | on | | |------|------|-----------------|---------------------------------|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | 7:5 | _ | Reserved | | | | | 4:0 | RX_ | | 96 or 192 kHz with respect to t | he 48-kHz isochronous rate, e.g<br>sochronous rate of 96 kHz.<br>0 1100 (Default) 48.000 kHz | | | | | 0 0001 8.00 kHz | 050 kHz 0 1010 44.100 kHz | 0 1110 88.236 kHz | 1 0001 176.472 kHz<br>1 0010 192.000 kHz<br>1 0011–1 1111 Reserved | ### 7.17.4 S/PDIF Channel Select #### Address 0x2504 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---------|---------|---------|---------| | | | _ | _ | | SPDIF_0 | CHB_SEL | SPDIF_0 | CHA_SEL | | Default | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | | Bits | Name | Description | |------|---------|-------------------------------------------------------------------------------------------------------------------| | 7:4 | _ | Reserved | | 3:2 | | S/PDIF Channel B select for DAI0. Selects right input channel. Valid only if the SWIRE_SEL pin is deasserted. See | | | CHB_SEL | Section 4.10.1 for programming details. | | | | 00 Channel 0 01 Channel 1 10 Channel 2 11 (Default) Channel 3 | | 1:0 | SPDIF_ | S/PDIF Channel A select for DAI0. Selects left input channel. Valid only if the SWIRE_SEL pin is deasserted. | | | CHA_SEL | 00 Channel 0 01 Channel 1 10 (Default) Channel 2 11 Channel 3 | # 7.17.5 Serial Port Transmit Isochronous Control #### Address 0x2505 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|-------------|---|---------------|---|----------------|-----------|---------| | | _ | SP_TX_RSYNC | | SP_TX_NSB_POS | 3 | SP_TX_NFS_NSBB | SP_TX_IS0 | OC_MODE | | Default | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | Bits | Name | Description | |------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | _ | Reserved | | 6 | | FIFO resync. Used to force the DAO FIFO into resync state, in which reads and writes are gated off. | | | RSYNC | Normal state (default) Resync state | | 5:3 | SP_TX_ | Serial-port transmit-null-sample bit position. Selects the position of the null byte in the resultant 16-, 24-, or 32-bit sample. | | | NSB_ | For all samples, if SP_TX_ISOC_MODE ≠ 00, SP_TX_NFS_NSBB = 0, the following applies: | | | POS | For a 16-bit sample (8-bit audio + null byte), [23:16] is the null byte. | | | | For a 24-bit sample (16-bit audio + null byte), [15:8] is the null byte. | | | | For a 32-bit sample (24-bit audio + null byte), [7:0] is the null byte. | | | | Note: NSB Mode does not support 32-bit audio samples. | | | | The ASP_TX_CHn_RES fields in Section 7.21 set the output resolution of the ASP transmit channel samples. | | | | Clearing SP_TX_NSB_POS indicates that Bit 0 must be zero for the sample to be classified as a null. | | | | 000 (Default) 0 111 7 | | 2 | | NFS Mode select. | | | NFS_<br>NSBB | 0 NSB Mode valid only if SP_TX_ISOC_MODE ≠ 00<br>1 (Default) NFS Mode | | 1:0 | SP_TX_<br>ISOC_<br>MODE | Serial port transmit isochronous mode. Selects the mode and rate of the isochronous stream. Selecting an isochronous mode allows for null insertion. The ASP Tx rate bits (SP_TX_FS, see p. 164) are used only to help determine when to insert nulls. 00 (Default) Native mode (no null insertion) 10 96k isochronous stream 11 192k isochronous stream | # 7.17.6 Serial Port Transmit Sample Rate | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|----------|---|---| | | | _ | | | | SP_TX_FS | | | | Default | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | | Bits | Name | | | Descriptio | n | | |------|------|---------------------------------------------------------|-------------------|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|----------------------------| | 7:5 | _ | Reserved | | | | | | 4:0 | | | | | when in Isochronous Mode. The 48-kHz isochronous rate. | is setting autoscales when | | | | 0 0000 Reserved<br>0 0001 8.00 kHz<br>0 0010 11.025 kHz | 0 0100 12.000 kHz | 0 1000 24.000 kHz<br>0 1001 32.000 kHz<br>0 1010 44.100 kHz | a 48-kHz setting in isochronou:<br>0 1100 (Default) 48.000 kHz<br>0 1101 88.200 kHz<br>0 1110 88.236 kHz<br>0 1111 96.000 kHz | 1 | ### 7.17.7 S/PDIF/SoundWire Control 1 #### Address 0x2507 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|-----------|---|--------------|---|---------------|---| | | _ | | SPDIF_RES | | SW_RES_INPUT | | SW_RES_OUTPUT | | | Default | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | Bits | Name | | | Description | | |------|-----------|-------------------------|--------------------------|-------------------------|----------------------| | 7:6 | _ | Reserved | | | | | 5:4 | SPDIF_RES | S/PDIF channel resoluti | on. See Section 4.10.1 f | or programming details. | | | | _ | 00 20 bits | 01 16 bits | 10 24 bits | 11 (Default) 32 bits | | 3:2 | SW_RES_ | ADC channel resolution | when using SoundWire. | | | | | INPUT | 00 8 bits | 01 16 bits | 10 24 bits | 11 (Default) 32 bits | | 1:0 | SW_RES_ | DAC channel resolution | when using SoundWire | | | | | OUTPUT | 00 20 bits | 01 16 bits | 10 24 bits | 11 (Default) 32 bits | # 7.18 SRC Registers # 7.18.1 SRC Input Sample Rate #### Address 0x2601 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|-------------|---|---| | | | _ | | | | SRC_SDIN_FS | | | | Default | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | | | Description | | | |------|-------------|-------------------------------------------------------------------------------------------|-----------------------------------|----------------------------------------|-------------------|------------------------------------------------------------------------------------------| | 7:5 | _ | Reserved | | | | | | 4:0 | | SRC input sample rate. Must ed | qual Fs <sub>INT</sub> if SRC_BYP | ASS_DAC = 1. | | | | | SDIN_<br>FS | 0 0000 (Default) Don't know<br>0 0001 8.00 kHz<br>0 0010 11.025 kHz<br>0 0011 11.0295 kHz | 0 0110 22.050 kHz | 0 1001 32.000 kHz<br>0 1010 44.100 kHz | 0 1110 88.236 kHz | 1 0000 176.400 kHz<br>1 0001 176.472 kHz<br>1 0010 192.000 kHz<br>1 0011–1 1111 Reserved | # 7.18.2 SRC Output Sample Rate #### Address 0x2609 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|--------------|---|---| | | | _ | | | | SRC_SDOUT_FS | | | | Default | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | | | Description | | | |------|--------------|-------------------------------------------------------------------------------------------|-------------------|----------------------------------------------------------------------------------|----------------------------------------|------------------------------------------------------------------------------------------| | 7:5 | _ | Reserved | | | | | | 4:0 | _ | SRC audio output sample rate. | | | | | | | SDOUT_<br>FS | 0 0000 (Default) Don't know<br>0 0001 8.00 kHz<br>0 0010 11.025 kHz<br>0 0011 11.0295 kHz | 0 0110 22.050 kHz | 0 1000 24.000 kHz<br>0 1001 32.000 kHz<br>0 1010 44.100 kHz<br>0 1011 44.118 kHz | 0 1101 88.200 kHz<br>0 1110 88.236 kHz | 1 0000 176.400 kHz<br>1 0001 176.472 kHz<br>1 0010 192.000 kHz<br>1 0011–1 1111 Reserved | # 7.19 DMA Registers ### 7.19.1 Soft Reset Reboot | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|----------------|---| | | | | _ | _ | • | | SFT_RST_REBOOT | _ | | Default | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | | Bits | Name | Description | |------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1 | SFT_RST_<br>REBOOT | Software reset reboot 0 (Default) Not initiated 1 Forces an internal configuration reboot to occur after a SoundWire reset. Reinitializes internal settings of the device. This must be done if a SoundWire reset has occurred. See Table 4-29. | | 0 | _ | Reserved | # 7.20 S/PDIF # 7.20.1 S/PDIF Control 1 Address 0x2801 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|--------------|--------------|--------------| | | | | _ | | | SPDIF_TX_RAW | SPDIF_TX_KAE | SPDIF_TX_PDN | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Bits | Name | Description | |------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:3 | _ | Reserved | | 2 | | S/PDIF transmit raw. Used to pass 32-bit raw (software-formatted) data from the DAI port to the S/PDIF output. The control bit's information (see Section 7.20.2) is not added to the stream. | | | | Note: The DAI input channels must be set to 32-bit width (ASP_RX0_CH1_RES, see p. 170, where RX0 Channels 1–4 and RX1 Channels 1 and 2 are configured) along with SPDIF_RES (see p. 165). 0 (Default) S/PDIF outputs up to 24 bits of data along with the control information from the S/PDIF Control 2 register. 1 S/PDIF outputs 32-bit raw (software-formatted) data. | | 1 | | S/PDIF keep alive. Transmit state depends on the SPDIF_TX_DIGEN and SPDIF_TX_PDN settings. See Table 4-20. | | | _ | Note: The value of this field has no function on the CS42L42. | | 0 | _ | S/PDIF TX power-down. | | | TX_PDN | 0 Transmit state depends on the SPDIF_TX_DIGEN and SPDIF_TX_PDN settings. See Table 4-20. 1 (Default) Powers down the S/PDIF TX circuitry. See Table 4-20. | # 7.20.2 S/PDIF Control 2 | R/W | 7 | | | 6 | | | 5 | | 4 | | 3 | | 2 | 1 | | | 0 | | |---------|--------|------|--------|------|-----|--------|------|--|-----|-----|------|--------|---|--------|-------|--------|------|-------| | | SPDIF_ | TX_L | SPDIF_ | _TX_ | PRO | SPDIF_ | _TX_ | | _TX | _CP | _TX_ | SPDIF_ | | SPDIF_ | _TX_V | SPDIF_ | _TX_ | DIGEN | | Default | 0 | | | 0 | | | 0 | | 0 | | 0 | | 0 | 0 | ) | | 0 | | | Bits | Name | Description | |------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | _ | S/PDIF transmit generation-level bit. Indicates the generation of audio material. | | | TX_L | 0 (Default) This data stream is a copy. A data stream cannot be copied from this copied stream.<br>1 The digital audio stream comes from the original and not from a copy. | | 6 | _ | S/PDIF transmit signal format select. See IEC60958-3 Digital Audio Interface—Consumer for details. | | | TX_<br>PRO | 0 (Default) Consumer format. Affects operation of SPDIF_TX_CP (Bit 4). 1 Professional audio | | 5 | SPDIF_ | S/PDIF transmit audio/nonaudio. Indicates whether data is audio data. | | | TX_<br>AUDIOB | 0 (Default) PCM format<br>1 Non-PCM format | | 4 | | S/PDIF transmit copy permit. Applicable only if SPDIF_TX_PRO = 0 (Bit 6, Consumer Mode) | | | TX_CP | 0 (Default) Copy inhibited<br>1 Copy permitted | | 3 | SPDIF_ | S/PDIF transmit filter preemphasis. | | | TX_PRE | 0 (Default) No preemphasis<br>1 Filter preemphasis 50/15 μs | | 2 | | VCFG (validity configuration). Determines S/PDIF transmitter behavior in conjunction with SPDIF_TX_V when audio data is transmitted. When asserted, this bit forces the deassertion of the S/PDIF validity flag (V), which is bit 28 transmitted in each S/PDIF subframe. The validity bit (V, bit 28) is Logic 0 if the audio sample word is suitable for conversion to an analog audio signal and is logic "1" if it is not. The SPDIF_TX_V description below describes interactions between the two bits. | | Bits | Name | | | Description | | | | | | | | | |------|--------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 1 | SPDIF_ | Validity. Affe | cts the | validity flag (V) bit 28, transmitted in each subframe in conjunction with the SPDIF_TX_VCFG setting. | | | | | | | | | | | TX_V | 0 (default)<br>1 The V bi | 0 (default) enables the S/PDIF transmitter to maintain connection during error or mute conditions. 1 The V bit in the subframe is always set to indicate invalid data | | | | | | | | | | | | | SPDIF_<br>TX_VCFG | SPDIF_<br>TX_V | Description | | | | | | | | | | | | 0 | 0 | (Default) For each S/PDIF subframe (left and right), the validity flag reflects whether an internal codec error occurred (i.e., whether the S/PDIF interface received and transmitted a valid sample). | | | | | | | | | | | | | | If a valid sample (left or right) is received and successfully transmitted, the V bit is cleared for that subframe. Otherwise, the V bit for that subframe must be transmitted as 1. | | | | | | | | | | | | 1 | 0 | For each S/PDIF subframe (left and right), the V bit reflects whether an internal codec transmission error occurred (i.e., an internal codec error should set the V bit). | | | | | | | | | | | | | | If a valid sample (left or right) is received and successfully transmitted, the V bit is cleared for that subframe. | | | | | | | | | | | | | | If the S/PDIF transmitter is not receiving a sample, the S/PDIF transmitter must set the V bit and pad each S/PDIF audio sample word in question with zeros for the corresponding subframe. | | | | | | | | | | | | 0 | 1 | Each S/PDIF subframe (left and right) is sent with the V bit set. This tags all S/PDIF subframes as invalid. | | | | | | | | | | | | 1 | 1 | Reserved | | | | | | | | | | 0 | SPDIF_ | S/PDIF trans | smit ena | ble. Determines whether data can be driven onto the S/PDIF output. | | | | | | | | | | | TX_<br>DIGEN | 0 (Default) | ) Data c | annot be driven onto the S/PDIF output. See Table 4-20. ven onto the S/PDIF output. See Table 4-20. | | | | | | | | | ### 7.20.3 S/PDIF Control 3 Address 0x2803 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|-------------|---|---|---| | | _ | | | | SPDIF_TX_CC | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|-----------------|-------------------------------------------------------------------------------------------------------| | 7 | _ | Reserved | | 6:0 | SPDIF_TX_<br>CC | S/PDIF transmit category code. Program according to the IEC60958-3 specification. 000 0000 (Default) | ### 7.20.4 S/PDIF Control 4 Address 0x2804 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---------------|---| | | | | _ | | | | SPDIF_TX_STAT | | | Default | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | | Bits | Name | Description | |------|-----------|----------------------------------------------------------------------------------------------| | 7:3 | _ | Reserved | | 2:0 | SPDIF_TX_ | S/PDIF transmit state. Configures the supported S/PDIF rate. See Section 4.10.1 for details. | | | STAT | 000 32 kHz 010 (Default) 48 kHz 100 96 kHz 110 192 kHz | | | | 001 44.1 kHz 011 88.2 kHz 101 176.4 kHz 111 Reserved | # 7.21 Serial Port Register Transmit Registers ### 7.21.1 ASP Transmit Size and Enable | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|------------|-----------| | | | | _ | _ | | | ASP_TX_2FS | ASP_TX_EN | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1 | ASP_<br>TX_<br>2FS | ASP channel data requests per frame. Used to configure the TX into Fs or 2Fs Mode. 0 (Default) Fs Mode 1 2Fs Mode (doubles the incoming LRCK rate) | | 0 | ASP_<br>TX_<br>EN | ASP TDM TX channel output enable. Configures the electrical state of the channel output phase determined by ASP_TX_CHx_RES. 0 (Default) Not enabled (Hi-Z) 1 Enabled (driven) | ### 7.21.2 ASP Transmit Channel Enable #### Address 0x2902 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---------------|---------------| | | | | _ | _ | | | ASP_TX_CH2_EN | ASP_TX_CH1_EN | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:2 | _ | Reserved | | 1 | ASP_<br>TX_<br>CH2_EN | ASP Transmit Channel 2 enable. Although two output channels exist, data from Channel 1 is replicated onto Channel 2 if ASP_TX_CH2_EN is set. As a result, Channel 2 can be used only if Channel 1 is used. This is targeted for 50/50 use, but can be used in any transmit situation with the stipulation that bit resolution must be the same for Channels 1 and 0 (ASP_TX_CH2_RES = ASP_TX_CH1_RES), along with matching MSB/LSB bit starts (ASP_TX_CH2_BIT_ST_MSB = ASP_TX_CH1_BIT_ST_MSB and ASP_TX_CH2_BIT_ST_LSB = ASP_TX_CH1_BIT_ST_LSB). However, the active phase for each channel must be different if using 50/50 Mode (ASP_TX_CH2_AP ≠ ASP_TX_CH1_AP). See Section 4.9 for details. 0 (Default) Disabled 1 Enabled | | 0 | ASP_<br>TX_<br>CH1_EN | ASP transmit Channel 1 enable. See Section 4.9 for details. 0 (Default) Disabled 1 Enabled | ### 7.21.3 ASP Transmit Channel Phase and Resolution #### Address 0x2903 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------------|---------------|---|---|---------|---------|---------|---------| | | ASP_TX_CH1_AP | ASP_TX_CH2_AP | _ | - | ASP_TX_ | CH2_RES | ASP_TX_ | CH1_RES | | Default | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | Bits | Name | Description | | | | | | | | |------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|--|--|--|--|--|--| | 7 | ASP_TX_CHx_AP | P transmit active phase. Valid only in 50/50 Mode (ASP_5050 = 1 and ASP_TX_2FS = 0). | | | | | | | | | 6 | | efault) Low. In 50/50 Mode, channel data is valid if LRCK/FSYNC is low.<br>gh. In 50/50 Mode, channel data is valid when LRCK/FSYNC is high. | | | | | | | | | 5:4 | _ | Reserved | erved | | | | | | | | 3:2 | ASP_TX_CH2_RES | | SP TX channel x bit width. Sets the output resolution of the ASP TX channel x samples. | | | | | | | | 1:0 | ASP_TX_CH1_RES | 00 8 bits per sample (valid only for isochronous NFS and native mode) 01 16 bits per sample | 10 24 bits per sample<br>11 (Default) 32 bits per sample | | | | | | | ### 7.21.4 ASP Transmit Channel 1 Bit Start MSB #### Address 0x2904 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|-----------------------| | | | | | _ | | | | ASP_TX_CH1_BIT_ST_MSB | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|------------|-------------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | | ASP transmit bit Channel 1 start MSB. Configures the MSB location of the channel with respect to SOF (LRCK edge + | | | CH1_ST_MSB | phase lag). | ### 7.21.5 ASP Transmit Channel 1 Bit Start LSB | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-----------------------|---|---|---|---|---|---|---| | | ASP_TX_CH1_BIT_ST_LSB | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|------------|-------------------------------------------------------------------------------------------------------------------| | 7:0 | | ASP transmit Channel 1 bit start LSB. Configures the LSB location of the channel with respect to SOF (LRCK edge + | | | CH1_ST_LSB | phase lag). | # 7.21.6 ASP Transmit Hi-Z and Delay Configuration Address 0x2906 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|--------------|---|----------------|---|---|---| | | | _ | ASP_TX_DRV_Z | | ASP_TX_HIZ_DLY | | _ | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | | D | escription | | |------|-------------|----------------------------------|-------------------------|-----------------------------------|----------------------| | 7:6 | _ | Reserved | | | | | 5:4 | ASP_TX_ | ASP transmit drive to Hi-Z. SDA | value for unselected bi | ts. | | | | DRV_Z | 00 (Default) Hi-Z 01 | Reserved | 10 Low | 11 High | | 3:2 | ASP_TX_HIZ_ | ASP transmit drive to Hi-Z delay | . Nominal additional de | lay to release of bit drive to Hi | -Z from sample edge. | | | DLY | 00 (Default) 0 ns 01 | ~8 ns | 10 ~16 ns | 11 Reserved | | 1:0 | _ | Reserved | | | | ### 7.21.7 ASP Transmit Channel 2 Bit Start MSB Address 0x290A | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|-----------------------| | | | | | _ | | | | ASP_TX_CH2_BIT_ST_MSB | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|-------------|-------------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | ASP_TX_BIT_ | ASP transmit Channel 2 bit start MSB. Configures the MSB location of the channel with respect to SOF (LRCK edge + | | | CH2_ST_MSB | phase lag). | ### 7.21.8 ASP Transmit Channel 2 Bit Start LSB Address 0x290B | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-----------------------|---|---|---|---|---|---|---| | | ASP_TX_CH2_BIT_ST_LSB | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|-------------|-------------------------------------------------------------------------------------------------------------------| | 7:0 | ASP_TX_BIT_ | ASP transmit Channel 2 bit start LSB. Configures the LSB location of the channel with respect to SOF (LRCK edge + | | | CH2_ST_LSB | phase lag). | # 7.22 Serial Port Receive Registers ### 7.22.1 ASP Receive Enable | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|-------------|-------------| | | ASP_RX1_<br>CH2_EN | ASP_RX1_<br>CH1_EN | ASP_RX0_<br>CH4_EN | ASP_RX0_<br>CH3_EN | ASP_RX0_<br>CH2_EN | ASP_RX0_<br>CH1_EN | ASP_RX1_2FS | ASP_RX0_2FS | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | | | | | | | | |------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 7:6 | ASP_<br>RX1_ | SP receive DAI1 enable. Determines whether the channel buffer receives data. ASP_RX1_CH1_EN = Channel 1 and SP_RX1_CH2_EN = Channel 2 | | | | | | | | | | CH[2:1]_<br>EN | Enabling is needed only when using S/PDIF in 2Fs Mode and playback in Fs Mode. (Default) The corresponding channel buffer is disabled. The corresponding channel buffer receives data. | | | | | | | | | 5:2 | ASP_ | ASP receive DAI0 enable. Determines whether the channel buffer gets populated. | | | | | | | | | | RX0_ | ASP_RX0_CH1_EN = Channel 1 ASP_RX0_CH3_EN = Channel 3 | | | | | | | | | | CH[4:1]_ | | | | | | | | | | | EN | (Default) The corresponding channel buffer does not get populated. The corresponding channel buffer is populated | | | | | | | | | 1 | ASP_ | ASP receive DAI1 double-rate mode. | | | | | | | | | | RX1_<br>2FS | 0 (Default) Standard sample rate, Fs (not doubled)<br>1 Sample rate is doubled, 2 Fs | | | | | | | | | 0 | ASP_ | ASP receive DAI0 double-rate mode. | | | | | | | | | | RX0_<br>2FS | 0 (Default) Standard sample rate, Fs (not doubled)<br>1 Sample rate is doubled, 2 Fs | | | | | | | | ### 7.22.2 ASP Receive DAI0 Channel 1 Phase and Resolution #### Address 0x2A02 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|----------------|---|---|---|---|----------|----------| | | _ | ASP_RX0_CH1_AP | | _ | _ | | ASP_RX0_ | _CH1_RES | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | Bits | Name | Description | | | | | | | | |------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--|--|--|--|--|--| | 7 | _ | served | | | | | | | | | 6 | | ASP receive DAI0 active phase. Valid only in 50/50 Mode (ASP_5050 = 1 and ASP_RXx_2FS = 0). | receive DAI0 active phase. Valid only in 50/50 Mode (ASP_5050 = 1 and ASP_RXx_2FS = 0). | | | | | | | | | CH1_AP | (Default) Low. In 50/50 Mode, channel data is valid if LRCK/FSYNC is low.<br>High. In 50/50 Mode, channel data is valid when LRCK/FSYNC is high. | | | | | | | | | 5:2 | _ | Reserved | | | | | | | | | 1:0 | ASP_RX0_<br>CH1_RES | ASP Receive DAI0 channel bit width. Sets output resolution of the ASP receive DAI0 channel x samples. 00 8 bits per sample (only for isochronous NFS and native modes) 01 16 bits per sample 11 (Default) 32 bits per sample | | | | | | | | ### 7.22.3 ASP Receive DAI0 Channel 1 Bit Start MSB #### Address 0x2A03 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|------------------------| | | | | | _ | | | | ASP_RX0_CH1_BIT_ST_MSB | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Π | Bits | Name | Description | |---|------|------|----------------------------------------------------------------------------------------------------------------------------------| | | 7:1 | _ | Reserved | | | 0 | | ASP receive DAI0 Channel 1 bit start MSB. Configures the MSB location of the channel with respect to SOF (LRCK edge + phase lag) | ### 7.22.4 ASP Receive DAI0 Channel 1 Bit Start LSB #### Address 0x2A04 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|------------|--------------|---|---|---| | | | | | ASP_RX0_CH | 1_BIT_ST_LSB | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ſ | Bits | Name | Description | |---|------|--------------|----------------------------------------------------------------------------------------------------------------| | Г | 7:0 | ASP_RX0_CH1_ | ASP receive DAI0 Channel 1 bit start LSB. Configures the LSB location of the channel with respect to SOF (LRCK | | | | BIT_ST_LSB | edge + phase lag) | #### 7.22.5 ASP Receive DAI0 Channel 2 Phase and Resolution ### Address 0x2A05 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|----------------|---|---|---|---|---|----------| | | _ | ASP_RX0_CH2_AP | | _ | _ | | | _CH2_RES | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | Bits | Name | Description | |------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | _ | Reserved | | 6 | | ASP receive DAI0 active phase. Valid only in 50/50 Mode (ASP_5050 = 1 and ASP_RXx_2FS = 0). | | | CH2_AP | 0 (Default) Low. In 50/50 Mode, channel data is input when LRCK/FSYNC is low.<br>1 High. In 50/50 Mode, channel data is input when LRCK/FSYNC is high. | | 5:2 | _ | Reserved | | 1:0 | ASP_RX0_ | ASP receive DAI0 channel bit width. Sets the output resolution of the ASP receive DAI0 channel x samples. | | | CH2_RES | 00 8 bits per sample (valid only for isochronous NFS and native mode) 10 24 bits per sample 11 (Default) 32 bits per sample | ### 7.22.6 ASP Receive DAI0 Channel 2 Bit Start MSB | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|------------------------| | | | | | _ | | | | ASP_RX0_CH2_BIT_ST_MSB | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|------|-----------------------------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | | ASP receive DAI0 Channel 2 bit start MSB. Configures the MSB location of the channel with respect to SOF (LRCK edge + phase lag). | ### 7.22.7 ASP Receive DAI0 Channel 2 Bit Start LSB Address 0x2A07 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|-------------|--------------|---|---|---| | | | | | ASP_RX0_CH2 | 2_BIT_ST_LSB | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits | Name | Description | |---|------|--------------|----------------------------------------------------------------------------------------------------------------| | ſ | 7:0 | ASP_RX0_CH2_ | ASP receive DAI0 Channel 2 bit start LSB. Configures the LSB location of the channel with respect to SOF (LRCK | | | | BIT_ST_LSB | edge + phase lag). | ### 7.22.8 ASP Receive DAI0 Channel 3 Phase and Resolution Address 0x2A08 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|----------------|---|---|---|---|---------|----------| | | _ | ASP_RX0_CH3_AP | | _ | _ | | ASP_RX0 | _CH3_RES | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | Bits | Name | Description | |------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | _ | Reserved | | 6 | ASP_<br>RX0_<br>CH3_AP | ASP receive DAI0 active phase. Valid only in 50/50 Mode (ASP_5050 = 1 and ASP_RXx_2FS = 0). 0 (Default) Low. In 50/50 Mode, channel data is input when LRCK/FSYNC is low. 1 High. In 50/50 Mode, channel data is input when LRCK/FSYNC is high. | | 5:2 | _ | Reserved | | 1:0 | ASP_<br>RX0_<br>CH3_RES | ASP receive DAI0 channel bit width. Sets the output resolution of the ASP receive DAI0 channel x samples. 00 8 bits per sample (valid only for isochronous NFS and native mode) 10 24 bits per sample 11 (Default) 32 bits per sample | ### 7.22.9 ASP Receive DAI0 Channel 3 Bit Start MSB Address 0x2A09 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|------------------------| | | | | | _ | • | | | ASP_RX0_CH3_BIT_ST_MSB | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|--------------|----------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | ASP_RX0_CH3_ | ASP receive DAI0 Channel 3 bit start MSB. Configures the MSB location of the channel with respect to SOF (LRCK | | | BIT ST MSB | edge + phase lag) | ### 7.22.10 ASP Receive DAI0 Channel 3 Bit Start LSB Address 0x2A0A | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|-------------|--------------|---|---|---| | | | | | ASP_RX0_CH3 | B_BIT_ST_LSB | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|--------------|----------------------------------------------------------------------------------------------------------------| | 7:0 | ASP_RX0_CH3_ | ASP receive DAI0 Channel 3 bit start LSB. Configures the LSB location of the channel with respect to SOF (LRCK | | | BIT_ST_LSB | edge + phase lag) | ### 7.22.11 ASP Receive DAI0 Channel 4 Phase and Resolution Address 0x2A0B | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|----------------|---|---|---|---|---------|----------| | | _ | ASP_RX0_CH4_AP | _ | | | | ASP_RX0 | _CH4_RES | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | Bits | Name | Description | | | | | |------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 7 | _ | Reserved | | | | | | 6 | ASP_ | SP receive DAI0 active phase. Valid only in 50/50 Mode (ASP_5050 = 1 and ASP_RXx_2FS = 0). | | | | | | | RX0_<br>CH4_AP | 0 (Default) Low. In 50/50 Mode, channel data is input when LRCK/FSYNC is low.<br>1 High. In 50/50 Mode, channel data is input when LRCK/FSYNC is high. | | | | | | 5:2 | _ | Reserved | | | | | | 1:0 | ASP_<br>RX0_<br>CH4_RES | ASP receive DAI0 channel bit width. Sets the output resolution of the ASP receive DAI1 channel x samples. 00 8 bits per sample (valid only for isochronous NFS and native mode) 10 24 bits per sample 01 16 bits per sample 11 (Default) 32 bits per sample | | | | | | 7.22.12 ASP Receive DAI0 | Channel 4 | Bit Start | MSB | |--------------------------|-----------|-----------|-----| |--------------------------|-----------|-----------|-----| | Address 0x | 2/ | ۷O | C | |------------|----|----|---| |------------|----|----|---| | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|------------------------| | | | | | _ | | | | ASP_RX0_CH4_BIT_ST_MSB | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|--------------|----------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | ASP_RX0_CH4_ | ASP receive DAI0 Channel 4 bit start MSB. Configures the MSB location of the channel with respect to SOF (LRCK | | | BIT_ST_MSB | edge + phase lag) | ### 7.22.13 ASP Receive DAI0 Channel 4 Bit Start LSB #### Address 0x2A0D | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|------------|--------------|---|---|---| | | | | | ASP_RX0_CH | 1_BIT_ST_LSB | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | | Description | |------|--------------|----------------------------------------------------------------------------------------------------------------| | 7:0 | ASP_RX0_CH4_ | ASP receive DAI0 Channel 4 bit start LSB. Configures the LSB location of the channel with respect to SOF (LRCK | | | BIT_ST_LSB | edge + phase lag) | ### 7.22.14 ASP Receive DAI1 Channel 1 Phase and Resolution #### Address 0x2A0E | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|----------------|---|---|---|---|---------|----------| | | _ | ASP_RX1_CH1_AP | | _ | _ | | ASP_RX1 | _CH1_RES | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | Bits | Name | Description | |------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | _ | Reserved | | 6 | ASP_ | ASP receive DAI1 active phase. Valid only in 50/50 Mode (ASP_5050 = 1 and ASP_RXx_2FS = 0). | | | RX1_<br>CH1_AP | 0 (Default) Low. In 50/50 Mode, channel data is input when LRCK/FSYNC is low.<br>1 High. In 50/50 Mode, channel data is input when LRCK/FSYNC is high. | | 5:2 | _ | Reserved | | 1:0 | _ | ASP receive DAI1 channel bit width. Sets the output resolution of the ASP receive DAI1 channel x samples. | | | RX1_<br>CH1_RES | 00 8 bits per sample (valid only for isochronous NFS and native mode) 10 24 bits per sample 11 (Default) 32 bits per sample | ### 7.22.15 ASP Receive DAI1 Channel 1 Bit Start MSB #### Address 0x2A0F | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|------------------------| | | | | | _ | | | | ASP_RX1_CH1_BIT_ST_MSB | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|--------------|----------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | ASP_RX1_CH1_ | ASP receive DAI1 Channel 1 bit start MSB. Configures the MSB location of the channel with respect to SOF (LRCK | | | BIT_ST_MSB | edge + phase lag) | ### 7.22.16 ASP Receive DAI1 Channel 1 Bit Start LSB | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|------------|--------------|---|---|---| | | | | | ASP_RX1_CH | 1_BIT_ST_LSB | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits | Name | Description | |---|------|--------------|----------------------------------------------------------------------------------------------------------------| | 7 | 7:0 | ASP_RX1_CH1_ | ASP receive DAI1 Channel 1 bit start LSB. Configures the LSB location of the channel with respect to SOF (LRCK | | | | BIT_ST_LSB | edge + phase lag). | ### 7.22.17 ASP Receive DAI1 Channel 2 Phase and Resolution Address 0x2A11 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|----------------|---|---|---|---|---------|----------| | | _ | ASP_RX1_CH2_AP | | _ | _ | | ASP_RX1 | _CH2_RES | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | Bits | Name | Description | |------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | | Reserved | | 6 | ASP_ | ASP receive DAI1 active phase. Valid only in 50/50 Mode (ASP_5050 = 1 and ASP_RXx_2FS = 0). | | | RX1_<br>CH2_AP | 0 (Default) Low. In 50/50 Mode, channel data is input when LRCK/FSYNC is low.<br>1 High. In 50/50 Mode, channel data is input when LRCK/FSYNC is high. | | 5:2 | _ | Reserved | | 1:0 | ASP_<br>RX1_<br>CH2_RES | ASP receive DAI1 channel bit width. Sets the output resolution of the ASP receive DAI1 Channel x samples. 00 8 bits per sample (valid only for isochronous NFS and native mode) 10 24 bits per sample 11 (Default) 32 bits per sample | ### 7.22.18 ASP Receive DAI1 Channel 2 Bit Start MSB Address 0x2A12 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|------------------------| | | | | | _ | | | | ASP_RX1_CH2_BIT_ST_MSB | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|------|----------------------------------------------------------------------------------------------------------------------------------| | 7:1 | _ | Reserved | | 0 | | ASP receive DAI1 Channel 2 bit start MSB. Configures the MSB location of the channel with respect to SOF (LRCK edge + phase lag) | ### 7.22.19 ASP Receive DAI1 Channel 2 Bit Start LSB Address 0x2A13 | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|-------------|--------------|---|---|---| | | | | | ASP_RX1_CH2 | 2_BIT_ST_LSB | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits | Name | Description | |------|--------------|----------------------------------------------------------------------------------------------------------------| | 7:0 | ASP_RX1_CH2_ | ASP receive DAI1 Channel 2 bit start LSB. Configures the LSB location of the channel with respect to SOF (LRCK | | | BIT ST LSB | edge + phase lag) | # 7.23 ID Registers ### 7.23.1 Subrevision | R/O | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-------------|---|---|---|---|---|---|---| | | SUBREVISION | | | | | | | | | Default | х | х | х | х | х | х | х | х | | Bits | Name | Description | |------|-------------|----------------------------------------------------------------------------------------------------------------------| | 7:0 | SUBREVISION | Subrevision. Identifies the CS42L42 subrevision. The Page 0x30 read sequence in Section 5.4 must be followed to read | | | | this register. | | | | 0000 0011 Initial version. | ## 8 PCB Layout Considerations The following sections provide general guidelines for PCB layout to ensure the best performance of the CS42L42. ### 8.1 Power Supply As with any high-resolution converter, to realize its potential, the CS42L42 requires careful attention to power supply and grounding arrangements. Fig. 2-1 and Fig. 2-2 show the recommended power arrangements, with VA and VCP connected to clean supplies. VL, which powers the digital circuitry, may be run from the system logic supply. Alternatively, VL may be powered from the analog supply via a ferrite bead. In this case, no additional devices should be powered from VL. ### 8.2 Grounding Note the following: - Extensive use of power and ground planes, ground-plane fill in unused areas, and surface-mount decoupling capacitors are recommended. - Decoupling capacitors should be as close as possible to the CS42L42 pins. - To minimize inductance effects, the low-value ceramic capacitor must be closest to the pin and mounted on the same side of the board as the CS42L42. - To avoid unwanted coupling into the modulators, all signals, especially clocks, must be isolated from the FILT+ pin. - The FILT+ capacitor must be positioned to minimize the electrical path from the pin to GNDA. - The +VCP\_FILT and –VCP\_FILT capacitors must be positioned to minimize the electrical path from each respective pin to GNDCP. ### 8.3 QFN Thermal Pad The CS42L42 comes in a compact QFN package, the underside of which reveals a large metal pad that serves as a thermal relief to provide maximum heat dissipation. This pad must mate with a matching copper pad on the PCB and must be electrically connected to ground. A series of vias should be used to connect this copper pad to one or more larger ground planes on other PCB layers. For best performance in split-ground systems, connect this thermal to GNDA. # 9 Plots # 9.1 Digital Filter Response # 9.1.1 Highpass Filter—ADC Figure 9-1. ADCx\_HPF\_CF = 00 Figure 9-3. ADCx\_HPF\_CF = 10 Figure 9-2. ADCx\_HPF\_CF = 01 Figure 9-4. ADCx\_HPF\_CF = 11 # 9.1.2 Highpass Filter—DAC Figure 9-5. DAC HPF Response ### 9.1.3 ADC, Notch Filter Disabled Figure 9-6. Passband—ADC, Notch Disabled Figure 9-8. Transition Band—ADC, Notch Disabled Figure 9-7. Stopband—ADC, Notch Disabled Figure 9-9. Phase Response—ADC, Notch Disabled # 9.1.4 ADC, Notch Filter Enabled Figure 9-10. Passband—ADC, Notch Enabled Figure 9-12. Transition Band—ADC, Notch Enabled Figure 9-11. Stopband—ADC, Notch Enabled Figure 9-13. Phase Response—ADC, Notch Enabled # 9.1.5 DAC to HP, Fs<sub>int</sub> = 44.118 kHz, MCLK = 136 x LRCK Figure 9-14. Passband—DAC, Fs<sub>int</sub> = 44.118 kHz Figure 9-16. Transition Band—DAC, Fs<sub>int</sub> = 44.118 kHz Figure 9-18. Phase Response—DAC, Fs<sub>int</sub> = 44.118 kHz Figure 9-15. Stopband—DAC, Fs<sub>int</sub> = 44.118 kHz Figure 9-17. Transition Band (Detail)—DAC, Fs<sub>int</sub> = 44.118 kHz # 9.1.6 DAC to HP, Fs<sub>int</sub> = 48.000 kHz, MCLK = 125 x LRCK Figure 9-19. Passband—DAC, Fs<sub>int</sub> = 48.000 kHz Figure 9-21. Transition Band—DAC, Fs<sub>int</sub> = 48.000 kHz Figure 9-23. Phase Response—DAC, Fs<sub>int</sub> = 48.000 kHz Figure 9-20. Stopband—DAC, Fs<sub>int</sub> = 48.000 kHz Figure 9-22. Transition Band (Detail)—DAC, Fs<sub>int</sub> = 48.000 kHz # 9.1.7 $x_SDOUT$ and $x_SDIN$ ASRC, $Fs_{INT} = 48$ kHz Figure 9-24. Passband—ASRC, Notch Disabled Figure 9-26. Transition Band—ASRC, Notch Disabled Figure 9-25. Stopband—ASRC, Notch Disabled Figure 9-27. Phase Response—ASRC, Notch Disabled # 9.2 Windnoise Filter Responses Figure 9-28. Windnoise Filter Frequency Response Figure 9-29. Windnoise Filter Transition Band Figure 9-30. Windnoise Filter Phase Response Figure 9-31. Windnoise Filter Delay # 9.3 HSBIAS Current Sense vs. VP Voltage per Trip Setting Figure 9-32. HS Bias Current Sense vs. VP Voltage for Each Trip Setting (HS BIAS = 2-V Mode) # 10 Package Dimensions # 10.1 WLCSP Package Dimensions #### Notes: - Dimensioning and tolerances per ASME Y 14.5M-1994. - The Ball A1 position indicator is for illustration purposes only and may not be to scale. Dimension "b" applies to the solder sphere diameter and is measured at the maximum solder-ball diameter, parallel to primary Datum Z. Table 10-1. WLCSP Package Dimensions | Dimension | Millimeters | | | | | | |----------------------------|-------------|---------|---------|--|--|--| | Dilliension | Minimum | Nominal | Maximum | | | | | A | 0.443 | 0.474 | 0.505 | | | | | A1 | 0.148 | 0.174 | 0.200 | | | | | A2 | 0.284 | 0.300 | 0.316 | | | | | M | BSC | 2.100 | BSC | | | | | N | BSC | 2.100 | BSC | | | | | b | 0.225 | 0.250 | 0.300 | | | | | С | REF | 0.272 | REF | | | | | d | REF | 0.272 | REF | | | | | е | BSC | 0.350 | BSC | | | | | X | 2.614 | 2.644 | 2.674 | | | | | Y | 2.614 | 2.644 | 2.674 | | | | | ccc = 0.015<br>ddd = 0.015 | | | | | | | Note: Controlling dimension is millimeters. # 10.2 QFN Package Dimensions Table 10-2. QFN Package Dimensions | Dimension | mm | | | | | | |-------------|----------|-----------|---------|--|--|--| | Dilliension | Minimum | Nominal | Maximum | | | | | Α | 0.70 | 0.75 | 0.80 | | | | | A1 | 0.00 | 0.035 | 0.05 | | | | | A2 | _ | 0.55 | _ | | | | | A3 | | 0.203 REF | | | | | | b | 0.15 | 0.20 | 0.25 | | | | | D | 6.00 BSC | | | | | | | K | 4.4 | 4.5 | 4.6 | | | | | е | 0.40 BSC | | | | | | | Е | 6.00 BSC | | | | | | | J | 4.4 | 4.5 | 4.6 | | | | | L | 0.35 | 0.40 | 0.45 | | | | | aaa | 0.10 | | | | | | | bbb | 0.10 | | | | | | | ccc | 0.08 | | | | | | | ddd | 0.10 | | | | | | | eee | 0.10 | | | | | | # 11 Thermal Characteristics Table 11-1. Typical JEDEC Four-Layer, 2s2p Board Thermal Characteristics | Parameter <sup>1</sup> | Symbol | QFN | WLCSP | Unit | |------------------------------------------------------------|-------------------|------|-------|------| | Junction-to-ambient thermal resistance | $\theta_{\sf JA}$ | 28.9 | 52.0 | °C/W | | Junction-to-board thermal resistance | $\theta_{JB}$ | 3.8 | 17.8 | °C/W | | Junction-to-case thermal resistance | $\theta_{\sf JC}$ | 2.7 | 0.15 | °C/W | | Junction-to-board thermal-characterization parameter | $\Psi_{JB}$ | 3.6 | 17.7 | °C/W | | Junction-to-package-top thermal-characterization parameter | $\Psi_{JT}$ | 0.1 | 0.04 | °C/W | <sup>1.</sup> Thermal setup: Still air @ maximum allowed ambient temperature JEDEC 2s2p printed wiring board (JEDEC Standard JESD51-11, June 2001) Size: 114.5 x 101.5 x 1.6 mm # 12 Ordering Information Table 12-1. Ordering Information | Product | Description | Package | RoHS<br>Compliant | Grade | Temperature<br>Range | Container | Order# | |---------|---------------------------------------------------------------------------------|------------------|-------------------|------------------------|----------------------|---------------|--------------| | CS42L42 | Low-Power Audio<br>Codec with<br>SoundWire®–l2S/<br>TDM and Audio<br>Processing | 49-ball<br>WLCSP | Yes | Extended<br>Commercial | -40 to +85°C | Tape and reel | CS42L42-CWZR | | | | 48-pin QFN Yes | Extended | -40 to +85°C | Tape and reel | CS42L42-CNZR | | | | | | | Commercial | | Tray | CS42L42-CNZ | ### 13 References - MIPI SoundWire Specification, Version 1.0. - International Electrotechnical Commission, IEC60958-3 Digital Audio Interface—Consumer, http://www.ansi.org/ - NXP Semiconductors, UM10204 Rev. 06, April 2014, The I<sup>2</sup>C-Bus Specification and User Manual, http://www.nxp.com - JEDEC Solid State Technology Association, *Guidelines for Reporting and Using Electronic Package Thermal Information*, *JEDEC Standard No. 51-12.01*, November 2012, http://www.jedec.org/ # 14 Revision History Table 14-1. Revision History | Revision | Changes | |----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | F4<br>DEC 2018 | <ul> <li>Updated headset connection in Fig. 2-1, Fig. 2-2, and Fig. 4-43.</li> <li>Updated minimum and maximum values for the external voltage applied to pin parameter in Table 3-2.</li> </ul> | | 220 2010 | Minor correction for the HS bias transition time Condition 5 parameter in Table 3-15. | | | Updated Footnote 2 and 3 in Table 3-22. Added a note about interphenomenable terms in Section 4. Provided Footnote 2 and 3 in Table 3-22. | | | <ul> <li>Added a note about interchangeable terms in Section 4.</li> <li>Minor update to Step 9 in Section 4.4.4.</li> </ul> | | | Minor update to last sentence in Section 4.7.1.2. | | | Updated Fig. 4-34. | | | <ul> <li>Clarified behavior of VP Monitor in Section 4.15.1.</li> <li>Added Section 4.19, FILT+ Operation.</li> </ul> | | | <ul> <li>Added a note about setting or clearing specific enable bits before performing any power-up sequence in Section 5.1.</li> <li>Updated bit field names and descriptions for ASP Receive Enable in Ex. 5-1, Ex. 5-2, Section 6.23, and Section 7.22.1.</li> <li>Corrected bit field value for PDN_ALL in Step 4 of Ex. 5-2.</li> </ul> | | | <ul> <li>Updated Step 9 in Ex. 5-4.</li> <li>Updated descriptions for ASP_SCPOL_IN_ADC and ASP_SCPOL_IN_DAC in Section 7.5.7.</li> </ul> | | | Removed Footnote 1 in Table 12-1. | | | Updated legal boilerplate wording. | | F5<br>NOV 2019 | <ul> <li>Updated Section 4.15.</li> <li>Updated legal boilerplate wording.</li> </ul> | | 140 7 2013 | opuated legal bollerplate wording. | | F6 | Corrected the Reserved and SRC_SDIN_FS register field value in Step 4.17 of Ex. 5-1. | | OCT 2020 | Updated the QFN thermal characteristics in Table 11-1, Typical JEDEC Four-Layer, 2s2p Board Thermal Characteristics. | | F7 | Added stereo and mono output mode A-weighted THD+N specifications to front page feature list. | | JUN 2025 | <ul> <li>Added A-weighted calculations of existing dynamic range and THD+D specifications to Table 3-13, as well as added<br/>single-ended and differential specification details. A-weighted calculations are determined based on original component level<br/>qualification.</li> </ul> | | F8<br>AUG 2025 | Updated typical values based on original qualification for dynamic range specification (Mono output mode) in Table 3-13. | **Important**: Please check with your Cirrus Logic sales representative to confirm that you are using the latest revision of this document and to determine whether there are errata associated with this device. ### **Contacting Cirrus Logic Support** For all product questions and inquiries, contact a Cirrus Logic Sales Representative. To find the one nearest you, go to www.cirrus.com. #### **IMPORTANT NOTICE** The products and services of Cirrus Logic International (UK) Limited; Cirrus Logic, Inc.; and other companies in the Cirrus Logic group (collectively either "Cirrus Logic" or "Cirrus") are sold subject to Cirrus Logic's terms and conditions of sale supplied at the time of order acknowledgment, including those pertaining to warranty, indemnification, and limitation of liability. Software is provided pursuant to applicable license terms. Cirrus Logic reserves the right to make changes to its products and specifications or to discontinue any product or service without notice. Customers should therefore obtain the latest version of relevant information from Cirrus Logic to verify that the information is current and complete. Testing and other quality control techniques are utilized to the extent Cirrus Logic deems necessary. Specific testing of all parameters of each device is not necessarily performed. In order to minimize risks associated with customer applications, the customer must use adequate design and operating safeguards to minimize inherent or procedural hazards. Cirrus Logic is not liable for applications assistance or customer product design. The customer is solely responsible for its overall product design, end-use applications, and system security, including the specific manner in which it uses Cirrus Logic components. Certain uses or product designs may require an intellectual property license from a third party. Features and operations described herein are for illustrative purposes only and do not constitute a suggestion or instruction to adopt a particular product design or a particular mode of operation for a Cirrus Logic component. CIRRUS LOGIC PRODUCTS ARE NOT DESIGNED, TESTED, INTENDED OR WARRANTED FOR USE (1) WITH OR IN IMPLANTABLE PRODUCTS OR FDA/MHRA CLASS III (OR EQUIVALENT CLASSIFICATION) MEDICAL DEVICES, OR (2) IN ANY PRODUCTS, APPLICATIONS OR SYSTEMS, INCLUDING WITHOUT LIMITATION LIFE-CRITICAL MEDICAL EQUIPMENT OR SAFETY OR SECURITY EQUIPMENT, WHERE MALFUNCTION OF THE PRODUCT COULD CAUSE PERSONAL INJURY, DEATH, SEVERE PROPERTY DAMAGE OR SEVERE ENVIRONMENTAL HARM. INCLUSION OF CIRRUS LOGIC PRODUCTS IN SUCH APPLICATIONS IS UNDERSTOOD TO BE FULLY AT THE CUSTOMER'S RISK AND CIRRUS LOGIC DISCLAIMS AND MAKES NO WARRANTY, EXPRESS, STATUTORY OR IMPLIED, INCLUDING THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR PARTICULAR PURPOSE, WITH REGARD TO ANY CIRRUS LOGIC PRODUCT THAT IS USED IN SUCH A MANNER. IF THE CUSTOMER OR CUSTOMER'S CUSTOMER USES OR PERMITS THE USE OF CIRRUS LOGIC PRODUCTS IN SUCH A MANNER, CUSTOMER AGREES, BY SUCH USE, TO FULLY INDEMNIFY CIRRUS LOGIC, ITS OFFICERS, DIRECTORS, EMPLOYEES, DISTRIBUTORS AND OTHER AGENTS FROM ANY AND ALL LIABILITY, INCLUDING ATTORNEYS' FEES AND COSTS, THAT MAY RESULT FROM OR ARISE IN CONNECTION WITH THESE USES. This document is the property of Cirrus Logic, and you may not use this document in connection with any legal analysis concerning Cirrus Logic products described herein. No license to any technology or intellectual property right of Cirrus Logic or any third party is granted herein, including but not limited to any patent right, copyright, mask work right, or other intellectual property rights. Any provision or publication of any third party's products or services does not constitute Cirrus Logic's approval, license, warranty or endorsement thereof. Cirrus Logic gives consent for copies to be made of the information contained herein only for use within your organization with respect to Cirrus Logic integrated circuits or other products of Cirrus Logic, and only if the reproduction is without alteration and is accompanied by all associated copyright, proprietary and other notices and conditions (including this notice). This consent does not extend to other copying such as copying for general distribution, advertising or promotional purposes, or for creating any work for resale. This document and its information is provided "AS IS" without warranty of any kind (express or implied). All statutory warranties and conditions are excluded to the fullest extent possible. No responsibility is assumed by Cirrus Logic for the use of information herein, including use of this information as the basis for manufacture or sale of any items, or for infringement of patents or other rights of third parties. Cirrus Logic, Cirrus, the Cirrus Logic logo design, and SoundClear are among the trademarks of Cirrus Logic. Other brand and product names may be trademarks or service marks of their respective owners. Copyright © 2014–2025 Cirrus Logic, Inc. and Cirrus Logic International Semiconductor Ltd. All rights reserved. MIPI and SoundWire are registered marks of MIPI Alliance, Inc.